打赏

通过JMX获取weblogic的监控指标

通过JMX获取weblogic的监控数据,包括JDBC,SESSION,SERVERLET,JVM等信息。主要用到weblogic自己的t3协议,所以要用到weblogic的jar包:wlfullclient.jar和wlclient.jar。这两个jar包怎么获取我专门在另外一篇文章中讲。下面贴一些获取监控指标的代码,做个备份只用吧。

1、对JDBC的监控,只取了最重要的监控指标:

package test;

import java.io.IOException;
import java.net.MalformedURLException;
import java.util.Hashtable;

import javax.management.MBeanServerConnection;
import javax.management.MalformedObjectNameException;
import javax.management.ObjectName;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXServiceURL;
import javax.naming.Context;

public class PrintJdbc {
	private static MBeanServerConnection connection;
	private static JMXConnector connector;
	private static final ObjectName service;
	

	   static {
	      try {
	         service = new ObjectName("com.bea:Name=RuntimeService,Type=weblogic.management.mbeanservers.runtime.RuntimeServiceMBean");
	      }catch (MalformedObjectNameException e) {
	         throw new AssertionError(e.getMessage());
	      }
	   }
	 
	   public static void initConnection(String hostname, String portString, 
	      String username, String password) throws IOException,
	      MalformedURLException { 
	      String protocol = "t3";
	      Integer portInteger = Integer.valueOf(portString);
	      int port = portInteger.intValue();
	      String jndiroot = "/jndi/";
	      String mserver = "weblogic.management.mbeanservers.runtime";
	      JMXServiceURL serviceURL = new JMXServiceURL(protocol, hostname,
	         port, jndiroot + mserver);
	      Hashtable h = new Hashtable();
	      h.put(Context.SECURITY_PRINCIPAL, username);
	      h.put(Context.SECURITY_CREDENTIALS, password);
	      h.put(JMXConnectorFactory.PROTOCOL_PROVIDER_PACKAGES,
	         "weblogic.management.remote");
	      connector = JMXConnectorFactory.connect(serviceURL, h);
	      connection = connector.getMBeanServerConnection();
	   }
	
	   public static ObjectName getServerRuntimes() throws Exception {
		    return (ObjectName)connection.getAttribute(service,
	    		  "ServerRuntime");
	   }
	   
	  
	   public  ObjectName getJDBCServer() throws Exception {
		   ObjectName dc = getServerRuntimes();
		   ObjectName jdbcService = (ObjectName)connection.getAttribute(dc,
				   "JDBCServiceRuntime");
		   return jdbcService;
	   }
	   
		public ObjectName[] getJDBCDataSourceRuntime() throws Exception   {
			ObjectName[] jdbcDataSourceRTMB = (ObjectName[]) connection.getAttribute(getJDBCServer(), "JDBCDataSourceRuntimeMBeans");
			return jdbcDataSourceRTMB;
		}
		
		
	   public void printJdbc() throws Exception {
		   ObjectName[] objectList = getJDBCDataSourceRuntime();
		   if(objectList != null && objectList.length > 0){
			   for(ObjectName obj : objectList){
				   int connectionsTotalCount = (int) connection.getAttribute(obj, "ConnectionsTotalCount");
				   int activeConnectionsCurrentCount = (int)connection.getAttribute(obj, "ActiveConnectionsCurrentCount");
				   int activeConnectionsAverageCount = (int)connection.getAttribute(obj,"ActiveConnectionsAverageCount");
				   int failuresToReconnectCount = (int)connection.getAttribute(obj, "FailuresToReconnectCount");
				   String name = (String)connection.getAttribute(obj, "Name");
				   int waitingForConnectionCurrentCount = (int)connection.getAttribute(obj, "WaitingForConnectionCurrentCount");
				   long waitingForConnectionFailureTotal = (long)connection.getAttribute(obj, "WaitingForConnectionFailureTotal");
				   int waitSecondsHighCount = (int)connection.getAttribute(obj, "WaitSecondsHighCount");
				   int connectionDelayTime = (int)connection.getAttribute(obj, "ConnectionDelayTime");
				   int activeConnectionsHighCount = (int)connection.getAttribute(obj, "ActiveConnectionsHighCount");
				   int currCapacity = (int)connection.getAttribute(obj, "CurrCapacity");
				   System.out.println("currCapacity==" + currCapacity);
				   System.out.println("activeConnectionsHighCount==" + activeConnectionsHighCount);
				   System.out.println("connectionDelayTime==" + connectionDelayTime);
				   System.out.println("connectionsTotalCount==" + connectionsTotalCount);
				   System.out.println("activeConnectionsCurrentCount==" + activeConnectionsCurrentCount);
				   System.out.println("activeConnectionsAverageCount==" + activeConnectionsAverageCount);
				   System.out.println("failuresToReconnectCount==" + failuresToReconnectCount);
				   System.out.println("name==" + name);
				   System.out.println("waitingForConnectionCurrentCount==" +waitingForConnectionCurrentCount );
				   System.out.println("waitingForConnectionFailureTotal==" + waitingForConnectionFailureTotal);
				   System.out.println("waitSecondsHighCount==" + waitSecondsHighCount);
				  
				
			   }
		   }
	   }
	   public static void main(String[] args) throws Exception {
		 
		      String hostname = "10.111.131.50";
		      String portString = "7001";
		      String username = "weblogic";
		      String password = "weblogic123";
		      PrintJdbc s = new PrintJdbc();
		      initConnection(hostname, portString, username, password);
		      s.printJdbc();
		      connector.close();
		   }
	   
	   
}

  2、有关thread的监控:

package test;

import java.io.IOException;
import java.net.MalformedURLException;
import java.util.Hashtable;

import javax.management.MBeanServerConnection;
import javax.management.MalformedObjectNameException;
import javax.management.ObjectName;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXServiceURL;
import javax.naming.Context;

public class PrintThread {

	private static MBeanServerConnection connection;
	private static JMXConnector connector;
	private static final ObjectName service;
	

	   static {
	      try {
	         service = new ObjectName("com.bea:Name=RuntimeService,Type=weblogic.management.mbeanservers.runtime.RuntimeServiceMBean");
	      }catch (MalformedObjectNameException e) {
	         throw new AssertionError(e.getMessage());
	      }
	   }
	 
	   public static void initConnection(String hostname, String portString, 
	      String username, String password) throws IOException,
	      MalformedURLException { 
	      String protocol = "t3";
	      Integer portInteger = Integer.valueOf(portString);
	      int port = portInteger.intValue();
	      String jndiroot = "/jndi/";
	      String mserver = "weblogic.management.mbeanservers.runtime";
	      JMXServiceURL serviceURL = new JMXServiceURL(protocol, hostname,
	         port, jndiroot + mserver);
	      Hashtable h = new Hashtable();
	      h.put(Context.SECURITY_PRINCIPAL, username);
	      h.put(Context.SECURITY_CREDENTIALS, password);
	      h.put(JMXConnectorFactory.PROTOCOL_PROVIDER_PACKAGES,
	         "weblogic.management.remote");
	      connector = JMXConnectorFactory.connect(serviceURL, h);
	      connection = connector.getMBeanServerConnection();
	   }
	
	   public static ObjectName getServerRuntimes() throws Exception {
		    return (ObjectName)connection.getAttribute(service,
	    		  "ServerRuntime");
	   }
	   
	   public void printInfo() throws Exception{
		   ObjectName objThreadPool = null;
		   ObjectName serverRT = getServerRuntimes();
		   
		   objThreadPool = (ObjectName) connection.getAttribute(serverRT, "ThreadPoolRuntime");
		   double throughput  = Double.parseDouble(String.valueOf(connection.getAttribute(
				   objThreadPool,"Throughput")));
		   System.out.println("throughput:" + throughput);
		   
		   int executeThreadTotalCount = Integer.parseInt(String.valueOf(connection.getAttribute(objThreadPool, "ExecuteThreadTotalCount")));
		   System.out.println("executeThreadTotalCount:" + executeThreadTotalCount);
		 
		
		   int executeThreadIdleCount = Integer.parseInt(String.valueOf(connection.getAttribute(objThreadPool, "ExecuteThreadIdleCount")));
		   System.out.println("executeThreadIdleCount:" + executeThreadIdleCount);
		  
		   int StandbyThreadCount = Integer.parseInt(String.valueOf(connection.getAttribute(objThreadPool, "StandbyThreadCount")));
	       System.out.println("StandbyThreadCount:" + StandbyThreadCount);
	       
	       
	       long timestamp = System.currentTimeMillis() / 1000;
			String metricJson = "";
			String jsonFormat = "{\"name\": \"weblogic_threadpool_metric_demo\", " +
	                "\"command\":\"weblogic_threadpool_metric\"," +
	                "\"type\": \"metric\"," +
	                "\"handlers\": [\"influxdb\"],"+
	                "\"output\": \"%s %.5f %d\\n%s %d %d\\n%s %d %d\\n\"," +
	                "\"status\": 0}";
			metricJson = String.format(jsonFormat,
		              ".weblogic.threadpool.throughput", (double)throughput, timestamp,
		              ".weblogic.threadpool.executeThreadTotalCount", (int)executeThreadTotalCount, timestamp,
		              ".weblogic.threadpool.executeThreadIdleCount", (int)executeThreadIdleCount, timestamp);
			System.out.println("metricJson==" + metricJson);
			
			
			
	   }
	   
	   
	public static void main(String args[]) throws Exception {
		 String hostname = "10.111.131.50";
	      String portString = "7001";
	      String username = "weblogic";
	      String password = "weblogic123";
	      PrintThread s = new PrintThread();
	      initConnection(hostname, portString, username, password);
	      s.printInfo();
	      connector.close();
	}
}

  3、有关session的监控:

package test;

import java.io.IOException;
import java.net.MalformedURLException;
import java.util.Hashtable;

import javax.management.MBeanServerConnection;
import javax.management.MalformedObjectNameException;
import javax.management.ObjectName;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXServiceURL;
import javax.naming.Context;

public class PrintServerState {
	private static MBeanServerConnection connection;
	private static JMXConnector connector;
	private static final ObjectName service;
	
	
	   static {
	      try {
	         service = new ObjectName("com.bea:Name=DomainRuntimeService,Type=weblogic.management.mbeanservers.domainruntime.DomainRuntimeServiceMBean");
	      }catch (MalformedObjectNameException e) {
	         throw new AssertionError(e.getMessage());
	      }
	   }
	   
	   public static void initConnection(String hostname, String portString, 
	      String username, String password) throws IOException,
	      MalformedURLException { 
	      String protocol = "t3";
	      Integer portInteger = Integer.valueOf(portString);
	      int port = portInteger.intValue();
	      String jndiroot = "/jndi/";
	      String mserver = "weblogic.management.mbeanservers.domainruntime";
	      JMXServiceURL serviceURL = new JMXServiceURL(protocol, hostname,
	         port, jndiroot + mserver);
	      Hashtable h = new Hashtable();
	      h.put(Context.SECURITY_PRINCIPAL, username);
	      h.put(Context.SECURITY_CREDENTIALS, password);
	      h.put(JMXConnectorFactory.PROTOCOL_PROVIDER_PACKAGES,
	         "weblogic.management.remote");
	      connector = JMXConnectorFactory.connect(serviceURL, h);
	      connection = connector.getMBeanServerConnection();
	   }
	   
	   public static ObjectName[] getServerRuntimes() throws Exception {
	      return (ObjectName[]) connection.getAttribute(service,
	         "ServerRuntimes");
	   }
	   
	   public static ObjectName[] getApplicationRuntimes(ObjectName serverRuntime) throws Exception {
		   return (ObjectName[])connection.getAttribute(serverRuntime, "ApplicationRuntimes");
	   }
	   
	   public static ObjectName[] getComponentRuntimes(ObjectName componentRutime) throws Exception {
		   return (ObjectName[]) connection.getAttribute(componentRutime, "ComponentRuntimes");
	   }
	   
	   
	   public void printSessionState() throws Exception {
		   ObjectName[] serverRT = getServerRuntimes();
		   int length = (int) serverRT.length;
		  
		   for(int i = 0;i<length;i++){
			   ObjectName[] applicationRT = getApplicationRuntimes(serverRT[i]);
			   int length_app = (int)applicationRT.length;
			 
			   for(int y = 0;y<length_app;y++){
				   String applicationName =  (String)connection.getAttribute(applicationRT[y], "ApplicationName");
				  
				   if(applicationName.equals("helloworld")){
					  
				   ObjectName[]  componentRuntime = getComponentRuntimes(applicationRT[y]);
				   int length_component = (int)componentRuntime.length;
				   System.out.println("length_component==" + length_component);
				   for(int z = 0;z<length_component;z++){
					   
					   String type =  (String)connection.getAttribute(componentRuntime[z], "Type");
					   if(type.equals("WebAppComponentRuntime")){
						   
					  
					   int SessionsOpenedTotalCount = (int)connection.getAttribute(componentRuntime[z], "SessionsOpenedTotalCount");
					   System.out.println("SessionsOpenedTotalCount==" + SessionsOpenedTotalCount);
					   
					   int openSessionsHighCount = (int)connection.getAttribute(componentRuntime[z], "OpenSessionsHighCount");
					   System.out.println("openSessionsHighCount==" + openSessionsHighCount);
					   
					   int openSessionsCurrentCount = (int)connection.getAttribute(componentRuntime[z], "OpenSessionsCurrentCount");
					   System.out.println("openSessionsCurrentCount==" + openSessionsCurrentCount);
					   break;
					   }
					   
				     }
				     break;
				  }
			   }
		   }
	   }
	   
	   public void printNameAndState() throws Exception {
	      ObjectName[] serverRT = getServerRuntimes();
	      System.out.println("got server runtimes");
	      int length = (int) serverRT.length;
	      for (int i = 0; i < length; i++) {
	    	
	         String name = (String) connection.getAttribute(serverRT[i],
	            "Name");
	         
	         String state = (String) connection.getAttribute(serverRT[i],
	            "State");
	         
	      
	         long activationTime  = (Long)connection.getAttribute(serverRT[i], "ActivationTime");
	         System.out.println("Server name: " + name);
	         System.out.println("Server state:" + state);
	         System.out.println("Server activationTime:" + activationTime);
	       
	         String weblogicVersion  = (String) connection.getAttribute(serverRT[i], "WeblogicVersion");
	         System.out.println("Server weblogicVersion:" + weblogicVersion);
	         
	         String weblogicHome = (String) connection.getAttribute(serverRT[i], "WeblogicHome");
	         System.out.println("Server WeblogicHome:" +weblogicHome );
	         
	         
	      }
	   }
	    public static void main(String[] args) throws Exception {
	      String hostname = "10.111.131.50";
	      String portString = "7001";
	      String username = "weblogic";
	      String password = "weblogic123";
	       PrintServerState s = new PrintServerState();
	      initConnection(hostname, portString, username, password);
	      s.printNameAndState();
	      s.printSessionState();
	      connector.close();
	   }
}

  4、有关serverlet的监控:

package test;

import java.io.IOException;
import java.net.MalformedURLException;
import java.util.Hashtable;

import javax.management.MBeanServerConnection;
import javax.management.MalformedObjectNameException;
import javax.management.ObjectName;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXServiceURL;
import javax.naming.Context;

public class PrintServerlet {

	private static MBeanServerConnection connection;
	   private static JMXConnector connector;
	   private static final ObjectName service;
	   private final String applicationName_app="helloworld";
	   private final String serverletName1="index.jsp";
	   private final String serverletName2="helloworld.jsp";
	    
	   static {
	      try {
	         service = new ObjectName(
	          "com.bea:Name=DomainRuntimeService,Type=weblogic.management.mbeanservers.domainruntime.DomainRuntimeServiceMBean");
	      }catch (MalformedObjectNameException e) {
	         throw new AssertionError(e.getMessage());
	      }
	   }
	   
	   public static void initConnection(String hostname, String portString, 
	      String username, String password) throws IOException,
	      MalformedURLException { 
	      String protocol = "t3";
	      Integer portInteger = Integer.valueOf(portString);
	      int port = portInteger.intValue();
	      String jndiroot = "/jndi/";
	      String mserver = "weblogic.management.mbeanservers.domainruntime";
	       JMXServiceURL serviceURL = new JMXServiceURL(protocol, hostname,
	         port, jndiroot + mserver);
	      Hashtable h = new Hashtable();
	      h.put(Context.SECURITY_PRINCIPAL, username);
	      h.put(Context.SECURITY_CREDENTIALS, password);
	      h.put(JMXConnectorFactory.PROTOCOL_PROVIDER_PACKAGES,
	         "weblogic.management.remote");
	      connector = JMXConnectorFactory.connect(serviceURL, h);
	      connection = connector.getMBeanServerConnection();
	   }
	   
	   public static ObjectName[] getServerRuntimes() throws Exception {
	      return (ObjectName[]) connection.getAttribute(service,
	         "ServerRuntimes");
	   }
	   
	   public String getApplicationName(ObjectName objectName) throws Exception {
		   return (String)connection.getAttribute(objectName, "Name");
	   }
	   
	   public String getServletName(ObjectName objectName) throws Exception {
		   return (String)connection.getAttribute(objectName,"Name");
	   }
	   
	   public void getServletData() throws Exception {
	      ObjectName[] serverRT = getServerRuntimes();
	      int length = (int) serverRT.length;
	      for (int i = 0; i < length; i++) {
	         ObjectName[] appRT = 
	            (ObjectName[]) connection.getAttribute(serverRT[i],
	            "ApplicationRuntimes");
	         int appLength = (int) appRT.length;
	         for (int x = 0; x < appLength; x++) {
	        	 String applicationName = getApplicationName(appRT[x]);
	        	 if(applicationName_app.equals(applicationName)){
	        		 System.out.println("Application name: " + applicationName);
	        		 ObjectName[] compRT = 
	        	               (ObjectName[]) connection.getAttribute(appRT[x],
	        	               "ComponentRuntimes");
	        	     int compLength = (int) compRT.length;
	        	 
	            for (int y = 0; y < compLength; y++) {
	            	printValue("Component name",(String)connection.getAttribute(compRT[y], "Name"));
	               String componentType = 
	                  (String) connection.getAttribute(compRT[y], "Type");
	               System.out.println(componentType.toString());
	               if (componentType.toString().equals("WebAppComponentRuntime")){
	                  ObjectName[] servletRTs = (ObjectName[])
	                     connection.getAttribute(compRT[y], "Servlets");
	                  int servletLength = (int) servletRTs.length;
	                  for (int z = 0; z < servletLength; z++) {
	                	  String servletName = getServletName(servletRTs[z]);
	                	  if (servletName.contains(serverletName1) || servletName.contains(serverletName2)){
	                		   printValue("Servlet name",servletName);

	                		   printValue("Servlet context path" ,
	 	                        (String)connection.getAttribute(servletRTs[z],
	 	                         "ContextPath"));
		 	                    printValue("Invocation Total Count" ,
		 		                        (Object)connection.getAttribute(servletRTs[z],
		 		                         "InvocationTotalCount"));
		 	                   printValue("ExecutionTimeHigh",
		 		 	                        (Object)connection.getAttribute(servletRTs[z],
		 		 	                         "ExecutionTimeHigh"));
		 		                printValue("ExecutionTimeTotal",(Object)connection.getAttribute(servletRTs[z],
		 	                         "ExecutionTimeTotal"));
		 		                printValue("ExecutionTimeAverage",(Object)connection.getAttribute(servletRTs[z],
		 		                		"ExecutionTimeAverage"));
	 		               
	                	  }
	                    
	                     
	               
	                  }
	               }
	            }
	           }
	         }
	      }
	   }
	   
	   private void printValue(String key,Object value){
		   System.out.println("  " + key + " : " + value);
	   }
	    public static void main(String[] args) throws Exception {
	    	 String hostname = "10.111.131.50";
		      String portString = "7001";
		      String username = "weblogic";
		      String password = "weblogic123";
		      PrintServerlet s = new PrintServerlet();
		      initConnection(hostname, portString, username, password);
		      s.getServletData();
		      connector.close();
	   }
}

  

posted @ 2015-04-27 16:55  矮子爬楼梯  阅读(5086)  评论(0编辑  收藏  举报