Skip to main content

服务配置

概述

本文介绍如何使用 go-zero 框架进行 gRPC Client 的开发。

配置

type RpcClientConf struct {
Etcd discov.EtcdConf `json:",optional,inherit"`
Endpoints []string `json:",optional"`
Target string `json:",optional"`
App string `json:",optional"`
Token string `json:",optional"`
NonBlock bool `json:",optional"`
Timeout int64 `json:",default=2000"`
KeepaliveTime time.Duration `json:",default=20s"`
Middlewares ClientMiddlewaresConf
}

type EtcdConf struct {
Hosts []string
Key string
ID int64 `json:",optional"`
User string `json:",optional"`
Pass string `json:",optional"`
CertFile string `json:",optional"`
CertKeyFile string `json:",optional=CertFile"`
CACertFile string `json:",optional=CertFile"`
InsecureSkipVerify bool `json:",optional"`
}

type ServerMiddlewaresConf struct {
Trace bool `json:",default=true"`
Recover bool `json:",default=true"`
Stat bool `json:",default=true"`
Prometheus bool `json:",default=true"`
Breaker bool `json:",default=true"`
}

RpcClientConf

名称类型含义默认值是否必选
EtcdEtcdConf服务发现配置,当需要使用 etcd 做服务发现时配置
Endpointsstring 类型数组RPC Server 地址列表,用于直连,当需要直连 rpc server 集群时配置
Targetstring域名解析地址,名称规则请参考 https://github.com/grpc/grpc/blob/master/doc/naming.md
Appstringrpc 认证的 app 名称,仅当 rpc server 开启认证时配置
Tokenstringrpc 认证的 token,仅当 rpc server 开启认证时配置
NonBlockbool是否阻塞模式,当值为 true 时,不会阻塞 rpc 链接false
Timeoutint64超时时间2000ms
KeepaliveTimeTime.Duration保活时间20s
MiddlewaresClientMiddlewaresConf是否启用中间件

EtcdConf

EtcdConf 为服务发现配置,当需要使用 etcd 做服务发现时配置。

名称类型含义默认值是否必选
Hostsstring 类型数组etcd 集群地址
Keystring服务发现 key
IDint64etcd 租户 id
Userstringetcd 用户名
Passstringetcd 密码
CertFilestringetcd 证书文件CertFile
CertKeyFilestringetcd 证书私钥文件
CACertFilestringetcd 证书根文件CertFile
InsecureSkipVerifybooletcd 是否跳过证书验证

ServerMiddlewaresConf

ServerMiddlewaresConf 为中间件配置,当需要控制中间件时配置。

名称类型含义默认值是否必选
Tracebool是否开启链路追踪true
Recoverbool是否开启异常恢复true
Statbool是否开启统计true
Prometheusbool是否开启 prometheustrue
Breakerbool是否开启熔断true