JBoss Ports

From Shrubbery

Jump to: navigation, search


Contents

[edit] Why configure JBoss's Ports?

Configuring port numbers in JBoss can seem a little complicated, but it's actually pretty easy to understand once you get how JBoss is configured. However, why bother spending the time learning all this if it isn't going to be useful? Here are a few reasons why you might want to configure JBoss ports:

  1. You are running an instance of Tomcat on your machine already, and you can't start JBoss because port 8080 is already in use.
  2. You have a team of developers sharing a deployment machine. Each developer needs their own instance of JBoss (Note: if so, you will want to look at Shared JBoss Installation Directory also)
  3. A testing team wants to test different versions of the application using the same machine.
  4. You are planning on deploying more than one JBoss JVM per machine in a cluster to get higher availability and better performance (lots of smaller JVMs).

[edit] JBoss 4.x Ports

Here are the ports used by JBoss 4.x:

[edit] Default port numbers and where they are configured

Default PortLocationDescription
1099./conf/jboss-service.xml or ./naming.sar/META-INF/jboss-service.xmlBootstrap JNP port.
1098 (anon)./conf/jboss-service.xml or ./naming.sar/META-INF/jboss-service.xmlRMI naming service port.

Use '0' for an anonymous port.

4444./conf/jboss-service.xml or ./deploy/invokers-service.xmlRMI/JRMP invoker port
4445./conf/jboss-service.xml or ./deploy/invokers-service.xmlPooled invoker
8083./conf/jboss-service.xml or ./deploy/dynclassloader-service.xmlRMI dynamic class loader port
8080./deploy/jbossweb-tomcat55.sar/server.xmlHTTP port for the web container
8009./deploy/jbossweb-tomcat55.sar/server.xmlAJP port for the web container
8093./deploy/jms/uil2-service.xmlUIL for JMS.
8443 (optional)./deploy/jbossweb-tomcat55.sar/server.xmlHTTPS port for the web container

[edit] Additional port numbers for clustered configurations

Default PortLocationDescription
1100./deploy/cluster-service.xmlHA-JNDI
1101 (anon) ./deploy/cluster-service.xmlRMI for HA-JNDI

Use '0' for an anonymous port.

4446./deploy/cluster-service.xmlHA Pooled Invoker
4447./deploy/cluster-service.xmlHA JRMP
45566 (mcast)./deploy/cluster-service.xmlJGroups clustering

[edit] Other ports for optional services

Default PortLocationDescription
3528./deploy/iiop-service.xmlCORBA port
3873./deploy/ejb3.deployer/META-INF/jboss-service.xmlEJB3 remote invoker
1162./deploy/snmp-adaptor.sar/META-INF/jboss-service.xmlSNMP Log
1161./deploy/snmp-adaptor.sar/META-INF/jboss-service.xmlSNMP Adaptor
19001jmx-rmi-adaptor.sarJMX over RMI

[edit] How to configure ports for different instances of JBoss

[edit] Solution #1 : Use the Service Binding facility

The "Service Binding" feature uses a JMX bean to configure the other JMX beans (as far as I can tell). This requires you to make a file that has all of the possible bindings for each 'jboss server name'. The basics are:

  1. Create a globally shared "Service Binding" file that will contain the port numbers for each possible instance of JBoss on the machine by 'configuration name'.
  2. Uncomment or add a "Service Binding" section in conf/jboss-service.xml. This where the configuration will select which set of bindings it will use from the shared bindings file.

See: http://wiki.jboss.org/wiki/Wiki.jsp?page=ConfiguringMultipleJBossInstancesOnOneMachine

[edit] Solution #2: Use M4 or ANT to pre-process the XML configuration files.

If JBoss isn't the only thing that needs port numbers, host names and directories configured into each instance than you need more than just the Service Binding feature. In this case, we experience one drawback of JBoss's modular configuration: there are lots of files to change! Although this isn't really that difficult it requires a bit of work and it might break if JBoss changes their configuration files around if you're not careful.

[edit] Solution #3 (the best of both) : Use a combination of Service Binding and ANT or M4

The answer to the drawbacks of solutions #1 and #2: Use both! If you use substitution on the service binding configuration file itself then it is as if all JBoss ports are configured in one file. This means you don't have to process each individual configuration file. The basic idea here is to create a service binding XML file that has the substitutable tokens in it, and use ANT or M4 to process this one file.

[edit] Mapping the EJB3 Remote Invoker Port

The example port bindings file doesn't map the EJB3 remoting port. This is easy:


     <service-config name="jboss.remoting:type=Connector,name=DefaultEjb3Connector,handler=ejb3"
        delegateClass="org.jboss.services.binding.AttributeMappingDelegate">
       <delegate-config>
          <attribute name="InvokerLocator">socket://${jboss.bind.address}:3873</attribute>
       </delegate-config>
        <binding port="3873"/>
     </service-config>

Just replace '3873' with the port number you want to use.


[edit] Links

Personal tools