python 应用thrift---- thrift的监控fb303 -

2011-08-18 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): constants 和thrift数据类型相同 ttypes 定义 fb_status FacebookBase Iface的空实现 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做监控吧,不用自己添加额外代码。。。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Python攻城狮

Python-shutil模块1.shutil 是高级的文件,文件夹,压缩包处理模块。2.使用

1.shutil.copyfileobj(fsrc, fdst[, length])     将文件内容拷贝到另一个文件中

692
来自专栏http://www.cnblogs.com

centos6.5编译安装php7

1.安装依赖软件库:   yum install -y libxml2-devel libtool* curl-devel libjpeg-devel libp...

47211
来自专栏Java后端技术栈

Jenkins部署Maven多环境项目(dev、beta、prod)的参数设置

http://blog.csdn.net/xlgen157387/article/details/50353317

1902
来自专栏ASP.NETCore

TinyFox在VS2015上的调试器

开源了 https://github.com/maxzhang1985/TinyFoxDEBUG

1323
来自专栏编程坑太多

springboot(14)redis实现session共享

1.6K4
来自专栏漫漫全栈路

Windows下JavaWeb环境的安装笔记

写在前面:专升本报道开课,这个学期的课程中开了JavaWeb和Oracle数据库,作为软狗虽然一百个不愿意,但是学习为重嘛。Oracle数据库之前在吉奥实习的...

3495
来自专栏技术博文

PHP版本号--phpversion(),PHP_VERSION,PHP_VERSION_ID

PHP版本号的命名规则 主版本号,次版本号,发布版本号 例如:7.0.12:7指的是主版本号,0是次版本号,12是发布版本号 PHP版本号的获取 1.phpve...

3049
来自专栏hbbliyong

JPA、Hibernate、Spring data jpa之间的关系,终于明白了

全称Java Persistence API,可以通过注解或者XML描述【对象-关系表】之间的映射关系,并将实体对象持久化到数据库中。

912
来自专栏专注于主流技术和业务

SpringMVC过滤器、拦截器与监听器的区别

3251
来自专栏黑泽君的专栏

eclipse中如何删除已经添加到 Web App Libraries 中引用的jar包

在 eclipse 中的 动态web项目 中,例如:我们通过向  /bos19/WebContent/WEB-INF/lib 中添加我们需要用到的jar包,如下...

1.8K2

扫码关注云+社区

领取腾讯云代金券