通过定时器实现配置文件热更新

简介: 配置文件修改及时生效

配置文件修改后,要达到及时生效,热加载的目的,那么可以通过2种方式实现

  1. 定时器循环,查看文件更新时间,如果发现有修改,那么重新加载
  2. 监听信号,文件更改后触发信号,通过捕获信号,再重新加载


例如,线上的应用日志级别为 info ,出现故障后,你需要开启 debug 来排查日志,但是把日志级别改成 debug ,那么你不得不重启应用,可能故障现象就不存在或不好重现了,而且重启服务可能会影响用户体验。


以下我就介绍一种定时器循环的方式来实现吧。

packagemainimport (
"encoding/json""fmt""io/ioutil""log""os""time")
//全局自定义拦截varintercept []Intercept//文件时间varftint64varfilenamestring="/Users/jiangyd/mygo/src/gi/intercept.json"typeInterceptstruct {
Urlstring`json:"url"`Methodstring`json:"method"`RespHeadermap[string]string`json:"resp_header"`RespBodyinterface{}       `json:"resp_body"`RespCodeint`json:"resp_code"`}
//读取自定义响应文件funcRead_resp() {
intercept_data, err :=ioutil.ReadFile(filename)
iferr!=nil {
log.Fatalln(err)
    }
err=json.Unmarshal(intercept_data, &intercept)
iferr!=nil {
log.Fatalln(err)
    }
}
funcmain() {
//启用定时器t :=time.NewTicker(1*time.Second)
gofunc() {
for {
_, ok :=<-t.Cifok {
fileinfo, err :=os.Stat(filename)
iferr!=nil {
fmt.Println(err)
                }
iffileinfo.ModTime().UnixNano() >ft {
Read_resp()
ft=fileinfo.ModTime().UnixNano()
                }
            }
        }
    }()
//循环打印for {
time.Sleep(1*time.Second)
iflen(intercept)>0{
fmt.Println(intercept[0].RespBody)
        }
    }
}

配置文件

[{
"url": "http://test.cloudcare.cn/api/v1/workspace/member/list",
"method": "get",
"resp_body": {"msg": "c"},
"resp_header": {"Content-Type": "application/json"},
"resp_code": 200}]


运行程序后,我编辑配置文件内容 resp_body  可以被重新加载到

map[msg:m]
map[msg:a]
map[msg:a]
map[msg:a]
map[msg:b]
map[msg:c]
map[msg:c]
目录
相关文章
|
8月前
|
Go 数据库 开发者
热更新最佳实践,网站无感知重启方法大全
热更新最佳实践,网站无感知重启方法大全
202 0
|
3月前
|
JavaScript 前端开发
js之永久定时器
js之永久定时器
36 1
|
5月前
|
JavaScript 前端开发
解决在JS中阻止定时器“重复”开启问题、Vue中定时器的使用
这篇文章讨论了在JavaScript和Vue中如何避免定时器重复开启的问题,并提供了一个模拟场景和代码示例,演示了在开启新定时器前清除旧定时器的方法。
解决在JS中阻止定时器“重复”开启问题、Vue中定时器的使用
|
8月前
|
应用服务中间件 nginx
nginx中的定时器源码分析与测试
nginx中的定时器源码分析与测试
69 0
|
前端开发 API 开发者
热更新原理
热更新原理
184 0
|
JavaScript
vue项目实现轮询定时器-关闭定时器(整理)
vue项目实现轮询定时器-关闭定时器(整理)
|
存储 数据可视化 Java
SpringBoot整合定时器:定时任务不再硬编码,动态定时刷起来
前言 传统定时器是硬编码。但是有的时候业务上需要不断地调整 问题描述 我们开发了一个定闹钟的功能。这个功能肯定是定时器开发。但是这就存在一个问题这个定时是动态的。那么我们如何实现呢?请接着看
|
JavaScript
Vue 开启或关闭热更新
Vue 开启或关闭热更新
672 0
|
JavaScript
热更新插件更新啦
热更新插件更新啦
171 0
|
开发工具 git
Compose中Paging3、SwipeRefresh配合实现下拉刷新和自动加载
Compose中Paging3、SwipeRefresh配合实现下拉刷新和自动加载
1280 0
Compose中Paging3、SwipeRefresh配合实现下拉刷新和自动加载