Nacos
安装
- nacos-sdk-go v1 版本
go get github.com/kitex-contrib/registry-nacos
- nacos-sdk-go v2 版本
go get github.com/kitex-contrib/registry-nacos/v2
服务注册
创建 Registry
提供了两个创建 Registry 的函数
NewDefaultNacosRegistry
NewDefaultNacosRegistry
使用 nacos 创建一个新的服务注册中心,从环境变量中读取信息用于创建 Nacos Client。可自定义服务注册中心配置,配置详情见 Option。
环境变量名 | 环境变量默认值 | 描述 |
---|---|---|
serverAddr | 127.0.0.1 | nacos 服务器地址 |
serverPort | 8848 | nacos 服务器端口 |
namespace | nacos 中的 namespace Id |
函数签名:
func NewDefaultNacosRegistry(opts ...Option) (registry.Registry, error
示例代码:
import (
// ...
"github.com/kitex-contrib/registry-nacos/registry"
"github.com/nacos-group/nacos-sdk-go/clients"
"github.com/nacos-group/nacos-sdk-go/clients/naming_client"
"github.com/nacos-group/nacos-sdk-go/common/constant"
"github.com/nacos-group/nacos-sdk-go/vo"
"github.com/cloudwego/kitex/pkg/rpcinfo"
// ...
)
func main() {
// ...
r, err := registry.NewDefaultNacosRegistry()
if err != nil {
panic(err)
}
svr := echo.NewServer(
new(EchoImpl),
server.WithServerBasicInfo(&rpcinfo.EndpointBasicInfo{ServiceName: "echo"}),
server.WithRegistry(r),
)
if err := svr.Run(); err != nil {
log.Println("server stopped with error:", err)
} else {
log.Println("server stopped")
}
// ...
}
NewNacosRegistry
NewNacosRegistry
使用 nacos 创建服务注册中心,需要传入自行配置的客户端。可自定义服务注册中心配置,配置详情见 Option。
函数签名:
func NewNacosRegistry(cli naming_client.INamingClient, opts ...Option) registry.Registry
示例代码:
import (
// ...
"github.com/kitex-contrib/registry-nacos/registry"
"github.com/nacos-group/nacos-sdk-go/clients"
"github.com/nacos-group/nacos-sdk-go/clients/naming_client"
"github.com/nacos-group/nacos-sdk-go/common/constant"
"github.com/nacos-group/nacos-sdk-go/vo"
// ...
)
func main() {
// ...
sc := []constant.ServerConfig{
*constant.NewServerConfig("127.0.0.1", 8848),
}
cc := constant.ClientConfig{
NamespaceId: "public",
TimeoutMs: 5000,
NotLoadCacheAtStart: true,
LogDir: "/tmp/nacos/log",
CacheDir: "/tmp/nacos/cache",
LogLevel: "info",
Username: "your-name",
Password: "your-password",
}
cli, err := clients.NewNamingClient(
vo.NacosClientParam{
ClientConfig: &cc,
ServerConfigs: sc,
},
)
if err != nil {
panic(err)
}
svr := echo.NewServer(new(EchoImpl),
server.WithServerBasicInfo(&rpcinfo.EndpointBasicInfo{ServiceName: "echo"}),
server.WithRegistry(registry.NewNacosRegistry(cli)),
)
if err := svr.Run(); err != nil {
log.Println("server stopped with error:", err)
} else {
log.Println("server stopped")
}
// ...
}
Option
Nacos 拓展在服务注册部分中提供了 option 配置。
WithCluster
Nacos 扩展提供了 WithCluster
用于帮助用户配置自定义的集群。默认为 “DEFAULT”。
函数签名:
func WithCluster(cluster string) Option
WithGroup
Nacos 扩展提供了 WithGroup
用于帮助用户配置自定义的集群。默认为 “DEFAULT_GROUP” 。
函数签名:
func WithGroup(group string) Option
服务发现
创建 Resolver
提供了两个创建 Resolver 的函数
NewDefaultNacosResolver
NewDefaultNacosResolver
使用 nacos 创建一个新的服务发现中心,从环境变量中读取信息用于创建 Nacos Client。可自定义服务注册中心配置,配置详情见 Option。
环境变量名 | 环境变量默认值 | 描述 |
---|---|---|
serverAddr | 127.0.0.1 | nacos 服务器地址 |
serverPort | 8848 | nacos 服务器端口 |
namespace | nacos 中的 namespace Id |
函数签名:
func NewDefaultNacosResolver(opts ...Option) (discovery.Resolver, error)
示例代码:
import (
// ...
"github.com/kitex-contrib/registry-nacos/resolver"
"github.com/nacos-group/nacos-sdk-go/clients"
"github.com/nacos-group/nacos-sdk-go/clients/naming_client"
"github.com/nacos-group/nacos-sdk-go/common/constant"
"github.com/nacos-group/nacos-sdk-go/vo"
// ...
)
func main() {
// ...
r, err := resolver.NewDefaultNacosResolver()
if err != nil {
panic(err)
}
client, err := echo.NewClient("echo", client.WithResolver(r))
if err != nil {
log.Fatal(err)
}
// ...
}
NewNacosResolver
NewNacosResolver
使用 nacos 创建服务发现中心,需要传入自行配置的客户端。可自定义服务注册中心配置,配置详情见 Option。
函数签名:
func NewNacosResolver(cli naming_client.INamingClient, opts ...Option) discovery.Resolver
示例代码:
import (
// ...
"github.com/kitex-contrib/registry-nacos/resolver"
"github.com/nacos-group/nacos-sdk-go/clients"
"github.com/nacos-group/nacos-sdk-go/clients/naming_client"
"github.com/nacos-group/nacos-sdk-go/common/constant"
"github.com/nacos-group/nacos-sdk-go/vo"
// ...
)
func main() {
// ...
sc := []constant.ServerConfig{
*constant.NewServerConfig("127.0.0.1", 8848),
}
cc := constant.ClientConfig{
NamespaceId: "public",
TimeoutMs: 5000,
NotLoadCacheAtStart: true,
LogDir: "/tmp/nacos/log",
CacheDir: "/tmp/nacos/cache",
LogLevel: "info",
Username: "your-name",
Password: "your-password",
}
cli, err := clients.NewNamingClient(
vo.NacosClientParam{
ClientConfig: &cc,
ServerConfigs: sc,
},
)
if err != nil {
panic(err)
}
client, err := echo.NewClient("echo", client.WithResolver(resolver.NewNacosResolver(cli))
if err != nil {
log.Fatal(err)
}
// ...
}
Option
Nacos 拓展在服务发现部分中提供了 option 配置。
WithCluster
Nacos 扩展提供了 WithCluster
用于帮助用户配置自定义的集群。默认为 “DEFAULT”。
函数签名:
func WithCluster(cluster string) Option
WithGroup
Nacos 扩展提供了 WithGroup
用于帮助用户配置自定义的集群。默认为 “DEFAULT_GROUP” 。
函数签名:
func WithGroup(group string) Option
使用示例
服务端
package main
import (
"context"
"log"
"net"
"github.com/cloudwego/kitex/pkg/rpcinfo"
"github.com/cloudwego/kitex/server"
"github.com/kitex-contrib/registry-nacos/example/hello/kitex_gen/api"
"github.com/kitex-contrib/registry-nacos/example/hello/kitex_gen/api/hello"
"github.com/kitex-contrib/registry-nacos/registry"
)
type HelloImpl struct{}
func (h *HelloImpl) Echo(_ context.Context, req *api.Request) (resp *api.Response, err error) {
resp = &api.Response{
Message: req.Message,
}
return
}
func main() {
r, err := registry.NewDefaultNacosRegistry()
if err != nil {
panic(err)
}
svr := hello.NewServer(
new(HelloImpl),
server.WithRegistry(r),
server.WithServerBasicInfo(&rpcinfo.EndpointBasicInfo{ServiceName: "Hello"}),
server.WithServiceAddr(&net.TCPAddr{IP: net.IPv4(127, 0, 0, 1), Port: 8080}),
)
if err := svr.Run(); err != nil {
log.Println("server stopped with error:", err)
} else {
log.Println("server stopped")
}
}
客户端
package main
import (
"context"
"log"
"time"
"github.com/cloudwego/kitex/client"
"github.com/kitex-contrib/registry-nacos/example/hello/kitex_gen/api"
"github.com/kitex-contrib/registry-nacos/example/hello/kitex_gen/api/hello"
"github.com/kitex-contrib/registry-nacos/resolver"
)
func main() {
r, err := resolver.NewDefaultNacosResolver()
if err != nil {
panic(err)
}
newClient := hello.MustNewClient(
"Hello",
client.WithResolver(r),
client.WithRPCTimeout(time.Second*3),
)
for {
resp, err := newClient.Echo(context.Background(), &api.Request{Message: "Hello"})
if err != nil {
log.Fatal(err)
}
log.Println(resp)
time.Sleep(time.Second)
}
}
注意
- nacos/v2 版本中 kitex 目前不支持多次在同分组下创建多端口示例
- nacos/v2 的服务注册与发现和先前的版本兼容
- nacos-sdk-go v2 版本中 constant.ClientConfig 中 CustomLogger 类型被移除
- nacos/v2 只支持 nacos 2.X 版本
配置
可自定义 Nacos 客户端以及服务端的配置,参考 nacos-sdk-go 配置。
完整示例
完整用法示例详见 example。