go-zero配置DB的redis缓存

16 篇文章 5 订阅

配置定义:

# cat internal/config/config.go 
package config

import (
	"github.com/zeromicro/go-zero/rest"
	"github.com/zeromicro/go-zero/core/stores/cache"
)

type Config struct {
	rest.RestConf
	CacheRedis cache.CacheConf
}

对应的配置文件:

# cat etc/abc-api.yaml 
Name: abc-api
Host: 0.0.0.0
Port: 8888

CacheRedis: 
    - Host: 127.0.0.2
      port: 6379
      type: node

加载配置:

func main() {
	var c config.Config
	conf.MustLoad(*configFile, &c)
	fmt.Printf("Host: %s\n", c.CacheRedis[0].Host)
}

执行效果:

# ./abc
Host: 127.0.0.2
Type: node

配置源码

// CacheConf is an alias of ClusterConf.
type CacheConf = ClusterConf

// A ClusterConf is the config of a redis cluster that used as cache.
type ClusterConf []NodeConf

// A NodeConf is the config of a redis node that used as cache.
type NodeConf struct {
	redis.RedisConf
	Weight int `json:",default=100"`
}

// A RedisConf is a redis config.
type RedisConf struct {
	Host     string
	Type     string `json:",default=node,options=node|cluster"`
	Pass     string `json:",optional"`
	Tls      bool   `json:",optional"`
	NonBlock bool   `json:",default=true"`
	// PingTimeout is the timeout for ping redis.
	PingTimeout time.Duration `json:",default=1s"`
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值