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

开发 开发工具 前端
不重启服务,重新载入配置的常见方式有3这么几种,不难但很使用,花1分钟和大家说一说。

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

不妨设,读取与设置超时的伪代码如下:

  1. // 从配置文件中读取超时配置 
  2. timeout = CGlobalConf::readFileConf(“timeout”); 
  3. // 设置请求超时阈值 
  4. CConnectionPool::setTimeout(timeout); 

不重启服务,重新载入配置的常见方式有3这么几种,不难但很使用,花1分钟和大家说一说。

方案一:发信号触发配置重载

这种方法无需加入任何组件,新增一个信号捕捉函数,来处理配置的重新载入。

  1. // 服务启动时,设置ctrl+c回调函数 
  2. signal(SIGINT, sigint_shenjian_process); 
  3.   
  4. // 捕获ctrl+c时,执行配置重新载入动作 
  5. void sigint_shenjian_process(int){ 
  6.          //从配置中读取超时配置 
  7.          timeoutCGlobalConf::readFileConf(“timeout”); 
  8.          //设置请求超时阈值 
  9.          CConnectionPool::setTimeout(timeout); 
  10.   

当需要变更配置时,只需要:

  • 修改配置文件;
  • 发送信号,触发配置重新载入;

画外音:啥,不知道如何向服务发信号?

方案二:检测配置文件变化,自动重新载入

这种方法无需手动发送信号,修改完配置文件,自动检测,自动载入,需要加入文件监控组件。

画外音:这类组件开源的也不少。

文件监控组件如何能监控文件的变化呢?

别想复杂了,可以定期检查文件的md5或者last_modify_time。

  1. // 服务启动时,初始化 
  2. CFileMonitor::init(){ 
  3.  // 获取初始md5 
  4.  old_md5=xxx
  5.   
  6. // 启动一个进程,监控文件变化 
  7. CFileMonitor::start(){ 
  8.  while(1){ // 循环检查 
  9.  // 获取最新md5 
  10.  now_md5=xxx
  11.  // 比对md5是否变化,如果变化 
  12.  if(now_md5!=old_md5){ 
  13.          //从配置中读取超时配置 
  14.          timeoutCGlobalConf::readFileConf(“timeout”); 
  15.          //设置请求超时阈值 
  16.          CConnectionPool::setTimeout(timeout); 
  17.          //修改md5 
  18.          old_md5=now_md5
  19.  } 
  20.  // 一秒后再检查 
  21.  sleep(1000); 
  22.  } 

方案三:配置中心,配置变化时回调

次方案抛弃了配置文件,需要引入配置中心:

  • 所有服务从配置中心拿配置;
  • 必须从配置中心后台修改配置;
  • 配置修改,配置中心回调引用了相关配置的服务;
  1. // 服务启动时,从配置中心获取配置,并注册回调函数 
  2. timeout = CConfCenter::(“timeout”, callback_shenjian); 
  3. // 设置请求超时阈值 
  4. CConnectionPool::setTimeout(timeout); 
  5.   
  6. void callback_shenjian(timeout){ 
  7.          //在配置中心修改配置时,会收到回调 
  8.          CConnectionPool::setTimeout(timeout); 
  9.   

修改配置,不重启服务,上面三种方式都很常见,不难但实用。

画外音:特别是前两种方式,瞬间就能实现。

希望大家有收获。

【本文为51CTO专栏作者“58沈剑”原创稿件,转载请联系原作者】

戳这里,看该作者更多好文

责任编辑:赵宁宁 来源: 51CTO专栏
相关推荐

2020-09-26 22:12:01

配置重启文件

2017-06-15 08:02:02

库存扣减查询

2012-10-15 09:22:24

云数据存储云存储云数据存储成本

2018-05-23 07:14:10

整合数据中心运维管理

2021-01-06 09:12:00

MySQL数据库架构

2013-02-28 11:00:51

IE10浏览器

2010-03-30 10:02:09

陈晓薇

2013-12-03 16:38:35

vSphere HA虚拟机

2022-11-29 10:33:15

Kubectl命令pod

2021-03-18 10:35:04

MySQL数据库架构

2021-04-02 09:50:28

MySQL数据库架构

2021-08-11 11:25:22

happens - bJava代码

2021-06-10 14:34:02

鸿蒙HarmonyOS应用

2013-08-12 15:10:50

GoogleGoogle总部

2021-07-29 07:51:43

工具 HappensBefore

2015-11-12 10:56:13

2015-06-15 11:21:03

密码

2021-08-11 16:34:02

浮动路由路由网络技术

2010-02-07 10:46:26

2020-08-03 09:05:48

代码程序员案例
点赞
收藏

51CTO技术栈公众号