`

jmx实现监控weblogic中的jms队列信息(一)

    博客分类:
  • jmx
阅读更多

 

需要加入jar包:weblogic.jar,wlclient.jar,wljmsclient.jar,wls-api.jar,这些jar包在weblogic安装目录下可以找到(bea\weblogic92\server\lib,这是9.2版本),

 

下面是简单的代码,通过java代码基本能监控queue中的数据情况

 

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 MonitorJMS {
    private static MBeanServerConnection connection;
    private static JMXConnector connector;
    private static final ObjectName service;
    // Initializing the object name for DomainRuntimeServiceMBean
    // so it can be used throughout the class.
    static {
       try {
          service = new ObjectName(
           "com.bea:Name=DomainRuntimeService," +
           "Type=weblogic.management.mbeanservers.domainruntime.DomainRuntimeServiceMBean");
       }catch (MalformedObjectNameException e) {
          throw new AssertionError(e.getMessage());
       }
    }
    /*
    * Initialize connection to the Domain Runtime MBean Server
    */
    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();
    }
    /*
    * Get an array of ServerRuntimeMBeans
    */
    public static ObjectName[] getServerRuntimes() throws Exception {
       return (ObjectName[]) connection.getAttribute(service,
          "ServerRuntimes");
    }
    
    public void getJmsQueueInfo() throws Exception {
        ObjectName[] serverRT = getServerRuntimes();
        ObjectName JMSRT = (ObjectName) connection.getAttribute(serverRT[0],
                                                                "JMSRuntime");
        ObjectName[] JMSServers = (ObjectName[]) connection.getAttribute(JMSRT,
                                                                         "JMSServers");
        int JMSServer_Length = (int) JMSServers.length;
        for (int x = 0; x < JMSServer_Length; x++) {
            //jmsserver名称
            String JMSServer_name = (String) connection.getAttribute(JMSServers[x],
                                                                     "Name");
            ObjectName[] JMSDests = (ObjectName[]) connection.getAttribute(JMSServers[x],
                                                                           "Destinations");
            int JMSdest_Length = (int) JMSDests.length;
            for (int y = 0; y < JMSdest_Length; y++) {
                //queue名称
                String queue_name = (String) connection.getAttribute(JMSDests[y],
                                                                     "Name");
                long pendingmcount = (Long) connection.getAttribute(JMSDests[y],
                                                                    "MessagesPendingCount");
                //当前队列中有多少条记录
                long currentcount = (Long) connection.getAttribute(JMSDests[y],
                                                                   "MessagesCurrentCount");

                System.out.println(y
                        + "--[jms server name]: "
                        + JMSServer_name
                        + "  [jms name]: "
                        + queue_name
                        + "   [pending]: "
                        + pendingmcount
                        + "   [current]: "
                        + currentcount);
                        
            }
        } 
    }
    
    public static void main(String[] args) throws Exception {
       String hostname = "127.0.0.1";
       String portString = "7001";
       String username = "weblogic";
       String password = "weblogic";
       MonitorJMS s = new MonitorJMS();
       initConnection(hostname, portString, username, password);
       s.getJmsQueueInfo();
       connector.close();
    }
}
 

更多weblogic MBean信息可以查看http://docs.oracle.com/cd/E13222_01/wls/docs92/wlsmbeanref/core/index.html

分享到:
评论

相关推荐

    jmx监控weblogic,tomcat,websphere源码

    通过JMX,用户可以监视WebSphere的性能指标,如服务器状态、集群信息、JMS队列和主题的状态,甚至可以进行一些配置更改。 这个项目中的"ops-container"可能是一个包含自定义实现的模块,它封装了与各个服务器JMX...

    weblogic中使用JMS发送和接受消息

    WebLogic Server是一款由Oracle公司提供的企业级应用服务器,它支持Java Message Service (JMS) 规范,允许在分布式环境中可靠地发送和接收消息。JMS是Java平台上的标准接口,用于实现应用程序间的异步通信。本文将...

    weblogic中配置JMS及其测试程序

    - **集群配置**:在WebLogic集群中部署JMS资源,实现负载均衡和故障转移。 - **持久化**:启用JMS消息的持久化,确保在服务器重启后消息不丢失。 - **消息驱动bean(MDB)**:作为JMS消费者的EJB组件,自动处理...

    Weblogic环境下JMS配置

    1. 创建JMS模块:在WebLogic管理控制台中,我们需要创建一个新的JMS模块,这是一个容器,可以包含多个JMS资源,如队列和主题。 2. 定义JMS资源:在JMS模块中,我们需要定义消息队列和主题。队列适用于一对一通信,...

    weblogic API FOR [weblogic.jar]

    WebLogic API提供了对服务器运行时环境的编程访问,包括服务器启动、停止、集群管理、部署、安全管理、JMS队列和主题管理等。这些API主要分为以下几大类别: 1. **服务器管理**:用于创建、启动、停止、重启服务器...

    weblogic第一期培训材料

    配置集群时,需要注意网络配置、数据源和JMS队列的集群化、session复制等关键环节。 4. **性能管理** 性能管理是确保WebLogic高效运行的关键。这包括了性能监控、调优和资源管理。使用WebLogic诊断框架收集和分析...

    weblogic 服务器管理(中文版)

    运行时对象反映服务器当前的活动状态,如内存使用、线程状态等,而配置对象则包含了服务器的持久化设置,如JDBC数据源、JMS队列等。 集中访问的日志消息是系统诊断和问题排查的关键,WebLogic Server提供了收集和...

    weblogic 学习资料大全

    WebLogic的主要功能包括:应用服务器、JMS消息队列、数据源管理、集群支持、安全管理、监控和诊断工具等。 二、WebLogic安装与配置 学习资料中可能包含WebLogic的安装步骤,包括下载、安装、配置环境变量等。配置...

    weblogic

    在域配置阶段,可以设置服务器的端口号、JDBC数据源、JMS队列和主题、EJB组件等。此外,还需要配置服务器的启动和停止脚本,以便于日常运维。 6. **部署应用程序** 部署Java EE应用到WebLogic,可以通过WebLogic...

    weblogic培训资料(英文版本)

    理解和掌握WebLogic的日志记录和诊断信息,以及如何使用JMX(Java Management Extensions)进行监控,是解决运行时问题的关键技能。 总的来说,WebLogic 9的培训资料能让你深入理解一个企业级应用服务器的运作,...

    weblogic.jar

    它包含了客户端API,使开发者可以远程管理WebLogic Server,创建和连接到服务器的 administered objects(如数据源、JMS队列或话题),以及执行部署和管理任务。此jar包对于构建需要与WebLogic Server交互的轻量级...

    AIX下的Weblogic安装

    设置Domain名称、管理服务器、集群、数据源、JMS队列等。 6. **启动WebLogic**: 在Domain的启动脚本目录下,运行`startManagedWebLogic.sh`或`startWebLogic.sh`命令,根据你的配置启动管理服务器或节点管理器。...

    weblogic中文文档

    配置WebLogic涉及到设置服务器、域、集群、网络通道、JMS队列和主题、数据源等一系列组件的属性。这些配置对服务器的性能、安全性及稳定性至关重要。 1. 服务器配置:包括内存设置、JVM参数、日志和诊断配置等,以...

    weblogic 错误信息详解

    WebLogic提供了一些内置的诊断工具,如JMX Console、WLST(WebLogic Scripting Tool)和JConsole,可以帮助管理员监控服务器状态,收集诊断信息,甚至执行远程操作来调试问题。 7. **社区支持** 当遇到难以解决的...

    weblogic资料.rar

    2. **WebLogic基础知识**:这可能涵盖WebLogic的基本概念,如域、管理服务器、受管服务器、数据源、JMS队列和主题等。理解这些概念对于日常管理和维护至关重要。 3. **WebLogic应用部署**:包括如何打包和部署WAR、...

    weblogic系统环境

    1. 管理控制台:WebLogic Server提供了一个基于Web的管理控制台,可以用来监控和管理域内的资源,如服务器实例、数据源、JMS队列等。 2. 部署应用程序:通过管理控制台或命令行工具,可以部署WAR、EAR或EJB等形式的...

    WebLogic企业级运维实战

    《WebLogic企业级运维实战》一书主要涵盖了Oracle WebLogic Server在企业环境中的部署、管理、监控和优化等核心运维知识。WebLogic Server是Oracle公司的一款广泛应用的Java EE应用服务器,它提供了强大的服务管理和...

    weblogic自学全套教程

    WebLogic提供丰富的监控和诊断工具,如日志、JMX、JFR等。学习如何有效利用这些工具可以提高问题排查效率。此外,了解如何优化WebLogic的内存设置、线程池配置以及资源调度策略也是提升系统性能的关键。 七、...

    Weblogic 培训 PPT

    3. 数据源与JMS队列:配置数据源以连接数据库,JMS队列用于消息传递和异步处理,是企业级应用中的重要组件。 4. 安全配置:包括用户、角色、权限的定义,SSL/TLS的配置,以及审计日志的设置,确保应用系统的安全性和...

Global site tag (gtag.js) - Google Analytics