如何理解RGW性能监控及源码实现
发表于:2024-11-29 作者:千家信息网编辑
千家信息网最后更新 2024年11月29日,如何理解RGW性能监控及源码实现,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1性能计数器实现性能计数器启动过程#src
千家信息网最后更新 2024年11月29日如何理解RGW性能监控及源码实现1 性能计数器实现 2 如何使用计数器
如何理解RGW性能监控及源码实现,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
性能计数器启动过程
#src/rgw/rgw_main.ccint main(int argc, const char **argv) ... if (g_conf->daemonize) { global_init_daemonize(g_ceph_context); } Mutex mutex("main"); SafeTimer init_timer(g_ceph_context, mutex); init_timer.init(); mutex.Lock(); init_timer.add_event_after(g_conf->rgw_init_timeout, new C_InitTimeout); mutex.Unlock(); // Enable the perf counter before starting the service thread g_ceph_context->enable_perf_counter(); ... r = rgw_perf_start(g_ceph_context); #启用rgw计数器
性能计数器参数说明
#src/rgw/rgw_common.ccint rgw_perf_start(CephContext *cct){ PerfCountersBuilder plb(cct, cct->_conf->name.to_str(), l_rgw_first, l_rgw_last); plb.add_u64_counter(l_rgw_req, "req", "Requests"); #处理成功请求数量 plb.add_u64_counter(l_rgw_failed_req, "failed_req", "Aborted requests"); #处理失败请求数量 plb.add_u64_counter(l_rgw_get, "get", "Gets"); #GET请求数量 plb.add_u64_counter(l_rgw_get_b, "get_b", "Size of gets"); plb.add_time_avg(l_rgw_get_lat, "get_initial_lat", "Get latency"); plb.add_u64_counter(l_rgw_put, "put", "Puts"); #PUT请求数量 plb.add_u64_counter(l_rgw_put_b, "put_b", "Size of puts"); plb.add_time_avg(l_rgw_put_lat, "put_initial_lat", "Put latency"); plb.add_u64(l_rgw_qlen, "qlen", "Queue length"); plb.add_u64(l_rgw_qactive, "qactive", "Active requests queue"); plb.add_u64_counter(l_rgw_cache_hit, "cache_hit", "Cache hits"); #用于缓存RGW元数据的缓存命中次数 plb.add_u64_counter(l_rgw_cache_miss, "cache_miss", "Cache miss"); #未命中次数 plb.add_u64_counter(l_rgw_keystone_token_cache_hit, "keystone_token_cache_hit", "Keystone token cache hits"); plb.add_u64_counter(l_rgw_keystone_token_cache_miss, "keystone_token_cache_miss", "Keystone token cache miss"); perfcounter = plb.create_perf_counters(); cct->get_perfcounters_collection()->add(perfcounter); return 0;}
性能计数器类型定义如下
#src/rgw/rgw_common.ccenum { l_rgw_first = 15000, l_rgw_req, l_rgw_failed_req, l_rgw_get, l_rgw_get_b, l_rgw_get_lat, l_rgw_put, l_rgw_put_b, l_rgw_put_lat, l_rgw_qlen, l_rgw_qactive, l_rgw_cache_hit, l_rgw_cache_miss, l_rgw_keystone_token_cache_hit, l_rgw_keystone_token_cache_miss, l_rgw_last,};
方式1
root@demo# ceph --admin-daemon /var/run/ceph-client.radosgw.en-zone1.asok perf dump{"cct": { "total_workers": 32, "unhealthy_workers": 0},"client.radosgw.en-zone1": { "req": 2, "failed_req": 2, "get": 0, "get_b": 0, "get_initial_lat": { "avgcount": 0, "sum": 0.000000000 }, "put": 0, "put_b": 0, "put_initial_lat": { "avgcount": 0, "sum": 0.000000000 }, "qlen": 0, "qactive": 0, "cache_hit": 0, "cache_miss": 2, "keystone_token_cache_hit": 0, "keystone_token_cache_miss": 0}
方式2 (使用Dumpling以上版本)
root@demo# ceph daemon client.radosgw.en-zone1 perf dump{ "cct": { "total_workers": 32, "unhealthy_workers": 0 }, "client.radosgw.en-zone1": { "req": 2, "failed_req": 2, "get": 0, "get_b": 0, "get_initial_lat": { "avgcount": 0, "sum": 0.000000000 }, "put": 0, "put_b": 0, "put_initial_lat": { "avgcount": 0, "sum": 0.000000000 }, "qlen": 0, "qactive": 0, "cache_hit": 0, "cache_miss": 2, "keystone_token_cache_hit": 0, "keystone_token_cache_miss": 0 }
性能计数器一般人可能不太关注,但是将计数器数据推送到一些监控系统里面,同时添加一些告警策略,能够显著提升运维质量。同时通过源码层面去扩展计数器类型,从ceph内部去实现一些自定义数据的统计,也是一个不错的功能亮点。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。
计数器
性能
数量
数据
源码
监控
同时
方式
次数
类型
缓存
处理
帮助
不错
显著
清楚
成功
亮点
内容
功能
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
关于dns服务器
数据库怎么连接到程序上
数据库系统工程师什么书
刑侦八大数据库
push服务器如何下发数据
租服务器上行京东淘宝
无锡定制软件开发工程师
怎么找网络安全的项目
上海网络安全培训有哪些机构
网络安全为主题手抄报一等奖
当今软件开发的主流平台有
网络技术对市场营销专业的影响
数据库基本语言
软件开发校内经历
软件开发没学懂
康皱免费领商城软件开发
江苏工控软件开发哪家专业
晋江手机应用软件开发
数据库部署在云上安全吗
魔兽怀旧服服务器里有哪些
软件开发 审计
百度网络安全教育
怎么查看服务器是不是主机
合肥机械成本软件开发平台
第三方移动服务器的重要性
对数据库量大处理
网络安全等级保护物联网
手撕包菜数据库下载
广东戴尔服务器电话多少
数据库更新一条原记录