package com.googlecode.jmxtrans.example;
import com.google.inject.Guice;
import com.google.inject.Injector;
import com.googlecode.jmxtrans.JmxTransformer;
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;
import com.googlecode.jmxtrans.util.JsonPrinter;
/**
* This example shows how to query hibernate for its statistics information.
*
* @author jon
*/
public class Hibernate {
private static final String GW_HOST = "192.168.192.133";
private static final JsonPrinter printer = new JsonPrinter(System.out);
public static void main(String[] args) throws Exception {
JmxProcess process = new JmxProcess(Server.builder()
.setHost("w2")
.setPort("1099")
.setAlias("w2_hibernate_1099")
.addQuery(Query.builder()
.setObj("org.hibernate.jmx:name=*,type=StatisticsService")
.addAttr("EntityDeleteCount")
.addAttr("EntityInsertCount")
.addAttr("EntityLoadCount")
.addAttr("EntityFetchCount")
.addAttr("EntityUpdateCount")
.addAttr("QueryExecutionCount")
.addAttr("QueryCacheHitCount")
.addAttr("QueryExecutionMaxTime")
.addAttr("QueryCacheMissCount")
.addAttr("QueryCachePutCount")
.addAttr("FlushCount")
.addAttr("ConnectCount")
.addAttr("SecondLevelCacheHitCount")
.addAttr("SecondLevelCacheMissCount")
.addAttr("SecondLevelCachePutCount")
.addAttr("SessionCloseCount")
.addAttr("SessionOpenCount")
.addAttr("CollectionLoadCount")
.addAttr("CollectionFetchCount")
.addAttr("CollectionUpdateCount")
.addAttr("CollectionRemoveCount")
.addAttr("CollectionRecreateCount")
.addAttr("SuccessfulTransactionCount")
.addAttr("TransactionCount")
.addAttr("CloseStatementCount")
.addAttr("PrepareStatementCount")
.addAttr("OptimisticFailureCount")
.addOutputWriter(GraphiteWriter.builder()
.addTypeName("name")
.setDebugEnabled(true)
.setHost(GW_HOST)
.setPort(2003)
.build())
.build())
.build());
printer.prettyPrint(process);
Injector injector = Guice.createInjector(new JmxTransModule(null));
JmxTransformer transformer = injector.getInstance(JmxTransformer.class);
transformer.executeStandalone(process);
// for (int i = 0; i < 160; i++) {
// JmxUtils.processServer(server);
// Thread.sleep(1000);
// }
}
}