go配置解析库 - viper

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: go配置解析库 - viper

简介

viper 是一个配置解决方案,拥有丰富的特性:

  • 支持 JSON/TOML/YAML/HCL/envfile/Java properties 等多种格式的配置文件;
  • 可以设置监听配置文件的修改,修改时自动加载新的配置;
  • 从环境变量、命令行选项和io.Reader中读取配置;
  • 从远程配置系统中读取和监听修改,如 etcd/Consul;
  • 代码逻辑中显示设置键值。

获取

$ go get github.com/spf13/viper
AI 代码解读

读取配置

viper读入配置有如下读入方式:

  • 设置默认的配置名
  • 读取配置文件
  • 监听和重新读取配置文件
  • 从io.Reader读取配置
  • 从环境变量读取
  • 从命令行标志读取
  • 从远程Key/Value存储读取

读取顺序

  1. 从默认的设置中读取
  2. 从pflag中读取
  3. 从环境变量中读取
  4. 从配置文件中读取
  5. 从KV存储中读取
  6. 从默认的配置文件中读取

其API如下,这里我将其进行分组

在这里插入图片描述

AddConfigPath

func AddConfigPath(in string)
AI 代码解读

添加文件的搜索路径

AddRemoteProvider

func AddRemoteProvider(provider, endpoint, path string) error
AI 代码解读

添加远程源,当前支持etcd、consul、firestore

  • provider:etcd、consul、firestore
  • endpoint:连接地址

    • etcd为http: //ip:port
    • consul为ip:port
  • path从kv存储中检索配置的路径,例如要从/configs/myapp.json检索名为myapp.json的配置文件则应该设置为/config并将配置名(SetConfigName)设置为myapp

AddSecureRemoteProvider

func AddSecureRemoteProvider(provider, endpoint, path, secretkeyring string) error
AI 代码解读

添加远程源,当前支持etcd、consul、firestore

  • provider:etcd、consul、firestore
  • endpoint:连接地址

    • etcd为http: //ip:port
    • consul为ip:port
  • path从kv存储中检索配置的路径,例如要从/configs/myapp.json检索名为myapp.json的配置文件则应该设置为/config并将配置名(SetConfigName)设置为myapp
  • secretkeyring:密钥路径

AllKeys

func AllKeys() []string
AI 代码解读

返回所有的键。

AllSettings

func AllSettings() map[string]interface{}
AI 代码解读

将所有键值对返回

AllowEmptyEnv

func AllowEmptyEnv(allowEmptyEnv bool)
AI 代码解读

是否允许空的环境变量视为有效值,默认是false

AutomaticEnv

func AutomaticEnv()
AI 代码解读

开启环境变量检查是否匹配现有键值,如果匹配则加载。

BindEnv

func BindEnv(input ...string) error
AI 代码解读

将环境变量的值设置到viper键中,该函数可以提供一或两个参数。

  • 只提供一个参数: 默认环境变量与该简直名称相同。
  • 提供两个参数:第一个参数是键,第二个参数是环境变量名称。

例如:

//假设配置文件中设置了值为192.168.3.244
fmt.Println(viper.GetString("mysql.ip")) // 192.168.3.244
// 绑定环境变量,假设我们设置mysql.ip=127.0.0.1、MYSQL.IP=localhost
viper.BindEnv("mysql.ip")//127.0.0.1是调用os.LookupEnv获取的值
fmt.Println(viper.GetString("mysql.ip"))
AI 代码解读

BindFlagValue

func BindFlagValue(key string, flag FlagValue) error
AI 代码解读

将键同flag绑定

BindFlagValues

func BindFlagValues(flags FlagValueSet) error
AI 代码解读

绑定flag集合

BindPFlag

func BindPFlag(key string, flag *pflag.Flag) error
AI 代码解读

绑定pflag

BindPFlags

func BindPFlags(flags *pflag.FlagSet) error
AI 代码解读

绑定pflag集合

ConfigFileUsed

func ConfigFileUsed() string
AI 代码解读

返回正在使用的配置文件,例如:

D:\workspace\myOpenSource\go-example\viper\ini\config.ini
AI 代码解读

Debug

func Debug()
AI 代码解读

打印调试信息,会根据viper查找顺序打印配置信息。例如:

Aliases:
map[string]string{}
Override:
map[string]interface {}{}
PFlags:
map[string]viper.FlagValue{}
Env:
map[string][]string{}
Key/Value Store:
map[string]interface {}{}
Config:
map[string]interface {}{"mysql.database":"awesome", "mysql.ip":"127.0.0.1", "mysql.password":"123456", "mysql.port":"3306", "mysql.user":"dj", "redis.ip":"127.0.0.1", "redis.port":"7381"}
Defaults:
map[string]interface {}{}
AI 代码解读

Get

获取指定key值信息

func Get(key string) interface{}
func GetBool(key string) bool
func GetDuration(key string) time.Duration
func GetFloat64(key string) float64
func GetInt(key string) int
func GetInt32(key string) int32
func GetInt64(key string) int64
func GetIntSlice(key string) []int
func GetSizeInBytes(key string) uint
func GetString(key string) string
func GetStringMap(key string) map[string]interface{}
func GetStringMapString(key string) map[string]string
func GetStringMapStringSlice(key string) map[string][]string
func GetStringSlice(key string) []string
func GetTime(key string) time.Time
func GetUint(key string) uint
func GetUint32(key string) uint32
func GetUint64(key string) uint64
AI 代码解读

InConfig

func InConfig(key string) bool
AI 代码解读

判断这个键是否存在。

fmt.Println(viper.InConfig("mysql"))    //false
fmt.Println(viper.InConfig("ip"))       //false
fmt.Println(viper.InConfig("mysql.ip")) //true
AI 代码解读

InSet

func IsSet(key string) bool
AI 代码解读

判断键是否是个集合

MergeConfig

func MergeConfig(in io.Reader) error
func MergeConfigMap(cfg map[string]interface{}) error
func MergeInConfig() error
AI 代码解读

会将新的配置和原有的配置合并

OnConfigChang

func OnConfigChange(run func(in fsnotify.Event))
AI 代码解读

设置配置改变时的回调函数

ReadConfig

func ReadConfig(in io.Reader) error
AI 代码解读

从IO接口中读取配置

ReadInConfig

func ReadInConfig() error
AI 代码解读

加载配置文件

ReadRemoteConfig

func ReadRemoteConfig() error
AI 代码解读

加载远程配置文件

RegisterAlias

func RegisterAlias(alias string, key string)
AI 代码解读

为key设置一个别名。

Reset

func Reset()
AI 代码解读

将存储的所有信息清空,仅用于测试

SafeWriteConfig

func SafeWriteConfig() error
AI 代码解读

仅当文件不存在时,将当前配置写入文件

SafeWriteConfigAs

func SafeWriteConfigAs(filename string) error
AI 代码解读

将当前配置写入给定文件名(如果它不存在)。

Set

func Set(key string, value interface{})
AI 代码解读

覆盖内存中的键的值,对键不区分大小写。将用于代替通过flag、配置文件、环境变量、默认值或键/值存储获得的值。

SetConfigFile

func SetConfigFile(in string)
AI 代码解读

明确定义配置文件的路径、名称和扩展名。Viper 将使用它而不检查任何配置路径。

SetConfigName

func SetConfigName(in string)
AI 代码解读

设置配置文件的名称。不包括扩展名。

SetConfigPermissions

func SetConfigPermissions(perm os.FileMode)
AI 代码解读

设置给定配置文件的权限

SetConfigType

func SetConfigType(in string)
AI 代码解读

设置配置文件的类型,如json、ini、toml

SetDefault

func SetDefault(key string, value interface{})
AI 代码解读

为指定的键设置默认值,对key不区分大小写,仅当用户没有通过flag、配置文件以及环境变量设置值时才使用默认值。

SetEnvKeyReplacer

func SetEnvKeyReplacer(r *strings.Replacer)
AI 代码解读

允许你使用一个strings.Replacer对象来将配置名重写为Env名。如果你想在Get()中使用包含-的配置名 ,但希望对应的环境变量名包含_分隔符,就可以使用该方法。使用它的一个例子可以在项目中viper_test.go文件里找到。

func TestSetEnvKeyReplacer(t *testing.T) {
    Reset()

    AutomaticEnv()

    testutil.Setenv(t, "REFRESH_INTERVAL", "30s")

    replacer := strings.NewReplacer("-", "_")
    SetEnvKeyReplacer(replacer)

    assert.Equal(t, "30s", Get("refresh-interval"))
}
AI 代码解读

SetEnvPrefix

func SetEnvPrefix(in string)
AI 代码解读

定义环境变量使用的前缀。

SetEnvPrefix("spf") // 将会自动转为大写
BindEnv("id")
 
os.Setenv("SPF_ID", "13") // 通常通过系统环境变量来设置
 
id := Get("id") // 13
AI 代码解读

SetFs

func SetFs(fs afero.Fs)
AI 代码解读

设置文件系统。github.com/spf13/afero

SetTypeByDefaultValue

func SetTypeByDefaultValue(enable bool)
AI 代码解读

使用 Get 函数时基于键的默认值而不是基于正常获取逻辑返回的值启用或禁用键值类型的推断。
例如,如果一个键的默认值为 []string{},并且通过环境变量将相同的键设置为“ab c”,则调用 Get 函数将返回该键的字符串切片,如果该键的类型由默认值推断,Get 函数将返回:

[]string {"a", "b", "c"}
AI 代码解读

否则返回

"a b c"
AI 代码解读

Unmarshal

func Unmarshal(rawVal interface{}, opts ...DecoderConfigOption) error
AI 代码解读

将配置解组到 Struct。确保正确设置结构字段上的标签。

UnmarshalExact

func UnmarshalExact(rawVal interface{}, opts ...DecoderConfigOption) error
AI 代码解读

UnmarshalExact 将配置解组为 Struct,如果目标结构中不存在字段,则会出错。

UnmarshalKey

func UnmarshalKey(key string, rawVal interface{}, opts ...DecoderConfigOption) error
AI 代码解读

UnmarshalKey 采用单个键并将其解组为 Struct。

WatchConfig

func WatchConfig()
AI 代码解读

监控配置

WatchRemoteConfig

func WatchRemoteConfig() error
AI 代码解读

WriteConfig

func WriteConfig() error
AI 代码解读

WriteConfigAs

func WriteConfigAs(filename string) error
AI 代码解读

WriteConfigAs 将当前配置写入给定的文件名。

目录
打赏
0
0
0
0
11
分享
相关文章
阿里云特惠云服务器99元与199元配置与性能和适用场景解析:高性价比之选
2025年,阿里云长效特惠活动继续推出两款极具吸引力的特惠云服务器套餐:99元1年的经济型e实例2核2G云服务器和199元1年的通用算力型u1实例2核4G云服务器。这两款云服务器不仅价格亲民,而且性能稳定可靠,为入门级用户和普通企业级用户提供了理想的选择。本文将对这两款云服务器进行深度剖析,包括配置介绍、实例规格、使用场景、性能表现以及购买策略等方面,帮助用户更好地了解这两款云服务器,以供参考和选择。
【环境】Rocky8使用gvm配置Go多版本管理的微服务开发环境(go-zero)
通过本文的介绍,我们详细讲解了如何在Rocky8上使用gvm来管理多个Go版本,并配置go-zero框架的开发环境。通过gvm的灵活管理,开发者可以轻松切换不同的Go版本,以适应不同项目的需求。同时,go-zero框架的使用进一步提升了微服务开发的效率和质量。希望本文能帮助开发者构建高效的Go语言开发环境,提高项目开发的灵活性和稳定性。
112 63
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
83 29
🚀 力扣热题 394:字符串解码(详细解析)(Go语言版)
文章提供了两种解法:栈结构和递归解法。栈解法通过维护数字栈与字符串栈,依次处理 `[` 和 `]`,构造解码结果;递归解法则利用函数调用逐层解析嵌套结构。两者时间复杂度均为 O(n),空间复杂度也为 O(n)。栈解法直观易懂,适合初学者;递归解法优雅简洁,适合处理深度嵌套规则。掌握这两种方法,可灵活应对类似问题,提升解题能力。
38 11
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
DHCP与DNS的配置
通过这些步骤,您可以在Linux环境下成功配置和验证DHCP和DNS服务。希望这些内容对您的学习和工作有所帮助。
125 27
详细介绍SpringBoot启动流程及配置类解析原理
通过对 Spring Boot 启动流程及配置类解析原理的深入分析,我们可以看到 Spring Boot 在启动时的灵活性和可扩展性。理解这些机制不仅有助于开发者更好地使用 Spring Boot 进行应用开发,还能够在面对问题时,迅速定位和解决问题。希望本文能为您在 Spring Boot 开发过程中提供有效的指导和帮助。
99 12
基于 Go 语言的公司内网管理软件哈希表算法深度解析与研究
在数字化办公中,公司内网管理软件通过哈希表算法保障信息安全与高效管理。哈希表基于键值对存储和查找,如用户登录验证、设备信息管理和文件权限控制等场景,Go语言实现的哈希表能快速验证用户信息,提升管理效率,确保网络稳定运行。
30 0
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

热门文章

最新文章

推荐镜像

更多