ython 应用thrift---- thrift的监控fb303 - [co

系统 2140 0

python 应用thrift---- thrift的监控fb303 - import coding_dog ---- by 坚毅的刀刀 - 博客大巴

ython 应用thrift---- thrift的监控fb303 - [ coding ]

2011-08-18

版权声明 :转载时请以超链接形式标明文章原始出处和作者信息及 本声明
http://shenguanpu.blogbus.com/logs/156741276.html

fb303  在thrift的源码包 contrib之中

* What does it provide? *
A standard interface to monitoring, dynamic options and configuration,
uptime reports, activity, etc.

也就是说fb303提供了几种接口方法,而并没有默认实现(很坑爹)有了fb303不需要在自己的thrift servcie 接口里去声明,只需要自动生成的processor继承fb303的FacebookService.Processor  但需要自己写handler 去处理接口方法

fb303库结构(需要编译并安装,步骤类似thrift):

  1. constants 和thrift数据类型相同
  2. ttypes 定义 fb_status
  3. FacebookBase  Iface的空实现
  4. FacebookService  A clinet 访问thrift服务,获取结果  B IFace标准基础服务 C Processor  序列化代码

 


调用过程:1 做一个client  2 去调用服务器的handler  3 服务器把handler得到的服务信息 访问数 生存时间 cpu状况 通过fb303接口序列化并返回给客户端。。。

  • 修改fb303_scripts中的示例客户端fb303_simple_mgmt.py
    class Fb303Client(FacebookService.Client, CMyClient):
      pass
    fb303_client = Fb303Client(protocol, protocol)
    protocol 按需要更改
  • 修改 domain ServerNameExchange.py
      from fb303 import *
     
    class Processor(Iface, TProcessor) --> class Processor(Iface, FacebookService.Processor):
    Process最终调用handler做处理
  • handler增加相关方法:
    def getStatusDetails(self):
          return " i am very fine!"

    def getStatus(self):
          return 1

cpu使用情况可分析 /proc/stat  内容 获得结果

综上,还是用monit做监控吧,不用自己添加额外代码。。。

ython 应用thrift---- thrift的监控fb303 - [coding]


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论