Go 项目配置文件的定义和读取
前言
我们在写应用时,基本都会用到配置文件,从各种 shell
到 nginx
等,都有自己的配置文件。虽然这没有太多难度,但是配置项一般相对比较繁杂,解析、校验也会比较麻烦。本文就给大家讲讲我们是怎么简化配置文件的定义和解析的。
场景
如果我们要写一个 Restful API
的服务,配置项大概有如下内容:
Host
,侦听的IP
,如果不填,默认用0.0.0.0
Port
,侦听的端口,必填,只能是数字,大于等于80,小于65535LogMode
,日志模式,只能选file
或者console
Verbose
,看是否输出详细日志,可选,默认为false
MaxConns
,允许的最大并发连接数,默认10000
Timeout
,超时设置,默认3s
CpuThreshold
,设置CPU
使用率触发系统降载的阈值,默认900
,1000m
表示100%
之前我们用 json
做配置文件,但是 json
有个问题,无法加注释,所以我们后来切换到了 yaml
格式。
接下来让我们看看借助 go-zero
怎么来方便的的定义和解析这样的配置文件~
定义配置
首先,我们需要将上述配置需求定义到 Go 结构体里,如下:
RestfulConf struct {
Host string `json:",default=0.0.0.0"`
Port int `json:",range=[80,65535)"`
LogMode string `json:",options=[file,console]"`
Verbose bool `json:",optional"`
MaxConns int `json:",default=10000"`
Timeout time.Duration `json:",default=3s"`
CpuThreshold int64 `json:",default=900,range=[0:1000]"`
}
可以看到,我们对每个配置项都有一定的定义和限制,其中一些定义如下:
default
,配置没填的话,使用该默认值,可以看到其中的3s
会自动解析成time.Duration
类型optional
,此项可以不配置,没有的话,用类型零值range
,限定数字类型,需要在给定的范围内options
,限制配置的值只能是给出的这几个之一
并且,一些属性可以叠加使用,比如:
default
和range
一起使用,就可以既增加了范围限制,又提供了默认值default
和options
一起使用,就可以既增加了可选项限制,又提供了默认值
配置文件
因为我们在定义配置的时候,给了很多的默认值,还有使用 optional
指定为可选,所以我们的配置文件里的配置项就相对比较少了,能用默认值的就不用写了,如下:
# 因为很多都有默认值,所以只需要写需要指定值和没有默认值的
Port: 8080
LogMode: console
# 可以读取环境变量的值
MaxBytes: ${MAX_BYTES}
这里有个注意点,如果配置项的 value
全部是数字,而你定义的配置类型是 string
,比如有人测试密码经常用 123456
,但是密码一般会定义为 string
,配置就要写成如下(只是举个例子哈,密码一般不建议裸写到配置文件里):
Password: "123456"
这里的双引号不能少,少了会报 type mismatch
之类的错误,因为 yaml
解析器会把不带双引号的 123456
解析成 int
。
加载配置文件
我们有了配置定义(config.go
)和配置文件(config.yaml
),接下来就是加载配置文件了,加载配置文件有三种方式:
- 必须加载成功,否则程序退出,我们一般这么用,如果配置不对,程序就无法继续了
// 有错误直接退出程序
var config RestfulConf
conf.MustLoad("config.yaml", &config)
go-zero
自带的 goctl
生成的默认代码也是使用 MustLoad
来加载配置文件的
- 加载配置,并自行判断是否有
error
// 自己判断并处理 error
var config RestfulConf
// 为了更简洁,这里的 LoadConfig 后续会改为 Load,LoadConfig 已被标记为 Deprecated
if err := conf.LoadConfig("config.yaml", &config); err != nil {
log.Fatal(err)
}
- 加载配置并读取环境变量
// 自动读取环境变量
var config RestfulConf
conf.MustLoad(configFile, &config, conf.UseEnv())
这里为啥我们需要显式指定 conf.UseEnv()
,因为如果默认读取的话,可能在配置里大家写特定字符的时候就需要 escape
了,所以默认不读取环境变量,这个设计也欢迎大家多提提建议哈
实现原理
我们在实现类似 yaml/json
解析的时候一般会直接使用 encoding/json
或者对应的 yaml
库,但是对于 go-zero
来说,我们需要在 unmarshal
的时候有更精确的控制,这就需要我们自己定制 yaml/json
的解析了,完整的代码实现在:
配置文件代码:https://github.com/zeromicro/go-zero/tree/master/core/conf
yaml/json
解析代码:https://github.com/zeromicro/go-zero/tree/master/core/mapping
这里也充分展示了 reflect
的用法,以及复杂场景下如何通过单元测试保证代码的正确性。
总结
我一直比较推荐 Fail Fast
的思想,我们在加载配置文件的时候也是这样,一旦有错误,立马退出,这样运维在部署服务时就会及时发现问题,因为进程压根起不来。
go-zero
的所有服务的配置项都是通过这样的方式来加载和自动验证的,包括我写的很多工具的配置也是基于此来实现的,希望能对你有所帮助!
项目地址
https://github.com/zeromicro/go-zero
https://gitee.com/kevwan/go-zero
欢迎使用 go-zero
并 star 支持我们!
微信交流群
关注『微服务实践』公众号并点击 交流群 获取社区群二维码。
如果你有 go-zero
的使用心得文章,或者源码学习笔记,欢迎通过公众号联系投稿!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
openGauss数据库性能调优概述及实例分析
目录 调优思路概述 调优流程 确定性能调优范围 性能因素 调优范围确定 硬件瓶颈点分析 CPU 内存 I/O 网络 查询最耗性能的SQL 分析作业是否被阻塞 调优思路概述 openGauss的总体性能调优思路为性能瓶颈点分析、关键参数调整以及SQL调优。在调优过程中,通过系统资源、吞吐量、负载等因素来帮助定位和分析性能问题,使系统性能达到可接受的范围。 openGauss性能调优过程需要综合考虑多方面因素,因此,调优人员应对系统软件架构、软硬件配置、数据库配置参数、并发控制、查询处理和数据库应用有广泛而深刻的理解。 须知: 性能调优过程有时候需要重启openGauss,可能会中断当前业务。因此,业务上线后,当性能调优操作需要重启openGauss时,操作窗口时间需向管理部门提出申请,经批准后方可执行。 调优流程 调优流程如图1所示。 图 1openGauss性能调优流程 调优各阶段说明,如表1所示。 表 1openGauss性能调优流程说明 阶段 描述 确定性能调优范围 获取openGauss节点的CPU、内存、I/O和网络资源使用情况,确认这些资源是否已被充分利用,是否存在瓶颈点。 ...
-
下一篇
HMS Core音频编辑服务实时变声,大叔音怪兽音随意变换
变声是直播类、聊天类应用中用户经常使用的功能。例如:很多主播选择使用变声器来实现带动直播间气氛;和朋友语音聊天时选择变成萝莉音让聊天更有趣。HMS Core音频编辑服务提供变声能力,帮助开发者在应用中构建变声功能。用户可以通过预置的变声风格进行变声,提升音频可玩性的同时有效保护用户隐私,让你随心所欲、想变就变。 HMS Core音频编辑服务目前可提供7种变声效果,包括大叔、萝莉、男生、女声、怪兽、卡通、机器人。不限语种,且实时处理,可简单便捷的应用在音视频通信或互娱直播场景,为主播提供实时变声特效,让直播音色更动听、更有趣。 变声效果 下面我们就一起来实操一下如何接入华为音频编辑服务,实现变声效果吧。 1开发准备 详细准备步骤可参考华为开发者联盟官网 2编辑工程集成 2.1设置应用的鉴权信息 开发者需要通过api_key或者Access Token来设置应用鉴权信息。 通过setAccessToken方法设置Access Token,在应用启动时初始化设置 HAEApplication.getInstance().setAccessToken("your access token");...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL数据库在高并发下的优化方案
- Dcoker安装(在线仓库),最新的服务器搭配容器使用
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS8编译安装MySQL8.0.19
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- SpringBoot2整合Thymeleaf,官方推荐html解决方案