前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >改了配置,不想重启,怎么整?

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

作者头像
架构师之路
发布2020-03-23 18:09:43
2.7K0
发布2020-03-23 18:09:43
举报
文章被收录于专栏:架构师之路

有个水友在知识星球提问:

沈老师,我们有个连接超时的配置,平时是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);

}

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

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

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-11-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 架构师之路 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
微服务引擎 TSE
微服务引擎(Tencent Cloud Service Engine)提供开箱即用的云上全场景微服务解决方案。支持开源增强的云原生注册配置中心(Zookeeper、Nacos 和 Apollo),北极星网格(腾讯自研并开源的 PolarisMesh)、云原生 API 网关(Kong)以及微服务应用托管的弹性微服务平台。微服务引擎完全兼容开源版本的使用方式,在功能、可用性和可运维性等多个方面进行增强。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档