改了配置,不想重启,怎么整?

简介: 精选回答:有什么好办法,不重启服务,就能够修改配置么?

有个水友在知识星球提问:沈老师,我们有个连接超时的配置,平时是300毫秒,双11压力上来了,数据库变慢了,平均请求处理时间增加到了500毫秒,于是我们决定将连接超时改为1000毫秒,但这个过程需要重启服务,会影响正在执行的请求。有什么好办法,不重启服务,就能够修改配置么? 不妨设,读取与设置超时的伪代码如下:

// 从配置文件中读取超时配置

timeout = CGlobalConf::readFileConf(“timeout”);

// 设置请求超时阈值

CConnectionPool::setTimeout(timeout);

  不重启服务,重新载入配置的常见方式有3这么几种,不难但很使用,花1分钟和大家说一说。   方案一:发信号触发配置重载 这种方法无需加入任何组件, 新增一个信号捕捉函数 ,来处理配置的重新载入。  

// 服务启动时,设置ctrl+c回调函数

signal(SIGINT, sigint_shenjian_process);

 

// 捕获ctrl+c时,执行配置重新载入动作

void sigint_shenjian_process(int){

         //从配置中读取超时配置

         timeout= CGlobalConf::readFileConf(“timeout”);

         //设置请求超时阈值

         CConnectionPool::setTimeout(timeout);

}

  当需要变更配置时,只需要: (1)修改配置文件; (2)发送信号,触发配置重新载入; 画外音:啥,不知道如何向服务发信号?   方案二:检测配置文件变化,自动重新载入 这种方法无需手动发送信号,修改完配置文件,自动检测,自动载入,需要加入 文件监控组件 画外音:这类组件开源的也不少。   文件监控组件如何能监控文件的变化呢? 别想复杂了,可以 定期检查文件的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);  }
}
  方案三:配置中心,配置变化时回调 次方案抛弃了配置文件, 需要引入配置中心 (1)所有服务从配置中心拿配置; (2)必须从 配置中心后台修改配置 (3)配置修改, 配置中心回调引用了相关配置的服务  

// 服务启动时,从配置中心获取配置,并注册回调函数

timeout = CConfCenter::(“timeout”, callback_shenjian);

// 设置请求超时阈值

CConnectionPool::setTimeout(timeout);

 

void callback_shenjian(timeout){

         //在配置中心修改配置时,会收到回调

         CConnectionPool::setTimeout(timeout);

}

  修改配置,不重启服务,上面三种方式都很常见,不难但实用。 画外音:特别是前两种方式,瞬间就能实现。   希望大家有收获。

本文转自“架构师之路”公众号,58沈剑提供。

目录
相关文章
|
1月前
|
Java Shell
「sh脚步模版自取」测试线排查的三个脚本:启动、停止、重启、日志保存
「sh脚步模版自取」测试线排查的三个脚本:启动、停止、重启、日志保存
37 1
|
3月前
|
运维 安全 Shell
不要再内耗了,这么乱的IP地址,是时候用脚本了!
不要再内耗了,这么乱的IP地址,是时候用脚本了!
702 2
|
网络协议 前端开发 Java
windows系统下重启springboot项目时,提示端口被占用,却找不到占用端口的程序
windows系统下重启springboot项目时,提示端口被占用,却找不到占用端口的程序
|
安全 Ubuntu Linux
Linux服务器的关机或者重启你一般会怎么操作?今天介绍5种办法,最后一种可以成救命草!
Linux服务器的关机或者重启你一般会怎么操作?今天介绍5种办法,最后一种可以成救命草!
1485 0
|
Java 应用服务中间件 Apache
一招教你如何减少本地调试tomcat重启次数,亲测有效
一招教你如何减少本地调试tomcat重启次数,亲测有效
|
运维 NoSQL Java
从源码研究如何不重启项目实现redis配置动态切换
上一篇Websocket的续篇暂时还没有动手写,这篇算是插播吧。今天讲讲不重启项目动态切换redis服务。
从源码研究如何不重启项目实现redis配置动态切换
|
缓存 监控 NoSQL
好饭不怕晚,扒一下Redis配置文件的底Ku
好饭不怕晚,扒一下Redis配置文件的底Ku
140 0
|
项目管理
好的开始是成功的一半 -- 怎么做好一个项目的启动
俗话说号的开始是成功的一半,管理一个项目也同样是这样,很多的时候,项目运行中的遇到的问题往往就是在填项目启动时所埋的坑。一个好的项目启动能极大的提高项目成功的概率,避免项目过程中很多的风险。这里我简单总结一下一般项目启动的过程,希望能给需要的同学一点参考。
18906 0