golang使用Viper的demo

栏目: Go · 发布时间: 6年前

获取配置例子

package main

import (
    "flag"
    "fmt"
    "runtime"

    "github.com/spf13/viper"
)
type Config struct {
    Base BaseConf `mapstructure:"base"`
}

type BaseConf struct {
    pidfile   string `mapstructure:"pidfile"`
}

var (
    Conf     *Config
    confPath string
)

func init() {
    flag.StringVar(&confPath, "d", "./", " set logic config file path")
}

func InitConfig() (err error) {
    Conf = NewConfig()
    viper.SetConfigName("logic") // 配置文件的名字
    viper.SetConfigType("toml") // 配置文件的类型
    viper.AddConfigPath(confPath) // 配置文件的路径

    if err := viper.ReadInConfig(); err != nil {
        return err
    }

    if err := viper.Unmarshal(&Conf); err != nil {
        panic(fmt.Errorf("unable to decode into struct:  %s \n", err))
    }

    return nil
}

func NewConfig() *Config {
    return &Config{
        Base: BaseConf{
            Pidfile:   "/tmp/comet.pid",
        },
    }
}

# toml 文件内容为
[base]
pidfile = "/tmp/logic.pid"

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

亿级流量网站架构核心技术

亿级流量网站架构核心技术

张开涛 / 电子工业出版社 / 2017-4 / 99

《亿级流量网站架构核心技术》一书总结并梳理了亿级流量网站高可用和高并发原则,通过实例详细介绍了如何落地这些原则。本书分为四部分:概述、高可用原则、高并发原则、案例实战。从负载均衡、限流、降级、隔离、超时与重试、回滚机制、压测与预案、缓存、池化、异步化、扩容、队列等多方面详细介绍了亿级流量网站的架构核心技术,让读者看后能快速运用到实践项目中。 不管是软件开发人员,还是运维人员,通过阅读《亿级流......一起来看看 《亿级流量网站架构核心技术》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具