如何用源码解读提高RGW最大并发数
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,今天就跟大家聊聊有关如何用源码解读提高RGW最大并发数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。源码解读如何提高RGW最大并发数以rgw服
千家信息网最后更新 2025年01月23日如何用源码解读提高RGW最大并发数
今天就跟大家聊聊有关如何用源码解读提高RGW最大并发数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
源码解读如何提高RGW最大并发数
以rgw服务的main()为入口,查看整个fastcgi的初始化过程,代码如下
#src/rgw/rgw_main.ccint main(int argc, const char **argv) if (framework == "fastcgi" || framework == "fcgi") { RGWProcessEnv fcgi_pe = { store, &rest, olog, 0 }; fe = new RGWFCGXFrontend(fcgi_pe, config); dout(0) << "starting handler: " << fiter->first << dendl; int r = fe->init(); #调用RGWFCGXFrontend的init()方法
再看init()方法构建了一个RGWFCGXProcess,并将rgw_thread_pool_size作为实参传递进去。
#src/rgw/rgw_frontend.hclass RGWFCGXFrontend : public RGWProcessFrontend {public: RGWFCGXFrontend(RGWProcessEnv& pe, RGWFrontendConfig* _conf) : RGWProcessFrontend(pe, _conf) {} int init() { pprocess = new RGWFCGXProcess(g_ceph_context, &env, g_conf->rgw_thread_pool_size, conf); return 0; }};
默认rgw_thread_pool_size为100,代码定义如下
#src/common/config_opts.hOPTION(rgw_thread_pool_size, OPT_INT, 100)
通过RGWFCGXProcess的构造函数发现max_connections=num_threads + (num_threads >> 3),也就是说默认情况下max_connections=100+1=101,代码注释中也提到这是为了确保能够尽可能多的处理请求。
#src/rgw/rgw_process.hclass RGWFCGXProcess : public RGWProcess { int max_connections;public: /* have a bit more connections than threads so that requests are * still accepted even if we're still processing older requests */ RGWFCGXProcess(CephContext* cct, RGWProcessEnv* pe, int num_threads, RGWFrontendConfig* _conf) : RGWProcess(cct, pe, num_threads, _conf), max_connections(num_threads + (num_threads >> 3)) {} void run(); void handle_request(RGWRequest* req);};
所以num_threads控制着max_connections的数量,如果你想提高单个rgw进程的最大并发数量,需要调高rgw_thread_pool_size。
看完上述内容,你们对如何用源码解读提高RGW最大并发数有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注行业资讯频道,感谢大家的支持。
最大
源码
代码
内容
数量
方法
也就是
也就是说
入口
函数
单个
尽可能
情况
更多
注释
知识
篇文章
行业
资讯
资讯频道
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
麻将软件开发制作
重保网络安全
佛山银联金融互联网科技
数据库流水线的分支模型
平谷区定制软件开发不二之选
软件开发环境netfram
软件开发的总体技术要求net
数据库模型搭建
广电网络技术部个人总结
苹果给软件开发者发工资吗
吉林联通服务器
socket通信 服务器
数据库同步软件的研发
计算机三级网络技术一晚速成
嵌入式软件开发价钱
数据库中什么是外部属性
龙岩公安网络安全保卫支队
怎么分辨电脑服务器
国网公司网络安全队伍
软件开发个人业绩报告
建立数据库的第一步是( )
u网络技术培训
乙方软件开发
苹果无法连接到远程服务器
pathon用什么软件开发
操作系统里有哪些是数据库
做软件开发需要服务器吗
网络安全个人金融信息简报
网络安全创意文案案例
pvsyst数据库更新