Golang参数配置
7small7 人气:0前言
在实际的开发过程中,我们必然会用到MySQL、Redis等这样的服务。为了实现系统的配置化,我们会把一些配置信息单独放在一些文件中,使用到的地方直接读取配置文件即可。 常见的文件配置方式有很多中,例如json、tomal、yml或者文本格式。下面就针对几种方式进行一一演示。
演示代码
JSON配置
首先我们创建一个JSON的文件,里面配置我们需要的参数格式,示例:
{ "host": "127.0.0.1", "user": "root", "password": "123456", "port": "3306", "db": "demo"
我们要读取配文件,就需要用到Golang中自带的json
包。 具体的读取过程: 读取json文件内容->使用json包进行反序列化->利用变量存反序列的数据
。
ang // 利用struct来定义json格式,与存储。 type DbJson struct { Host string `json:"host"` User string `json:"user"` Password string `json:"password"` Port string `json:"port"` Db string `json:"db"` } // 解析 func GetJsonConfig() { // 1. 读取json文件内容 file, err := ioutil.ReadFile("./config/json.json") if err != nil { fmt.Println("err1", err) return } db := new(DbJson) // 2. 将读取到的json文件内容,进行反序列化;将得到一个[]byte类型的切片 err = json.Unmarshal(file, db) if err != nil { fmt.Println("err2", err) return } // 2.1 将读取到的json文件内容,进行反序列化,复制给map[string][]byte(和2中的效果是一样的) allConfig := make(map[string]json.RawMessage, 0) err = json.Unmarshal(file, &allConfig) if err != nil { fmt.Println("err3", err) return } // 3. 循环map内容 for k, v := range allConfig { fmt.Println(k, string(v)) // 值为[]byte类型,将其转为string }
最终输入结果:
ang
host "127.0.0.1"
user "root"
password "123456"
port "3306"
db "demo
在2和2.1其实都是不同的实现方式。
yml配置
yml格式也是我们常见的文件配置格式,在Golang中,我们读取该配置,主要用到了gopkg.in/yaml.v2
包。 同样的,我们需要读取配置文件->解析文件内容
。我们创建一个yml.yml
文件,写入下面的示例配置:
yml host: 127.0.0.1 user: root password: 123456 port: 3306 db: dem
需要注意的是,yml的配置项:与值中间是有一个空格的。
ang // 定义一个struct来定义格式 type DbYml struct { Host string `yaml:"host"` User string `yaml:"user"` Password string `yaml:"password"` Port string `yaml:"port"` Db string `yaml:"db"` } func GetYmlConfig() { // 1. 读取配置文件内容,将返回一个[]byte的内容 file, err := ioutil.ReadFile("./config/yml.yml") if err != nil { return } db := new(DbYml) // 2. 使用yaml包进行反序列化 err = yaml.Unmarshal(file, db) if err != nil { return } fmt.Println(db.Host, db.User, db.Password, db.Port, db.Db)
最终输入结果:
ang
127.0.0.1 root 123456 3306 dem
文本格式
读取文件格式的内容,就是按行读取,然后针对每行的内容进行解析。因为我们文本中的格式一般都是循序key=value
的格式,因此我们只要读取到改行的内容,然后根据=
进行分割即可。
首先我们创建一个文件.txt的文件内容,大致内容如下:
host=127.0.0.1 user=root password=123456 port=3306 db=dem
具体读取配置代码:
ang func GetKeyValue() { allConfig := make(map[string]string) // 1. 读取文件,得到文件句柄 open, err := os.Open("./config/key.txt") if err != nil { fmt.Println("err1", err) return } // 2. 读取文件内容 content := bufio.NewReader(open) for { // 3. 按行读取文件内容 line, _, err := content.ReadLine() if err != nil { if err == io.EOF { // 去读到结尾,就跳出循环读取 break } return } // 4. 处理每一行读取到的文件内容 s := strings2.TrimSpace(string(line)) // 去掉左右空格 index := strings2.Index(s, "=") // 因为配置是=,找到=的索引位置 if index < 0 { continue } key := strings2.TrimSpace(s[:index]) // 截取=左侧的值为key if len(key) == 0 { continue } value := strings2.TrimSpace(s[index+1:]) // 截取=右侧的为value if len(value) == 0 { continue } allConfig[key] = value // 添加到map中,key为map的key,value为map的value } for k, v := range allConfig { fmt.Println(k, string(v)) } defer open.Close() // 关闭关文件
输出的内容大致如下:
ang
host 127.0.0.1
user root
password 123456
port 3306
db dem
tomal
使用toml格式的配置文件,主要用到了toml包进行解析出来。同样的,首先我们是加载文件,将文件的路径传入到toml包中即可。
首先我们创建一个toml文件的,定义如下内容:
ang [database] host="127.0.0.1" user="root" password="123456" port=[3306, 3307] db="demo
下面是具体的解析代码:
ang import ( "github.com/BurntSushi/toml" "path/filepath" ) type DbToml struct { Db Database `toml:"database"` } type Database struct { Host string User string Password string Port []int32 Db string } func GetToml() { // 1. 定义结构体变量来接收解析的数据 var config DbToml // 2. 获取文件绝对路径 fileName, err := filepath.Abs("./config/toml.toml") if err != nil { fmt.Println("err1", err) return } // 3. 根据toml包的规则传入文件路径 _, err1 := toml.DecodeFile(fileName, &config) if err1 != nil { fmt.Println("err2", err1) return } fmt.Println(config.Db.Host, config.Db.User, config.Db.Password, config.Db.Port[0], config.Db.Db)
输出结果如下:
ang
127.0.0.1 root 123456 3306 dem
加载全部内容