您好,登錄后才能下訂單哦!
今天小編給大家分享一下配置中心nacos如何安裝使用的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
什么是配置中心
用來統一管理項目中所有配置的系統。 雖然聽起來很簡單,但也不要小瞧了這個模塊。 如果一個中型互聯網項目,不采用配置中心的模式,一大堆的各類配置項,各種不定時的修改需求,一定會讓開發同學非常頭疼且管理十分混亂。
配置中心的服務流程如下: 用戶在配置中心更新配置信息。 服務 A 和服務 B 及時得到配置更新通知,從配置中心獲取配置。 總得來說,配置中心就是一種統一管理各種應用配置的基礎服務組件。
在系統架構中,配置中心是整個微服務基礎架構體系中的一個組件,它的功能看上去并不起眼,無非就是配置的管理和存取,但它是整個微服務架構中不可或缺的一環。
nacos 是什么
Nacos
Nacos 是 Naming and Configuration Service 的縮寫,從名字上能看出它重點關注的兩個領域是 Naming 即注冊中心和Configuration 配置中心。
業務上的配置,功能開關,服務治理上對弱依賴的降級,甚至數據庫的密碼等,都可能用到動態配置中心。 在沒有專門的配置中心組件時,我們使用硬編碼、或配置文件、或數據庫、緩存等方式來解決問題。 硬編碼修改配置時需要重新編譯打包,配置文件需要重啟應用,數據庫受限于性能,緩存喪失了及時性。
Nacos 的配置模型
namespace + group + dataId 唯一確定一個配置
namespace:與 client 綁定,一個 clinet 對應到一個 namespace,可用來隔離環境或區分租戶
group:分組,區分業務
dataId:配置的 id
來看一下是如何在實際場景使用的
例如:一個電商網站其中有這幾個模塊:用戶模塊、商品模塊、訂單模塊、庫存模塊
這幾個模塊都需要進行配置且它們的配置不同,這是我們為每一個模塊做一個 namespace, 每一個模塊都需要有
開發階段的配置,和上線后的配置,使用我們使用 dev, 和 pro 兩個分組來進行區分,對于 dataId,不管是 dev 還是
pro 都必須填寫。
Nacos 的安裝
這里我們直接使用 docker 進行安裝
Nacos 的安裝 (docker)
docker run --name nacos-standalone -e MODE=standalone -e JVM_XMS=512m -e JVM_XMX=512m -e JVM_XMN=256m -p 8848:8848 -d nacos/nacos-server:latest
訪問:192.168.1.103:8848/nacos/index.html 用戶名 / 密碼:nacos/nacos
配置開機啟動:
docker container update --restart=always xxx
用 nacos 做配置
nacos 成功啟動后訪問:192.168.1.103:8848/nacos/index.html
可以創建 namespace, 我們新建一個用戶模塊 user , 創建成功后可以看到有對應的 id, 例如:7ae18f62-e2b9-48bd-bff2-a49e7443f5bc
然后我們在 user 命名空間下新建一個配置文件,并填寫對應的名稱 (dataId) 和分組,這里我們新建一個 josn 的配置文件:
{
"name": "user-web",
"host": "10.2.106.169",
"port": 9091,
"tags":["iceymoss", "goods", "golang", "web"],
"user_srv":{
"name": "user-srv",
"host": "10.2.106.169",
"port": 8081
},
"jwt":{
"key": "dfijdfjidhfjijdfbdfdFwohPd6XmVCdnQi"
},
"sms":{
"key": "mykey",
"secret": "mysecret"
},
"params":{
"sign_name": "生鮮小店",
"code": "SMS_244610581"
},
"redis":{
"host": "127.0.0.1",
"port": 6379,
"expir": 300
},
"verify":{
"width": 5
},
"consul":{
"host": "10.2.106.169",
"port": 8500
},
"tracing":{
"host": "127.0.0.1",
"port": 6831,
"name": "shopping"
}
}
這樣整個配置文件就配置完成了
讀取 nacos 中配置文件
拉取依賴
我們使用 go 來讀取配置文件,使用需要拉取 nacos 的 sdk:
go get github.com/nacos-group/nacos-sdk-go/clients
go get github.com/nacos-group/nacos-sdk-go/common/constant
go get github.com/nacos-group/nacos-sdk-go/vo
讀取配置
在讀取配置之前我們先編寫一個用來做配置映射的結構體
目錄結構:
nacos_test
├── config
│ └── config.go
└── main.go
編寫 config 時需要注意的是我們需要保持 tag 名和配置文件中的名稱一致
package config
//UserSerConfig 映射用戶配置
type UserSerConfig struct {
Name string `mapstructure:"name" json:"name"`
Host string `mapstructure:"host" json:"host"`
Port int `mapstructure:"port" json:"port"`
}
//JWTConfig 映射token配置
type JWTConfig struct {
SigningKey string `mapstructure:"key" json:"key"`
}
//AliSmsConfig 阿里秘鑰
type AliSmsConfig struct {
Apikey string `mapstructure:"key" json:"key"`
ApiSecret string `mapstructure:"secret" json:"secret"`
}
//ParamsConfig 短信模板配置
type ParamsConfig struct {
SignName string `mapstructure:"sign_name" json:"sign_name"`
TemplateCode string `mapstructure:"code" json:"code"`
}
//RedisConfig redis數據庫配置
type RedisConfig struct {
Host string `mapstructure:"host" json:"host"`
Port int `mapstructure:"port" json:"port"`
Expir int `mapstructure:"expir" json:"expir"`
}
//Verifier 手機驗證長度
type Verifier struct {
Width int `mapstructure:"width" json:"width"`
}
type ConsulConfig struct {
Host string `mapstructure:"host" json:"host"`
Port int `mapstructure:"port" json:"port"`
}
//ServerConfig 映射服務配置
type ServerConfig struct {
Name string `mapstructure:"name" json:"name"`
Port int `mapstructure:"port" json:"port"`
UserSerInfo UserSerConfig `mapstructure:"user_srv" json:"user_srv"`
JWTInfo JWTConfig `mapstructure:"jwt" json:"jwt"`
AliSms AliSmsConfig `mapstructure:"sms" json:"sms"`
Params ParamsConfig `mapstructure:"params" json:"params"`
Redis RedisConfig `mapstructure:"redis" json:"redis"`
Verify Verifier `mapstructure:"verify" json:"verify"`
ConsulInfo ConsulConfig `mapstructure:"consul" json:"consul"`
}
下面進行配置文件讀取:
package main
import (
"StudyGin/nacos/config"
"encoding/json"
"fmt"
"github.com/nacos-group/nacos-sdk-go/clients"
"github.com/nacos-group/nacos-sdk-go/common/constant"
"github.com/nacos-group/nacos-sdk-go/vo"
)
func main() {
//服務端配置, nacos運行的socket
sc := []constant.ServerConfig{
{
IpAddr: "10.2.81.102",
Port: 8848,
},
}
//客服端配置
cc := constant.ClientConfig{
NamespaceId: "7ae18f62-e2b9-48bd-bff2-a49e7443f5bc", // 如果需要支持多namespace,我們可以場景多個client,它們有不同的NamespaceId
TimeoutMs: 5000,
NotLoadCacheAtStart: true,
LogDir: "tmp/nacos/log",
CacheDir: "tmp/nacos/cache",
//RotateTime: "1h",
//MaxAge: 3,
LogLevel: "debug",
}
configClient, err := clients.CreateConfigClient(map[string]interface{}{
"serverConfigs": sc,
"clientConfig": cc,
})
if err != nil {
panic(err)
}
//獲取配置
content, err := configClient.GetConfig(vo.ConfigParam{
DataId: "user-web.json",
Group: "dev"})
if err != nil {
panic(err)
}
Config := &config.ServerConfig{}
//將配置信息讀取到config.ServerConfig{}對象中
err = json.Unmarshal([]byte(content), &Config)
if err != nil {
panic(err)
}
fmt.Println(Config)
}
輸出:
&{user-web 9091 {user-srv 10.2.106.169 8081} {dfijdfjidhfjijdfbdfdFwohPd6XmVCdnQi} {mykey mysecret} {生鮮小店 SMS_244610581} {127.0.0.1 6379 300} {5} {10.2.106.1600}}
當然配置中心和 viper 都提供實時監控配置
可以這樣寫:
//監聽配置變化
err = configClient.ListenConfig(vo.ConfigParam{
DataId: "user-web",
Group: "DEV",
OnChange: func(namespace, group, dataId, data string) {
fmt.Println("配置文件變化")
fmt.Println("group:" + group + ", dataId:" + dataId + ", data:" + data)
},
})
time.Sleep(3000 * time.Second)
以上就是“配置中心nacos如何安裝使用”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。