com.logicbus.service.MetricsReport Maven / Gradle / Ivy
package com.logicbus.service;
import java.util.HashMap;
import java.util.Map;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import com.alogic.metrics.Fragment;
import com.alogic.metrics.stream.MetricsHandlerFactory;
import com.anysoft.stream.Handler;
import com.anysoft.util.JsonTools;
import com.anysoft.util.XmlTools;
import com.logicbus.backend.AbstractServant;
import com.logicbus.backend.Context;
import com.logicbus.backend.ServantException;
import com.logicbus.backend.message.JsonMessage;
import com.logicbus.backend.message.XMLMessage;
import com.logicbus.models.servant.ServiceDescription;
/**
* 指标处理报告
* @author duanyy
*
* @since 1.2.8
* @version 1.4.0 [20141117 duanyy]
* - 将MessageDoc和Context进行合并整合
*
* @version 1.6.6.13 [20170109 duanyy]
* - 采用新的指标接口 handler = MetricsHandlerFactory.getClientInstance();
if (handler != null){
Element root = msg.getRoot();
Document doc = root.getOwnerDocument();
Element logger = doc.createElement(handler.getHandlerType());
XmlTools.setInt(logger, "offset", offset);
XmlTools.setInt(logger, "limit", limit);
XmlTools.setString(logger, "keyword",keyword);
handler.report(logger);
root.appendChild(logger);
}
return 0;
}
protected int onJson(Context ctx) {
JsonMessage msg = (JsonMessage)ctx.asMessage(JsonMessage.class);
int offset = getArgument("offset", 0, ctx);
int limit = getArgument("limit", 30, ctx);
String keyword = getArgument("keyword","",ctx);
Handler handler = MetricsHandlerFactory.getClientInstance();
if (handler != null){
Map root = msg.getRoot();
Map logger = new HashMap();
JsonTools.setInt(logger, "offset", offset);
JsonTools.setInt(logger, "limit", limit);
JsonTools.setString(logger, "keyword",keyword);
handler.report(logger);
root.put(handler.getHandlerType(), logger);
}
return 0;
}
}