有一个超时配置,需要从配置文件中读取,并设置到连接池里:
- // 从配置文件中读取超时配置
- timeout = CGlobalConf::readFileConf(“timeout”);
- // 设置请求超时阈值
- CConnectionPool::setTimeout(timeout);
如果超时配置要修改,每次都要重启服务,很麻烦,能不能不重启服务呢?
方案一:发信号触发配置重载
这种方法无需加入任何组件,新增一个信号捕捉函数,来处理配置的重新载入。
- // 服务启动时,设置ctrl+c回调函数
- signal(SIGINT, sigint_shenjian_process);
- // 捕获ctrl+c时,执行配置重新载入动作
- void sigint_shenjian_process(int){
- //从配置中读取超时配置
- timeout= CGlobalConf::readFileConf(“timeout”);
- //设置请求超时阈值
- CConnectionPool::setTimeout(timeout);
- }
当需要变更配置时,只需要:
- 修改配置文件;
- 发送信号,触发配置重新载入;
画外音:啥,不知道如何向服务发信号?
方案二:检测配置文件变化,自动重新载入
这种方法无需手动发送信号,修改完配置文件,自动检测,自动载入,需要加入文件监控组件。
画外音:这类组件开源的也不少。
文件监控组件如何能监控文件的变化呢?
别想复杂了,可以定期检查文件的md5或者last_modify_time。
- // 服务启动时,初始化
- CFileMonitor::init(){
- // 获取初始md5
- old_md5=xxx;
- }
- // 启动一个进程,监控文件变化
- CFileMonitor::start(){
- while(1){ // 循环检查
- // 获取最新md5
- now_md5=xxx;
- // 比对md5是否变化,如果变化
- if(now_md5!=old_md5){
- //从配置中读取超时配置
- timeout= CGlobalConf::readFileConf(“timeout”);
- //设置请求超时阈值
- CConnectionPool::setTimeout(timeout);
- //修改md5
- old_md5=now_md5;
- }
- // 一秒后再检查
- sleep(1000);
- }
- }
方案三:注册中心,配置变化时回调
次方案抛弃了配置文件,需要引入注册中心:
- 所有服务从注册中心拿配置;
- 必须从注册中心后台修改配置;
- 配置修改,注册中心回调引用了相关配置的服务;
- // 服务启动时,从注册中心获取配置,并注册回调函数
- timeout = CConfCenter::(“timeout”, callback_shenjian);
- // 设置请求超时阈值
- CConnectionPool::setTimeout(timeout);
- void callback_shenjian(timeout){
- //在注册中心修改配置时,会收到回调
- CConnectionPool::setTimeout(timeout);
- }
修改配置,不重启服务,上面三种方式都很常见,不难但实用。
【本文为51CTO专栏作者“58沈剑”原创稿件,转载请联系原作者】