ICE的日志和统计接口

来源:互联网 发布:有机遇成功的数据 编辑:程序博客网 时间:2024/05/22 05:13
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);
   
原创粉丝点击