分享
golang整洁之道(一)
Mandelbrot_Kobe · · 1385 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
设计工整的go项目配置文件
问题背景
- 项目经常会涉及到配置文件,而配置文件往往包含多方的配置信息,可能同时涉及到MySQL,kafka,hive,hdfs等等。
不加思索的yaml配置文件
- 最快,最直接的方案自然是如下示例,直接写
-
yaml部分
hdfs_path: "/user/hive/warehouse/dm_user.db/user_vod_time/create_time=" hdfs_host: "hdfsNode9" hdfs_port: "8020" eth_host: "http://127.0.0.1" eth_port: "8545" coin_password: "password" -
golang部分
package config type config struct{ HDFSPath string `yaml:"hdfs_path"` HDFSHost string `yaml:"hdfs_host"` HDFSPort string `yaml:"hdfs_port"` EthHost string `yaml:"eth_host"` EthPort string `yaml:"eth_port"` EthCoinPassword string `yaml:"coin_password"` }
这个方案存在什么问题
- 没有条理,虽然在命名方面可以看出来对应的各个部分的配置,但是不够清晰。假如项目规模增大,配置文件内容看上去就是一大坨
- 每一个包,可能需要再额外定义一个类似的结构,保存相应的配置,造成代码的冗余。毕竟,以上边这个例子来说,HDFS的处理跟ETH的处理不可能放在一个package里,那对应的包要不要再定义一个数据结构,保存配置数据呢?
更加清晰的yaml配置文件
- 利用golang struct的组合特性,就可以让结构更加清晰,减少代码冗余
-
yaml文件
hdfs: { path: "/user/hive/warehouse/dm_user.db/user_vod_time/create_time=", host: "hdfsNode9", port: "8020" } eth: { host: "http://127.0.0.1", port: "8545", coin_password: "password", } -
golang 文件——config包
type config struct { hdfs.HDFSConfig `yaml:"hdfs"` eth.EthConfig `yaml:"eth"` } -
golang文件——eth包
type EthConfig struct { EthHost string `yaml:"host"` EthPort string `yaml:"port"` EthCoinPassword string `yaml:"coin_password"` } -
golang文件——hdfs包
type HDFSConfig struct { HDFSPath string `yaml:"path"` HDFSHost string `yaml:"host"` HDFSPort string `yaml:"port"` }
总结
- 整个配置文件和代码结构,重构之后瞬间清晰了很多。用代码实现需求通常不难,大部分时候都有别人写好的接口,直接调用就可以。但是要想写好golang,让结构清晰,代码健壮,接下来还需要花很多功夫。(借助struct的组合,常常可以让代码结构更加清晰)
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1385 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
设计工整的go项目配置文件
问题背景
- 项目经常会涉及到配置文件,而配置文件往往包含多方的配置信息,可能同时涉及到MySQL,kafka,hive,hdfs等等。
不加思索的yaml配置文件
- 最快,最直接的方案自然是如下示例,直接写
-
yaml部分
hdfs_path: "/user/hive/warehouse/dm_user.db/user_vod_time/create_time=" hdfs_host: "hdfsNode9" hdfs_port: "8020" eth_host: "http://127.0.0.1" eth_port: "8545" coin_password: "password" -
golang部分
package config type config struct{ HDFSPath string `yaml:"hdfs_path"` HDFSHost string `yaml:"hdfs_host"` HDFSPort string `yaml:"hdfs_port"` EthHost string `yaml:"eth_host"` EthPort string `yaml:"eth_port"` EthCoinPassword string `yaml:"coin_password"` }
这个方案存在什么问题
- 没有条理,虽然在命名方面可以看出来对应的各个部分的配置,但是不够清晰。假如项目规模增大,配置文件内容看上去就是一大坨
- 每一个包,可能需要再额外定义一个类似的结构,保存相应的配置,造成代码的冗余。毕竟,以上边这个例子来说,HDFS的处理跟ETH的处理不可能放在一个package里,那对应的包要不要再定义一个数据结构,保存配置数据呢?
更加清晰的yaml配置文件
- 利用golang struct的组合特性,就可以让结构更加清晰,减少代码冗余
-
yaml文件
hdfs: { path: "/user/hive/warehouse/dm_user.db/user_vod_time/create_time=", host: "hdfsNode9", port: "8020" } eth: { host: "http://127.0.0.1", port: "8545", coin_password: "password", } -
golang 文件——config包
type config struct { hdfs.HDFSConfig `yaml:"hdfs"` eth.EthConfig `yaml:"eth"` } -
golang文件——eth包
type EthConfig struct { EthHost string `yaml:"host"` EthPort string `yaml:"port"` EthCoinPassword string `yaml:"coin_password"` } -
golang文件——hdfs包
type HDFSConfig struct { HDFSPath string `yaml:"path"` HDFSHost string `yaml:"host"` HDFSPort string `yaml:"port"` }
总结
- 整个配置文件和代码结构,重构之后瞬间清晰了很多。用代码实现需求通常不难,大部分时候都有别人写好的接口,直接调用就可以。但是要想写好golang,让结构清晰,代码健壮,接下来还需要花很多功夫。(借助struct的组合,常常可以让代码结构更加清晰)