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

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

有个水友在知识星球提问:沈老师,我们有个连接超时的配置,平时是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沈剑提供。

目录
相关文章
|
11月前
|
人工智能 前端开发 API
OpenAI 12天发布会内容全纪录!一文快速回顾获知亮点信息,原文附发布会中文字幕视频
OpenAI 于12月5日宣布将举行为期12天的系列发布活动,期间每天发布一个产品或样品,包括备受期待的AI视频生成工具Sora和新的推理模型。本文将介绍这12天的发布会每日的发布内容和相关亮点信息。
746 82
|
安全 Android开发 Kotlin
Android经典实战之SurfaceView原理和实践
本文介绍了 `SurfaceView` 这一强大的 UI 组件,尤其适合高性能绘制任务,如视频播放和游戏。文章详细讲解了 `SurfaceView` 的原理、与 `Surface` 类的关系及其实现示例,并强调了使用时需注意的线程安全、生命周期管理和性能优化等问题。
552 8
|
8月前
|
设计模式 安全 Java
设计模式觉醒系列(02)这几种设计模式很简单实用 | 相信你肯定见过
本文介绍了设计模式中的模板方法模式、外观模式和单例模式。模板方法模式通过父类定义算法框架,子类实现具体步骤,提高代码复用性和扩展性;外观模式提供高层次接口隐藏子系统复杂性,降低耦合度;单例模式确保一个类只有一个实例,适用于资源开销敏感场景。文中结合实战demo及Tomcat源码应用详细解析了这三种模式的实现与优点,并附带Spring中单例模式的应用示例。
|
8月前
|
安全
一文看懂网络文化经营许可证
一文看懂网络文化经营许可证
562 3
|
编译器 数据安全/隐私保护 C++
C++一分钟之-属性友元与访问控制
【7月更文挑战第9天】C++中的友元机制允许非成员函数或类访问私有和保护成员,打破了封装性。友元需在类内声明,常见的错误包括忘记声明、过度使用及误解友元的非继承性。要避免错误,应明确声明友元,限制其使用,并理解其局限。示例展示了如何声明和使用友元函数来访问私有数据。谨慎使用友元以保持代码的健壮性和可维护性。
247 1
|
11月前
|
存储 IDE JavaScript
【HarmonyOS Next开发】端云一体化初始化项目
端云一体化开发是HarmonyOS对云端开发的支持、实现端云联动。云开发服务提供了云函数、云数据库、云存储等服务,可以使开发者专注于应用的业务逻辑开发,无需关注基础设施,例如:服务器、操作系统等问题。
249 6
【HarmonyOS Next开发】端云一体化初始化项目
|
11月前
|
自然语言处理 供应链 数据可视化
跨境电商团队如何管理远程项目?选择看板工具时需要考虑的关键因素
随着跨境电商的迅速发展,全球化带来了巨大商机,但也带来了跨时区、语言和文化差异等协作挑战。为了提高远程协作效率,本文推荐了五款适合跨境电商团队使用的看板工具:板栗看板、Trello、Asana、ClickUp 和 Monday.com。这些工具通过可视化的任务管理和进度追踪,帮助团队高效协作、确保信息一致性和任务顺利完成。
跨境电商团队如何管理远程项目?选择看板工具时需要考虑的关键因素
|
分布式计算 Java 数据处理
Apache Spark优缺点大揭秘
【10月更文挑战第12天】
475 11
|
C语言 索引 Python
利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
297 4
|
数据采集 监控 安全
数据预处理几种常见问题
【6月更文挑战第12天】数据处理中常见的问题:数据缺失、数据重复、数据异常和数据样本差异大。对于数据缺失,处理方法包括定位、不处理、删除和填补,其中填补可使用业务知识、其他属性或统计方法。