ICE的日志和统计接口
1、获取日志对象:
   virtual LoggerPtr getLogger() const;
2、日志对象提供的方法:
   local interface Logger
   {
        void print(string message);
        void trace(string category, string message);
        void warning(string message);
        void error(string message);
        Logger cloneWithPrefix(string prefix);
    };
3、communicator提供的默认日志接口是打屏的,可以通过如下方法定制日志接口:
   Ice::InitializationData id;
   id.logger = new MyLoggerI();
   Ice::Communicator ic = Ice::Initiliaze(argc, argv, id);
4、也可以通过插件设置日志
   class MyLoggerI : public Ice::Logger
   {
   public:
        void print(string message);
        void trace(string category, string message);
        void warning(string message);
        void error(string message);
        Logger cloneWithPrefix(string prefix);
   };
   extern "C"
   {
   ICE_DECLSPEC_EXPORT Ice::Plugin* createLogger(const Ice::Communicator& ic, const std::string& name, 
                                                 const Ice::StringSeq& args)
{
   Ice::LoggerPtr logger = new MyLoggerI();
return new Ice::LoggerPlugin(ic, logger);
}
   }
   编译成动态库libmylogger.so
   配置属性:Ice.Plugin.MyLogger = mylogger::createLogger
4、ICE提供了一系列的工具类来处理日志:Ice::Error、Ice::Warning、Ice::Trace、Ice::Print
    Ice::Error err(communicator->getLogger());
err<<"This is error "<<myErrorString;
5、ICE提供了统计接口用来统计网络流量,具体的接口使用如下:
   local interface stats
   {
        void bytesSent(std::string& protocol, Ice::Int num);
void bytesReceived(std::string& protocol, Ice::Int num);
    };  
   Ice::InitializationData id;
   id.stats = new MyStatsI();
   Ice::Communicator ic = Ice::Initiliaze(argc, argv, id);
   
阅读更多
个人分类: ICE学习
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

ICE的日志和统计接口

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭