java activemq jmx_通过JMX 获取Activemq 队列信息

首先在 activemq.xml 中新增以下属性

在broker 节点新增属性 useJmx="true"

在managementContext 节点配置断开与访问服务iP

配置成功后启动

下面来看测试代码

/**

* @Title: ActivemqTest.java

* @Package activemq

* @Description: TODO(用一句话描述该文件做什么)

* @author LYL

* @date 下午2:25:59

* @version V1.0

*/

package activemq;

import java.io.IOException;

import java.net.MalformedURLException;

import java.util.HashMap;

import java.util.Map;

import javax.management.MBeanServerConnection;

import javax.management.MBeanServerInvocationHandler;

import javax.management.ObjectName;

import javax.management.remote.JMXConnector;

import javax.management.remote.JMXConnectorFactory;

import javax.management.remote.JMXServiceURL;

import org.apache.activemq.broker.jmx.BrokerViewMBean;

import org.apache.activemq.broker.jmx.QueueViewMBean;

/**

* @Title: ActivemqTest.java

* @Package activemq

* @Description: TODO(用一句话描述该文件做什么)

* @author LYL

* @date 下午2:25:59

* @version V1.0

*/

public class ActivemqTest {

public static void main(String[] args) throws Exception {

String ip = "127.0.0.1:8188";

String url = String.format("service:jmx:rmi:///jndi/rmi://%s/jmxrmi",ip);

Map credentials = new HashMap<>();

// credentials.put(JMXConnector.CREDENTIALS, new String[] {"admin", "admin"});

JMXServiceURL urls = new JMXServiceURL(url);

JMXConnector connector = JMXConnectorFactory.connect(urls,credentials);

connector.connect();

MBeanServerConnection conn = connector.getMBeanServerConnection();

ObjectName name = new ObjectName("org.apache.activemq:brokerName=localhost,type=Broker");

BrokerViewMBean mBean = (BrokerViewMBean)MBeanServerInvocationHandler.newProxyInstance(conn, name, BrokerViewMBean.class, true);

ObjectName[] pAry = mBean.getQueueSubscribers();

for (ObjectName objectName : pAry) {

}

ObjectName[] ary = mBean.getQueues();

for (ObjectName objectName : ary) {

QueueViewMBean queueBean = (QueueViewMBean) MBeanServerInvocationHandler.newProxyInstance(conn, objectName, QueueViewMBean.class, true);

System.out.println("队列的名称:"+queueBean.getName());

System.out.println("消息积压数:"+queueBean.getQueueSize());

System.out.println("入队:"+queueBean.getEnqueueCount());

System.out.println("出队:"+queueBean.getDequeueCount());

System.out.println("消费者数:"+queueBean.getConsumerCount());

System.out.println("生产者数:"+queueBean.getProducerCount());

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值