Search in sources :

Example 1 with JCAStats

use of javax.management.j2ee.statistics.JCAStats in project newrelic-java-agent by newrelic.

the class J2EEStatsAttributeProcessor method process.

@Override
public boolean process(StatsEngine statsEngine, ObjectInstance instance, Attribute attribute, String metricName, Map<String, Float> values) {
    Object value = attribute.getValue();
    if (value instanceof Stats) {
        boolean isBuiltInMetric = isBuiltInMetric(metricName);
        if (value instanceof JDBCStats) {
            pullJDBCStats(statsEngine, (JDBCStats) value, attribute, metricName, values, isBuiltInMetric);
        } else if (value instanceof JCAStats) {
            pullJCAStats(statsEngine, (JCAStats) value, attribute, metricName, values, isBuiltInMetric);
        } else if (value instanceof JMSStats) {
            pullJMSStats(statsEngine, (JMSStats) value, attribute, metricName, values, isBuiltInMetric);
        } else {
            Stats jmxStats = (Stats) value;
            grabBaseStats(statsEngine, jmxStats, attribute, metricName, values, isBuiltInMetric);
        }
        return true;
    } else {
        Agent.LOG.finer(MessageFormat.format("Attribute value is not a javax.management.j2ee.statistics.Stats: {0}", value.getClass().getName()));
        return false;
    }
}
Also used : JMSConnectionStats(javax.management.j2ee.statistics.JMSConnectionStats) JCAConnectionPoolStats(javax.management.j2ee.statistics.JCAConnectionPoolStats) JMSSessionStats(javax.management.j2ee.statistics.JMSSessionStats) JCAStats(javax.management.j2ee.statistics.JCAStats) JMSStats(javax.management.j2ee.statistics.JMSStats) JCAConnectionStats(javax.management.j2ee.statistics.JCAConnectionStats) JDBCConnectionStats(javax.management.j2ee.statistics.JDBCConnectionStats) JDBCStats(javax.management.j2ee.statistics.JDBCStats) Stats(javax.management.j2ee.statistics.Stats) JDBCConnectionPoolStats(javax.management.j2ee.statistics.JDBCConnectionPoolStats) JDBCStats(javax.management.j2ee.statistics.JDBCStats) JCAStats(javax.management.j2ee.statistics.JCAStats) JMSStats(javax.management.j2ee.statistics.JMSStats)

Example 2 with JCAStats

use of javax.management.j2ee.statistics.JCAStats in project newrelic-java-agent by newrelic.

the class J2EEStatsAttributeTest method addJcaValueJdbcTest.

@Test
public void addJcaValueJdbcTest() throws MalformedObjectNameException {
    JCAStats count = new JCAStats() {

        @Override
        public JCAConnectionStats[] getConnections() {
            return new JCAConnectionStats[0];
        }

        @Override
        public JCAConnectionPoolStats[] getConnectionPools() {
            return new JCAConnectionPoolStats[] { new TestJcaConnectionPool() };
        }

        @Override
        public Statistic getStatistic(String statisticName) {
            return null;
        }

        @Override
        public String[] getStatisticNames() {
            return null;
        }

        @Override
        public Statistic[] getStatistics() {
            return new Statistic[0];
        }
    };
    Attribute att = new Attribute("stats", count);
    J2EEStatsAttributeProcessor processor = new J2EEStatsAttributeProcessor();
    StatsEngine engine = new StatsEngineImpl();
    processor.process(engine, new ObjectInstance("tezt:type=2", "test"), att, "JMX/Test", new HashMap<String, Float>());
    // check count stats
    Assert.assertEquals(6, engine.getStats("JMX/Test/Create").getTotal(), .001);
    Assert.assertEquals(1, engine.getStats("JMX/Test/Create").getCallCount(), .001);
    Assert.assertEquals(99, engine.getStats("JMX/Test/Closed").getTotal(), .001);
    Assert.assertEquals(1, engine.getStats("JMX/Test/Closed").getCallCount(), .001);
    // check time stats
    Assert.assertEquals(10, engine.getResponseTimeStats("JMX/Test/Wait").getMaxCallTime(), .001);
    Assert.assertEquals(5, engine.getResponseTimeStats("JMX/Test/Wait").getMinCallTime(), .001);
    Assert.assertEquals(2, engine.getResponseTimeStats("JMX/Test/Wait").getCallCount(), .001);
    Assert.assertEquals(6, engine.getResponseTimeStats("JMX/Test/User").getMaxCallTime(), .001);
    Assert.assertEquals(4, engine.getResponseTimeStats("JMX/Test/User").getMinCallTime(), .001);
    Assert.assertEquals(2, engine.getResponseTimeStats("JMX/Test/User").getCallCount(), .001);
}
Also used : StatsEngineImpl(com.newrelic.agent.stats.StatsEngineImpl) Attribute(javax.management.Attribute) ObjectInstance(javax.management.ObjectInstance) JCAConnectionStats(javax.management.j2ee.statistics.JCAConnectionStats) StatsEngine(com.newrelic.agent.stats.StatsEngine) CountStatistic(javax.management.j2ee.statistics.CountStatistic) RangeStatistic(javax.management.j2ee.statistics.RangeStatistic) TimeStatistic(javax.management.j2ee.statistics.TimeStatistic) BoundedRangeStatistic(javax.management.j2ee.statistics.BoundedRangeStatistic) BoundaryStatistic(javax.management.j2ee.statistics.BoundaryStatistic) Statistic(javax.management.j2ee.statistics.Statistic) JCAStats(javax.management.j2ee.statistics.JCAStats) JCAConnectionPoolStats(javax.management.j2ee.statistics.JCAConnectionPoolStats) Test(org.junit.Test)

Aggregations

JCAConnectionPoolStats (javax.management.j2ee.statistics.JCAConnectionPoolStats)2 JCAConnectionStats (javax.management.j2ee.statistics.JCAConnectionStats)2 JCAStats (javax.management.j2ee.statistics.JCAStats)2 StatsEngine (com.newrelic.agent.stats.StatsEngine)1 StatsEngineImpl (com.newrelic.agent.stats.StatsEngineImpl)1 Attribute (javax.management.Attribute)1 ObjectInstance (javax.management.ObjectInstance)1 BoundaryStatistic (javax.management.j2ee.statistics.BoundaryStatistic)1 BoundedRangeStatistic (javax.management.j2ee.statistics.BoundedRangeStatistic)1 CountStatistic (javax.management.j2ee.statistics.CountStatistic)1 JDBCConnectionPoolStats (javax.management.j2ee.statistics.JDBCConnectionPoolStats)1 JDBCConnectionStats (javax.management.j2ee.statistics.JDBCConnectionStats)1 JDBCStats (javax.management.j2ee.statistics.JDBCStats)1 JMSConnectionStats (javax.management.j2ee.statistics.JMSConnectionStats)1 JMSSessionStats (javax.management.j2ee.statistics.JMSSessionStats)1 JMSStats (javax.management.j2ee.statistics.JMSStats)1 RangeStatistic (javax.management.j2ee.statistics.RangeStatistic)1 Statistic (javax.management.j2ee.statistics.Statistic)1 Stats (javax.management.j2ee.statistics.Stats)1 TimeStatistic (javax.management.j2ee.statistics.TimeStatistic)1