2016-12-28 37 views
0

我在server.xml中配置了連接標記,如下所示。在Java代碼中訪問server.xml的已配置連接器標記

<Connector port="8080" bindOnInit="false" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> 

我想用Java代碼在運行時讀取bindOnInit參數的值。 我不想分析xml。 當我搜索我發現我可以從獲取數據Tomcat tomcat = new Tomcat(); tomcat對象。我如何獲得現有的tomcat對象而不是創建新的tomcat對象,因爲創建新的tomcat對象不會給我配置的值。

請在幫助閱讀bindOnInit運行時使用java代碼的參數。

預先感謝您。

+0

你想要這個值爲什麼? –

+0

我想知道如何閱讀這些值。 –

+0

如果可以解釋我如果您知道連接器在bindOnInit =「false」時的行爲。 –

回答

0

您必須使用MBeanServer恢復org.apache.catalina.server.StandardServer。這是所有的Tomcat系統元素的根條目:

import java.lang.management.ManagementFactory; 
import java.util.Collection; 
import java.util.HashSet; 

import javax.management.MBeanServer; 
import javax.management.ObjectName; 
import org.apache.catalina.Service; 
import org.apache.catalina.connector.Connector; 
import org.apache.catalina.core.StandardServer; 
import org.apache.log4j.Logger; 

public class TomcatConnectors { 

    public static final String CATALINA_SERVICE_NAME = "Catalina"; 

    public static final String CONNECTOR_HTTP_PROTOCOL_NAME = "HTTP/1.1"; 

    private Logger logger = Logger.getLogger(this.getClass()); 

    private Collection<Connector> connectors; 

    /** 
    * 
    */ 
    public TomcatConnectors() { 
     super(); 
     this.connectors = new HashSet<Connector>(); 
     this.loadConnectors(); 
    } 

    /** 
    * 
    * @return 
    */ 
    protected StandardServer getServerInstance(){ 
     org.apache.catalina.core.StandardServer server = null; 
     try{ 
      MBeanServer mbeanServer = ManagementFactory.getPlatformMBeanServer(); 
      server = (StandardServer)mbeanServer.getAttribute(
         new ObjectName("Catalina:type=Server"), 
         "managedResource" 
        ); 
      if(logger.isDebugEnabled()){ 
       logger.debug("Server found. Info: "); 
       logger.debug(" - address   : " + server.getAddress()); 
       logger.debug(" - domain   : " + server.getDomain()); 
       logger.debug(" - info    : " + server.getInfo()); 
       logger.debug(" - shutdown port : " + server.getPort()); 
       logger.debug(" - shutdown command : " + server.getShutdown()); 
       logger.debug(" - serverInfo  : " + server.getServerInfo()); 
       logger.debug(" - status   : " + server.getStateName()); 

      }    

     }catch(Throwable t){ 
      logger.fatal("Fatal Error Recovering StandardServer from MBeanServer : " + t.getClass().getName() + ": " + t.getMessage(), t); 
     } 
     return server; 
    } 

    /* 
    * 
    */ 
    protected Service getCatalinaService(){ 
     org.apache.catalina.core.StandardServer server = this.getServerInstance(); 
     Service[] services = server.findServices(); 
     for(Service aService : services){ 
      if(logger.isDebugEnabled()){ 
       logger.debug("Service: " + aService.getName() + 
         ", info: " + aService.getInfo() + 
         ", state: " + aService.getStateName()); 
      } 

      if(aService.getName().equalsIgnoreCase(CATALINA_SERVICE_NAME)){ 
       return aService;     
      } 
     } 
     return null; 
    } 

    protected void loadConnectors() { 
     Service catalinaService = this.getCatalinaService(); 
     if(catalinaService == null){ 
      throw new IllegalStateException("Service Catalina cannot be null"); 
     } 
     if(catalinaService.findConnectors() != null && catalinaService.findConnectors().length > 0){ 
      logger.debug("List of connectors: "); 
      for(Connector aConnector : catalinaService.findConnectors()){ 
       if(logger.isDebugEnabled()){ 
        logger.debug("Connector.getProtocol: " + aConnector.getProtocol()); 
        logger.debug("Connector.getPort: " + aConnector.getPort()); 
        logger.debug("Connector.getInfo: " + aConnector.getInfo()); 
        logger.debug("Connector.getStateName: " + aConnector.getStateName()); 
        logger.debug("Connector.property.bindOnInit: " + aConnector.getProperty("bindOnInit")); 
        logger.debug("Connector.attribute.bindOnInit: " + aConnector.getAttribute("bindOnInit")); 
        logger.debug("Connector.getState: " + aConnector.getState()); 
       } 
       this.connectors.add(aConnector); 
      } 
     } 
    } 

    /** 
    * @return the connectors 
    */ 
    public Collection<Connector> getConnectors() { 
     if(this.connectors.isEmpty()){ 
      this.loadConnectors(); 
     } 
     return connectors; 
    } 
} 

我與此連接的配置進行了測試:

<Service name="Catalina"> 

    <Connector connectionTimeout="20000" port="8787" protocol="HTTP/1.1" redirectPort="8443"/> 

    <Connector bindOnInit="false" port="8009" protocol="AJP/1.3" redirectPort="8443"/> 

    ... 

這是日誌輸出:

HH:mm:ss,046 DEBUG TomcatConnectors:46 - Server found. Info: 
HH:mm:ss,046 DEBUG TomcatConnectors:47 - - address   : localhost 
HH:mm:ss,046 DEBUG TomcatConnectors:48 - - domain   : Catalina 
HH:mm:ss,046 DEBUG TomcatConnectors:49 - - info    : org.apache.catalina.core.StandardServer/1.0 
HH:mm:ss,046 DEBUG TomcatConnectors:50 - - shutdown port : 8005 
HH:mm:ss,046 DEBUG TomcatConnectors:51 - - shutdown command : SHUTDOWN 
HH:mm:ss,046 DEBUG TomcatConnectors:52 - - serverInfo  : Apache Tomcat/7.0.29 
HH:mm:ss,046 DEBUG TomcatConnectors:53 - - status   : STARTING 
HH:mm:ss,047 DEBUG TomcatConnectors:71 - Service: Catalina, info: org.apache.catalina.core.StandardService/1.0, state: STARTING 
HH:mm:ss,047 DEBUG TomcatConnectors:89 - List of connectors: 
HH:mm:ss,047 DEBUG TomcatConnectors:92 - Connector.getProtocol: HTTP/1.1 
HH:mm:ss,047 DEBUG TomcatConnectors:93 - Connector.getPort: 8787 
HH:mm:ss,047 DEBUG TomcatConnectors:94 - Connector.getInfo: org.apache.catalina.connector.Connector/2.1 
HH:mm:ss,047 DEBUG TomcatConnectors:95 - Connector.getStateName: INITIALIZED 
HH:mm:ss,047 DEBUG TomcatConnectors:96 - Connector.property.bindOnInit: null 
HH:mm:ss,047 DEBUG TomcatConnectors:97 - Connector.attribute.bindOnInit: null 
HH:mm:ss,047 DEBUG TomcatConnectors:98 - Connector.getState: INITIALIZED 
HH:mm:ss,048 DEBUG TomcatConnectors:92 - Connector.getProtocol: AJP/1.3 
HH:mm:ss,048 DEBUG TomcatConnectors:93 - Connector.getPort: 8009 
HH:mm:ss,048 DEBUG TomcatConnectors:94 - Connector.getInfo: org.apache.catalina.connector.Connector/2.1 
HH:mm:ss,048 DEBUG TomcatConnectors:95 - Connector.getStateName: INITIALIZED 
HH:mm:ss,048 DEBUG TomcatConnectors:96 - Connector.property.bindOnInit: false 
HH:mm:ss,048 DEBUG TomcatConnectors:97 - Connector.attribute.bindOnInit: false 
HH:mm:ss,048 DEBUG TomcatConnectors:98 - Connector.getState: INITIALIZED 

你可以請參閱binOnInit屬性可通過Connector的getProperty()getAttribute()方法進行訪問,並且它實際上會返回false AJP連接器的值:

HH:mm:ss,048 DEBUG TomcatConnectors:92 - Connector.getProtocol: AJP/1.3 
HH:mm:ss,048 DEBUG TomcatConnectors:96 - Connector.property.bindOnInit: false 
HH:mm:ss,048 DEBUG TomcatConnectors:97 - Connector.attribute.bindOnInit: false