總結(jié)Golang四種不同的參數(shù)配置方式
前言
在實(shí)際的開發(fā)過程中,我們必然會(huì)用到MySQL、Redis等這樣的服務(wù)。為了實(shí)現(xiàn)系統(tǒng)的配置化,我們會(huì)把一些配置信息單獨(dú)放在一些文件中,使用到的地方直接讀取配置文件即可。 常見的文件配置方式有很多中,例如json、tomal、yml或者文本格式。下面就針對(duì)幾種方式進(jìn)行一一演示。
演示代碼
JSON配置
首先我們創(chuàng)建一個(gè)JSON的文件,里面配置我們需要的參數(shù)格式,示例:
{ "host": "127.0.0.1", "user": "root", "password": "123456", "port": "3306", "db": "demo"
我們要讀取配文件,就需要用到Golang中自帶的??json?
?包。 具體的讀取過程: ??讀取json文件內(nèi)容->使用json包進(jìn)行反序列化->利用變量存反序列的數(shù)據(jù)?
?。
ang // 利用struct來定義json格式,與存儲(chǔ)。 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文件內(nèi)容 file, err := ioutil.ReadFile("./config/json.json") if err != nil { fmt.Println("err1", err) return } db := new(DbJson) // 2. 將讀取到的json文件內(nèi)容,進(jìn)行反序列化;將得到一個(gè)[]byte類型的切片 err = json.Unmarshal(file, db) if err != nil { fmt.Println("err2", err) return } // 2.1 將讀取到的json文件內(nèi)容,進(jìn)行反序列化,復(fù)制給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. 循環(huán)map內(nèi)容 for k, v := range allConfig { fmt.Println(k, string(v)) // 值為[]byte類型,將其轉(zhuǎn)為string }
最終輸入結(jié)果:
ang
host "127.0.0.1"
user "root"
password "123456"
port "3306"
db "demo
在2和2.1其實(shí)都是不同的實(shí)現(xiàn)方式。
yml配置
yml格式也是我們常見的文件配置格式,在Golang中,我們讀取該配置,主要用到了??gopkg.in/yaml.v2?
?包。 同樣的,我們需要??讀取配置文件->解析文件內(nèi)容?
?。我們創(chuàng)建一個(gè)??yml.yml?
?文件,寫入下面的示例配置:
yml host: 127.0.0.1 user: root password: 123456 port: 3306 db: dem
需要注意的是,yml的配置項(xiàng):與值中間是有一個(gè)空格的。
ang // 定義一個(gè)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. 讀取配置文件內(nèi)容,將返回一個(gè)[]byte的內(nèi)容 file, err := ioutil.ReadFile("./config/yml.yml") if err != nil { return } db := new(DbYml) // 2. 使用yaml包進(jìn)行反序列化 err = yaml.Unmarshal(file, db) if err != nil { return } fmt.Println(db.Host, db.User, db.Password, db.Port, db.Db)
最終輸入結(jié)果:
ang
127.0.0.1 root 123456 3306 dem
文本格式
讀取文件格式的內(nèi)容,就是按行讀取,然后針對(duì)每行的內(nèi)容進(jìn)行解析。因?yàn)槲覀兾谋局械母袷揭话愣际茄??key=value?
?的格式,因此我們只要讀取到改行的內(nèi)容,然后根據(jù)??=?
?進(jìn)行分割即可。
首先我們創(chuàng)建一個(gè)文件.txt的文件內(nèi)容,大致內(nèi)容如下:
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. 讀取文件內(nèi)容 content := bufio.NewReader(open) for { // 3. 按行讀取文件內(nèi)容 line, _, err := content.ReadLine() if err != nil { if err == io.EOF { // 去讀到結(jié)尾,就跳出循環(huán)讀取 break } return } // 4. 處理每一行讀取到的文件內(nèi)容 s := strings2.TrimSpace(string(line)) // 去掉左右空格 index := strings2.Index(s, "=") // 因?yàn)榕渲檬?,找到=的索引位置 if index < 0 { continue } key := strings2.TrimSpace(s[:index]) // 截取=左側(cè)的值為key if len(key) == 0 { continue } value := strings2.TrimSpace(s[index+1:]) // 截取=右側(cè)的為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() // 關(guān)閉關(guān)文件
輸出的內(nèi)容大致如下:
ang
host 127.0.0.1
user root
password 123456
port 3306
db dem
tomal
使用toml格式的配置文件,主要用到了toml包進(jìn)行解析出來。同樣的,首先我們是加載文件,將文件的路徑傳入到toml包中即可。
首先我們創(chuàng)建一個(gè)toml文件的,定義如下內(nèi)容:
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. 定義結(jié)構(gòu)體變量來接收解析的數(shù)據(jù) var config DbToml // 2. 獲取文件絕對(duì)路徑 fileName, err := filepath.Abs("./config/toml.toml") if err != nil { fmt.Println("err1", err) return } // 3. 根據(jù)toml包的規(guī)則傳入文件路徑 _, 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)
輸出結(jié)果如下:
ang
127.0.0.1 root 123456 3306 dem
到此這篇關(guān)于總結(jié)Golang四種不同的參數(shù)配置方式的文章就介紹到這了,更多相關(guān)Golang參數(shù)配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
golang?waitgroup輔助并發(fā)控制使用場(chǎng)景和方法解析
Golang?提供了簡潔的?go?關(guān)鍵字來讓開發(fā)者更容易的進(jìn)行并發(fā)編程,同時(shí)也提供了?WaitGroup?對(duì)象來輔助并發(fā)控制,今天我們就來分析下?WaitGroup?的使用方法,順便瞧一瞧它的底層源碼2023-09-09GoLang bytes.Buffer基礎(chǔ)使用方法詳解
Go標(biāo)準(zhǔn)庫中的bytes.Buffer(下文用Buffer表示)類似于一個(gè)FIFO的隊(duì)列,它是一個(gè)流式字節(jié)緩沖區(qū),我們可以持續(xù)向Buffer尾部寫入數(shù)據(jù),從Buffer頭部讀取數(shù)據(jù)。當(dāng)Buffer內(nèi)部空間不足以滿足寫入數(shù)據(jù)的大小時(shí),會(huì)自動(dòng)擴(kuò)容2023-03-03Golang多線程下載器實(shí)現(xiàn)高效快速地下載大文件
Golang多線程下載器是一種高效、快速地下載大文件的方法。Golang語言天生支持并發(fā)和多線程,可以輕松實(shí)現(xiàn)多線程下載器的開發(fā)。通過使用Golang的協(xié)程和通道,可以將下載任務(wù)分配到多個(gè)線程中并行處理,提高了下載的效率和速度2023-05-05go語言發(fā)送smtp郵件的實(shí)現(xiàn)示例
這篇文章主要介紹了go發(fā)送smtp郵件的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09