需要加入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,用户可以监视WebSphere的性能指标,如服务器状态、集群信息、JMS队列和主题的状态,甚至可以进行一些配置更改。 这个项目中的"ops-container"可能是一个包含自定义实现的模块,它封装了与各个服务器JMX...
WebLogic Server是一款由Oracle公司提供的企业级应用服务器,它支持Java Message Service (JMS) 规范,允许在分布式环境中可靠地发送和接收消息。JMS是Java平台上的标准接口,用于实现应用程序间的异步通信。本文将...
- **集群配置**:在WebLogic集群中部署JMS资源,实现负载均衡和故障转移。 - **持久化**:启用JMS消息的持久化,确保在服务器重启后消息不丢失。 - **消息驱动bean(MDB)**:作为JMS消费者的EJB组件,自动处理...
1. 创建JMS模块:在WebLogic管理控制台中,我们需要创建一个新的JMS模块,这是一个容器,可以包含多个JMS资源,如队列和主题。 2. 定义JMS资源:在JMS模块中,我们需要定义消息队列和主题。队列适用于一对一通信,...
WebLogic API提供了对服务器运行时环境的编程访问,包括服务器启动、停止、集群管理、部署、安全管理、JMS队列和主题管理等。这些API主要分为以下几大类别: 1. **服务器管理**:用于创建、启动、停止、重启服务器...
配置集群时,需要注意网络配置、数据源和JMS队列的集群化、session复制等关键环节。 4. **性能管理** 性能管理是确保WebLogic高效运行的关键。这包括了性能监控、调优和资源管理。使用WebLogic诊断框架收集和分析...
运行时对象反映服务器当前的活动状态,如内存使用、线程状态等,而配置对象则包含了服务器的持久化设置,如JDBC数据源、JMS队列等。 集中访问的日志消息是系统诊断和问题排查的关键,WebLogic Server提供了收集和...
WebLogic的主要功能包括:应用服务器、JMS消息队列、数据源管理、集群支持、安全管理、监控和诊断工具等。 二、WebLogic安装与配置 学习资料中可能包含WebLogic的安装步骤,包括下载、安装、配置环境变量等。配置...
在域配置阶段,可以设置服务器的端口号、JDBC数据源、JMS队列和主题、EJB组件等。此外,还需要配置服务器的启动和停止脚本,以便于日常运维。 6. **部署应用程序** 部署Java EE应用到WebLogic,可以通过WebLogic...
理解和掌握WebLogic的日志记录和诊断信息,以及如何使用JMX(Java Management Extensions)进行监控,是解决运行时问题的关键技能。 总的来说,WebLogic 9的培训资料能让你深入理解一个企业级应用服务器的运作,...
它包含了客户端API,使开发者可以远程管理WebLogic Server,创建和连接到服务器的 administered objects(如数据源、JMS队列或话题),以及执行部署和管理任务。此jar包对于构建需要与WebLogic Server交互的轻量级...
设置Domain名称、管理服务器、集群、数据源、JMS队列等。 6. **启动WebLogic**: 在Domain的启动脚本目录下,运行`startManagedWebLogic.sh`或`startWebLogic.sh`命令,根据你的配置启动管理服务器或节点管理器。...
配置WebLogic涉及到设置服务器、域、集群、网络通道、JMS队列和主题、数据源等一系列组件的属性。这些配置对服务器的性能、安全性及稳定性至关重要。 1. 服务器配置:包括内存设置、JVM参数、日志和诊断配置等,以...
WebLogic提供了一些内置的诊断工具,如JMX Console、WLST(WebLogic Scripting Tool)和JConsole,可以帮助管理员监控服务器状态,收集诊断信息,甚至执行远程操作来调试问题。 7. **社区支持** 当遇到难以解决的...
2. **WebLogic基础知识**:这可能涵盖WebLogic的基本概念,如域、管理服务器、受管服务器、数据源、JMS队列和主题等。理解这些概念对于日常管理和维护至关重要。 3. **WebLogic应用部署**:包括如何打包和部署WAR、...
1. 管理控制台:WebLogic Server提供了一个基于Web的管理控制台,可以用来监控和管理域内的资源,如服务器实例、数据源、JMS队列等。 2. 部署应用程序:通过管理控制台或命令行工具,可以部署WAR、EAR或EJB等形式的...
《WebLogic企业级运维实战》一书主要涵盖了Oracle WebLogic Server在企业环境中的部署、管理、监控和优化等核心运维知识。WebLogic Server是Oracle公司的一款广泛应用的Java EE应用服务器,它提供了强大的服务管理和...
WebLogic提供丰富的监控和诊断工具,如日志、JMX、JFR等。学习如何有效利用这些工具可以提高问题排查效率。此外,了解如何优化WebLogic的内存设置、线程池配置以及资源调度策略也是提升系统性能的关键。 七、...
3. 数据源与JMS队列:配置数据源以连接数据库,JMS队列用于消息传递和异步处理,是企业级应用中的重要组件。 4. 安全配置:包括用户、角色、权限的定义,SSL/TLS的配置,以及审计日志的设置,确保应用系统的安全性和...