<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    溫馨提示:您的每一次轉載,體現了我寫此文的意義!!!煩請您在轉載時注明出處http://www.tkk7.com/sxyx2008/謝謝合作!!!

    雪山飛鵠

    溫馨提示:您的每一次轉載,體現了我寫此文的意義!!!煩請您在轉載時注明出處http://www.tkk7.com/sxyx2008/謝謝合作!!!

    BlogJava 首頁 新隨筆 聯系 聚合 管理
      215 Posts :: 1 Stories :: 674 Comments :: 0 Trackbacks
    1. 單臺Linux服務器中如何部署多個獨立應用,即多個應用不能run在一個jboss實例中?
      換言之,這個問題也可以這樣描述:在單臺Linux服務器中服務啟動多個Jboss實例?
      默認情況下,jboss啟動時加載server/default/目錄下的配置,要實現多個實例的啟動,主要是解決端口沖突的問題,因為一套端口只能被一個應用占有;
      一般來說,我們可以在Jboss啟動時通過-Djboss.server.home設置當前實例啟動時加載不同的目錄來實現;
      比如Jboss主程序安裝在/usr/xx/jboss/,應用放在/home/admin/app/;那此時就可以cp一份default目錄到當前應用app目錄下,通過-Djboss.server.home=/home/admin/app/default來啟動該實例;
      若直接在/usr/xx/jboss/server/下復制default目錄并改名為yy,則可以用更簡單的參數-c yy來啟動;
      對于多應用的情況,我們仍然要解決端口沖突的問題,有兩種方式:
      其一,直接修改各應用對應的default目錄下的所有配置端口,主要涉及配置文件conf/jboss-service.xml、tomcat下的server.xml;該方法比較土,很容易出錯,因為端口眾多,只要有一項端口沒有改,jboss就將無法正常啟動;若應用較少,比如就只有2個,那這種方式勉強可以用用;
      其二,在jboss-service.xml中啟用jboss.system:service=ServiceBindingManager這個mbean服務,設置ServerName、StoreURL屬性;將各套應用對應的端口全部配置在同一個文件中;推薦采用該方案,具體可參考:

    1. <mbean code="org.jboss.services.binding.ServiceBindingManager" 
    2.   name="jboss.system:service=ServiceBindingManager"> 
    3.   <attribute name="ServerName">ports-01</attribute> 
    4.   <attribute name="StoreURL">${jboss.home.url}/docs/examples/binding-manager/sample-bindings.xml</attribute> 
    5.   <attribute name="StoreFactoryClassName"> 
    6.     org.jboss.services.binding.XMLServicesStoreFactory 
    7.   </attribute> 
    8. </mbean> 

     

  • Jboss無法正常啟動,報異常javax.management.MBeanRegistrationException: preRegister() failed?
    一般來說,上面的異常出現在4.2及其以后的版本中,比較詳細的異常如下:
    1. javax.management.MBeanRegistrationException: preRegister() failed: [ObjectName='jboss.remoting:service=NetworkRegistry', Class=org.jboss.remoting.network.NetworkRegistry (org.jboss.remoting.network.NetworkRegistry@16b6c55)] 
    2.         at org.jboss.mx.server.registry.BasicMBeanRegistry.invokePreRegister(BasicMBeanRegistry.java:713
    3.         at org.jboss.mx.server.registry.BasicMBeanRegistry.registerMBean(BasicMBeanRegistry.java:211
    4.         at sun.reflect.GeneratedMethodAccessor1.invoke(Unknown Source) 
    5.         at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25
    6.         at java.lang.reflect.Method.invoke(Method.java:585
    7.         at org.jboss.mx.interceptor.ReflectedDispatcher.invoke(ReflectedDispatcher.java:155
    8.         ... 51 more 
    9. Caused by: java.lang.RuntimeException: Exception creating identity: mall_dev4: mall_dev4 
    10.         at org.jboss.remoting.ident.Identity.get(Identity.java:211
    11.         at org.jboss.remoting.network.NetworkRegistry.preRegister(NetworkRegistry.java:268
    12.         at org.jboss.mx.server.AbstractMBeanInvoker.invokePreRegister(AbstractMBeanInvoker.java:966
    13.         at org.jboss.mx.modelmbean.ModelMBeanInvoker.invokePreRegister(ModelMBeanInvoker.java:489
    14.         at org.jboss.mx.server.AbstractMBeanInvoker.preRegister(AbstractMBeanInvoker.java:654
    15.         at org.jboss.mx.server.registry.BasicMBeanRegistry.invokePreRegister(BasicMBeanRegistry.java:697
    16.         ... 56 more 

    這主要是因為Jboss啟動了一個jboss.remoting:service=NetworkRegistry的mbean服務,啟動時卻又無法根據當前hostname找到IP!
    解決方案為在/etc/hosts中綁定當前服務器的主機名和IP,比如10.2.224.214 mall_dev4;
    對于4.2系列之前的版本,如果沒有綁定主機名和IP,雖然會出現以下的異常,但并不一定會影響應用的正常啟動;
    1. 11:32:12,427 WARN  [ServiceController] Problem starting service jboss:service=invoker,type=http 
    2. java.net.UnknownHostException: mall_dev4: mall_dev4 
    3.         at java.net.InetAddress.getLocalHost(InetAddress.java:1308
    4.         at org.jboss.invocation.http.server.HttpInvoker.checkInvokerURL(HttpInvoker.java:204
    5.         at org.jboss.invocation.http.server.HttpInvoker.startService(HttpInvoker.java:101
    6.         at org.jboss.system.ServiceMBeanSupport.jbossInternalStart(ServiceMBeanSupport.java:289
    7.         at org.jboss.system.ServiceMBeanSupport.jbossInternalLifecycle(ServiceMBeanSupport.java:245
    8.         at sun.reflect.GeneratedMethodAccessor2.invoke(Unknown Source) 
    9.         at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25
    10.         at java.lang.reflect.Method.invoke(Method.java:585
    11.         at org.jboss.mx.interceptor.ReflectedDispatcher.invoke(ReflectedDispatcher.java:155
    12.         at org.jboss.mx.server.Invocation.dispatch(Invocation.java:94
    13.         at org.jboss.mx.server.Invocation.invoke(Invocation.java:86
    14.         at org.jboss.mx.server.AbstractMBeanInvoker.invoke(AbstractMBeanInvoker.java:264
    15.         at org.jboss.mx.server.MBeanServerImpl.invoke(MBeanServerImpl.java:659
    16.         at org.jboss.system.ServiceController$ServiceProxy.invoke(ServiceController.java:978
    17.         at $Proxy0.start(Unknown Source) 
    18.         at org.jboss.system.ServiceController.start(ServiceController.java:417
  • Jboss已經正常啟動,但是無法用IP或者綁定IP訪問應用?
    熟悉Linux相關知識的筒靴都知道一個端口是綁定在某個地址上的,可以是一個,也可以是多個,一個端口在同一個地址上不能被兩個應用占有;
    出現這個問題一般是因為你使用的是4.2系列及其之后的版本,因為從這個系列開始,Jboss默認綁定的端口由之前的0.0.0.0變成了127.0.0.1;前者表示綁定當前服務器下所有地址,包括自身的IP、127.0.0.1;而后者只綁定了127.0.0.1,而沒有綁定本機IP,通過IP去訪問應用自然也就無法成功了,因為訪問的IP地址沒有開放對應的端口;
    對于默認的這種情況,一般來說jboss是要和apache搭配使用的,apache暴露應用外部訪問的端口,然后apache再監聽本地(也就是127.0.0.1)的端口;
    當然這個默認配置也是可以修改的,方式也比較多,比如:
    方式1,啟動腳本中通過參數-b, --host=<host or ip>指定地址,比如-b 0.0.0.0就表示綁定所有地址;
    方式2,啟動腳本中通過參數-Djboss.bind.address指定地址,比如-Djboss.bind.address=0.0.0.0;
    方式3,直接修改需要對外暴露的端口綁定地址,比如tomcat/server.xml中的http端口綁定address信息;
  • Jboss正常啟動,但是用shutdown腳本無法關閉應用?
    對于jboss的關閉,shutdown命令允許好幾種方式的關閉,可以參考該命令的幫助:
    1. usage: shutdown [options] <operation> 
    2. options: 
    3.     -h, --help                Show this help message (default
    4.     -D<name>[=<value>]        Set a system property 
    5.     --                        Stop processing options 
    6.     -s, --server=<url>        Specify the JNDI URL of the remote server 
    7.     -n, --serverName=<url>    Specify the JMX name of the ServerImpl 
    8.     -a, --adapter=<name>      Specify JNDI name of the MBeanServerConnection to use 
    9.     -u, --user=<name>         Specify the username for authentication 
    10.     -p, --password=<name>     Specify the password for authentication 
    11. operations: 
    12.     -S, --shutdown            Shutdown the server 
    13.     -e, --exit=<code>         Force the VM to exit with a status code 
    14.     -H, --halt=<code>         Force the VM to halt with a status code 
    一般來說,我們使用-s參數來關閉,也即通過JNDI URL;
    若是基于JNDI URL的方式出現這種情況一般有三種可能:
    其一,當前應用所使用的default目錄內的內容與當前運行jboss自身的default內容不一致,比如當前jboss版本為4.0.5,而啟動時指定的default卻是從jboss 4.2.1中cp過來的;這種情況在搭建環境時經常出現,因為一般直接從另外一臺linux服務器中scp過來,但其實兩臺服務器自身安裝的jboss版本不一致;
    其二,shutdown命令中指定的JNDI端口與實際應用啟動的JNDI端口不一致
    其三,/etc/hosts中對當前主機名綁定的IP地址不正確,比如當前服務器實際的IP地址為10.2.224.214,而hosts中綁定的卻是10.0.0.1;
    總之,出現此類情況都是因為jboss自身無法正確接收到正確的關閉命令所致,一般來說在jboss的server.log中會拋如下的異常信息:
    1. Exception in thread "main" javax.naming.CommunicationException [Root exception is java.rmi.ConnectException: Connection refused to host: 10.0.0.1; nested exception is:  
    2.         java.net.ConnectException: Connection timed out]  
    3.         at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:707)  
    4.         at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:572)  
    5.         at javax.naming.InitialContext.lookup(InitialContext.java:351)  
    6.         at org.jboss.Shutdown.main(Shutdown.java:202)  
    7. Caused by: java.rmi.ConnectException: Connection refused to host: 10.0.0.1; nested exception is:  
    8.         java.net.ConnectException: Connection timed out  
    9.         at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:574)  
    10.         at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:185)  
    11.         at sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:171)  
    12.         at sun.rmi.server.UnicastRef.invoke(UnicastRef.java:94)  
    13.         at org.jnp.server.NamingServer_Stub.lookup(Unknown Source)  
    14.         at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:610)  
    15.         ... 3 more  
  • 如何對Linux下的Jboss應用進行debug?
    其實這個問題和Jboss是否部署在Linux下沒有直接關系,可以在jboss啟動時指定遠程debug端口即可,比如:
    1. -Xrunjdwp:transport=dt_socket,address=8787,server=y,suspend=n 

    然后在eclipse中新建remote debug時指定對應的端口即可;

  • Linux下Jboss啟動、關閉、端口配置等常見問題FAQ 
    關于JBOSS端口被占用的問題
    posted on 2012-03-28 10:58 雪山飛鵠 閱讀(5417) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 亚洲综合久久夜AV | 女人18毛片水最多免费观看| 亚洲国产婷婷综合在线精品| 亚洲另类无码一区二区三区| 在线观看日本免费a∨视频| 亚洲av永久无码嘿嘿嘿| 毛片免费在线观看网站| 亚洲丰满熟女一区二区哦| 在线观看免费为成年视频| 亚洲成在人线在线播放无码| 国产一级高清视频免费看| 高h视频在线免费观看| 亚洲精品WWW久久久久久| 精品一区二区三区高清免费观看| 久久久久噜噜噜亚洲熟女综合| 国产高潮流白浆喷水免费A片 | 亚洲AV无码一区东京热| 久久久久久夜精品精品免费啦| 亚洲国产一区在线观看| 在线免费观看污网站| 国产亚洲综合视频| 亚洲人成亚洲人成在线观看| 亚洲免费人成视频观看| 亚洲av第一网站久章草| 在线亚洲午夜理论AV大片| 在线免费中文字幕| 亚洲欧美日韩一区二区三区在线| 九月婷婷亚洲综合在线| 日本高清高色视频免费| 亚洲色偷偷偷综合网| 国产亚洲成人久久| 18女人毛片水真多免费| 色窝窝亚洲av网| 亚洲av一综合av一区| 好爽…又高潮了免费毛片| 久久免费观看视频| 亚洲乱码卡一卡二卡三| 国产亚洲欧洲Aⅴ综合一区| 99在线精品视频观看免费| 看一级毛片免费观看视频| 亚洲网站在线观看|