use of com.alipay.common.tracer.core.reporter.stat.model.StatKey in project sofa-rpc by sofastack.
the class RpcClientStatTest method testClientStat.
@Test
@Ignore
public void testClientStat() {
try {
Tracer rpcSofaTracer = Tracers.getTracer();
Field tracerField = null;
try {
tracerField = RpcSofaTracer.class.getDeclaredField("sofaTracer");
} catch (NoSuchFieldException e) {
e.printStackTrace();
}
tracerField.setAccessible(true);
SofaTracer tracer = null;
// OpenTracing tracer 标准实现
try {
tracer = (SofaTracer) tracerField.get(rpcSofaTracer);
} catch (IllegalAccessException e) {
e.printStackTrace();
}
Reporter clientReporter = tracer.getClientReporter();
assertNotNull(clientReporter);
assertTrue(clientReporter instanceof MemoryReporterImpl);
memoryReporter = (MemoryReporterImpl) clientReporter;
final SofaRequest request = new SofaRequest();
request.setInterfaceName("a");
request.setTargetServiceUniqueName("app.service:1.0");
request.setMethodName("method");
RpcInternalContext context = RpcInternalContext.getContext();
context.setAttachment(RpcConstants.INTERNAL_KEY_APP_NAME, "client");
// this will not be used, only in real invoke
final ProviderInfo providerInfo = new ProviderInfo();
providerInfo.setStaticAttr(ProviderInfoAttrs.ATTR_APP_NAME, "server");
context.setProviderInfo(providerInfo);
for (int i = 0; i < 10; i++) {
rpcSofaTracer.startRpc(request);
rpcSofaTracer.clientBeforeSend(request);
final SofaResponse response = new SofaResponse();
response.setAppResponse("b");
rpcSofaTracer.clientReceived(request, response, null);
}
Map<StatKey, StatValues> datas = memoryReporter.getStoreDatas();
LOGGER.info("1" + datas);
Assert.assertEquals(1, datas.size());
for (Map.Entry entry : datas.entrySet()) {
final StatMapKey key = (StatMapKey) entry.getKey();
final StatValues value = (StatValues) entry.getValue();
Assert.assertEquals("client,,app.service:1.0,method", key.getKey());
Assert.assertEquals(10, value.getCurrentValue()[0]);
}
request.setTargetServiceUniqueName("app.service:2.0");
for (int i = 0; i < 20; i++) {
rpcSofaTracer.startRpc(request);
rpcSofaTracer.clientBeforeSend(request);
final SofaResponse response = new SofaResponse();
response.setAppResponse("b");
rpcSofaTracer.clientReceived(request, response, null);
}
LOGGER.info("2" + datas);
int i = 0;
for (Map.Entry entry : datas.entrySet()) {
if (i == 0) {
continue;
}
final StatMapKey key = (StatMapKey) entry.getKey();
final StatValues value = (StatValues) entry.getValue();
Assert.assertEquals("client,,app.service:2.0,method", key.getKey());
Assert.assertEquals(20, value.getCurrentValue()[0]);
}
Assert.assertEquals(2, datas.size());
} catch (Throwable e) {
e.printStackTrace();
Assert.assertTrue(false);
}
}
use of com.alipay.common.tracer.core.reporter.stat.model.StatKey in project sofa-rpc by sofastack.
the class MemoryReporterImpl method statisticReport.
private void statisticReport(SofaTracerSpan span) {
statReporter.reportStat(span);
Field statDatas;
Map<StatKey, StatValues> datas = null;
try {
statDatas = getDeclaredField(statReporter, "statDatas");
statDatas.setAccessible(true);
datas = (Map<StatKey, StatValues>) statDatas.get(statReporter);
} catch (IllegalAccessException e) {
LOGGER.error("statisticReport error", e);
}
storeDatas.putAll(datas);
}
Aggregations