/** * The MIT License * Copyright © 2010 JmxTrans team * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ package com.googlecode.jmxtrans.example; import com.google.inject.Injector; import com.googlecode.jmxtrans.JmxTransformer; import com.googlecode.jmxtrans.cli.JmxTransConfiguration; import com.googlecode.jmxtrans.guice.JmxTransModule; import com.googlecode.jmxtrans.model.JmxProcess; import com.googlecode.jmxtrans.model.Query; import com.googlecode.jmxtrans.model.Server; import com.googlecode.jmxtrans.model.output.GraphiteWriter; /** * This example shows how to query an ActiveMQ server for some information. * * The point of this example is to show that * works as part of the objectName. * It also shows that you don't have to set an attribute to get for a query. * jmxtrans will get all attributes on an object if you don't specify any. * * @author jon */ @SuppressWarnings({"squid:S106", "squid:S1118"}) // using StdOut if fine in an example public class ActiveMQ { @SuppressWarnings("squid:S1313") // this is an example, no need to make it configurable private static final String GW_HOST = "192.168.192.133"; public static void main(String[] args) throws Exception { Server.Builder serverBuilder = Server.builder() .setHost("w2") .setPort("1105") .setAlias("w2_activemq_1105"); GraphiteWriter gw = GraphiteWriter.builder() .addTypeName("destinationName") .addTypeName("Destination") .setDebugEnabled(true) .setHost(GW_HOST) .setPort(2003) .build(); Query q = Query.builder() .setObj("org.apache.activemq:BrokerName=localhost,Type=Subscription,clientId=*,consumerId=*,destinationName=*,destinationType=Queue,persistentMode=Non-Durable") .addAttr("PendingQueueSize") .addAttr("DispatchedQueueSize") .addAttr("EnqueueCounter") .addAttr("DequeueCounter") .addAttr("MessageCountAwaitingAcknowledge") .addAttr("DispachedCounter") .addOutputWriterFactory(gw) .build(); serverBuilder.addQuery(q); Query q2 = Query.builder() .setObj("org.apache.activemq:BrokerName=localhost,Destination=ActiveMQ.Advisory.Consumer.Queue.*,Type=Topic") .addAttr("QueueSize") .addAttr("MaxEnqueueTime") .addAttr("MinEnqueueTime") .addAttr("AverageEnqueueTime") .addAttr("InFlightCount") .addAttr("ConsumerCount") .addAttr("ProducerCount") .addAttr("DispatchCount") .addAttr("DequeueCount") .addAttr("EnqueueCount") .addAttr("Subscriptions") .addOutputWriterFactory(gw) .build(); serverBuilder.addQuery(q2); Query q3 = Query.builder() .setObj("org.apache.activemq:BrokerName=localhost,Destination=*,Type=Queue") .addAttr("QueueSize") .addAttr("MaxEnqueueTime") .addAttr("MinEnqueueTime") .addAttr("AverageEnqueueTime") .addAttr("InFlightCount") .addAttr("ConsumerCount") .addAttr("ProducerCount") .addAttr("DispatchCount") .addAttr("DequeueCount") .addAttr("EnqueueCount") .addAttr("Subscriptions") .addOutputWriterFactory(gw) .build(); serverBuilder.addQuery(q3); Query q4 = Query.builder() .setObj("org.apache.activemq:BrokerName=localhost,Destination=*,Type=Topic") .addAttr("QueueSize") .addAttr("MaxEnqueueTime") .addAttr("MinEnqueueTime") .addAttr("AverageEnqueueTime") .addAttr("InFlightCount") .addAttr("ConsumerCount") .addAttr("ProducerCount") .addAttr("DispatchCount") .addAttr("DequeueCount") .addAttr("EnqueueCount") .addAttr("Subscriptions") .addOutputWriterFactory(gw) .build(); serverBuilder.addQuery(q4); Query q5 = Query.builder() .setObj("org.apache.activemq:BrokerName=localhost,Type=Broker") .addOutputWriterFactory(gw) .build(); serverBuilder.addQuery(q5); Query q6 = Query.builder() .setObj("java.lang:type=Memory") .addAttr("HeapMemoryUsage") .addAttr("NonHeapMemoryUsage") .addOutputWriterFactory(gw) .build(); serverBuilder.addQuery(q6); Query q7 = Query.builder() .setObj("java.lang:type=Threading") .addAttr("DaemonThreadCount") .addAttr("PeakThreadCount") .addAttr("ThreadCount") .addAttr("CurrentThreadCpuTime") .addAttr("CurrentThreadUserTime") .addAttr("TotalStartedThreadCount") .addOutputWriterFactory(gw) .build(); serverBuilder.addQuery(q7); Query q8 = Query.builder() .setObj("java.lang:name=*,type=GarbageCollector") .addKey("committed") .addKey("init") .addKey("max") .addKey("used") .addKey("duration") .addKey("CollectionCount") .addKey("CollectionTime") .addOutputWriterFactory(gw) .build(); serverBuilder.addQuery(q8); Query q9 = Query.builder() .setObj("java.lang:type=MemoryPool,name=*") .addOutputWriterFactory(GraphiteWriter.builder() .addTypeName("name") .setDebugEnabled(true) .setHost(GW_HOST) .setPort(2003) .build()) .build(); serverBuilder.addQuery(q9); JmxProcess process = new JmxProcess(serverBuilder.build()); new JsonPrinter(System.out).prettyPrint(process); Injector injector = JmxTransModule.createInjector(new JmxTransConfiguration()); JmxTransformer transformer = injector.getInstance(JmxTransformer.class); transformer.executeStandalone(process); } }