成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Go 語言微服務框架 Kratos 服務注冊與發現

開發 前端
Go 語言微服務框架 Kratos 服務注冊與發現,支持多種注冊中心,本文我們以 Consul 為例,介紹 Kratos 項目怎么實現服務注冊與發現。

1.介紹

Go 語言微服務框架 Kratos 服務注冊與發現,支持多種注冊中心,本文我們以 Consul 為例,介紹 Kratos 項目怎么實現服務注冊與發現。

以 blog 項目作為 RPC 服務端,我們再創建一個 blog-client 項目作為 RPC 客戶端。

2.服務注冊

我們通過改造 blog 項目的代碼,將 blog 服務作為 RPC 服務端,注冊到 Consul 中。

創建 Consul 注冊中心

在 blog/internal 目錄中,創建 registry 目錄,并創建 consul.go 和 registry.go 文件。

編寫 blog/internal/registry/consul.go 文件。

func NewConsulRegistry(c *conf.Registry) *consul.Registry {
 client, err := api.NewClient(&api.Config{
  Address: c.Consul.Addr,
  Scheme:  c.Consul.Schema,
 })
 if err != nil {
  panic(err)
 }
 return consul.New(client)
}

編寫 blog/internal/registry/registry.go 文件。

var ProviderSet = wire.NewSet(NewConsulRegistry)

編寫 blog/cmd/blog/wire.go 文件。

func wireApp(*conf.Server, *conf.Data, *conf.Registry, log.Logger) (*kratos.App, func(), error) {
 panic(wire.Build(server.ProviderSet, data.ProviderSet, biz.ProviderSet, service.ProviderSet, registry.ProviderSet, newApp))
}

wire 生成文件

cd /root/go/src/blog/cmd/blog
wire

編寫 blog/cmd/blog/main.go 文件。

func newApp(conf *conf.Server, logger log.Logger, gs *grpc.Server, hs *http.Server, registry *consul.Registry) *kratos.App {
 return kratos.New(
  kratos.ID(id),
  kratos.Name(conf.Name),
  kratos.Version(conf.Version),
  kratos.Metadata(map[string]string{}),
  kratos.Logger(logger),
  kratos.Server(
   gs,
   hs,
  ),
  kratos.Registrar(registry),
 )
}

運行項目

cd /root/go/src/blog/cmd/blog
kratos run

訪問 consul UI

在瀏覽器中訪問 http://IP:8500/ui/dc1/services,檢查 blog 服務的注冊狀態。

3.服務發現

使用 kratos 創建一個客戶端項目 blog-client。

創建 Consul 注冊中心

在 blog-client/internal 目錄中,創建 registry 目錄,并創建 consul.go 和 registry.go 文件。

編寫 blog-client/internal/registry/consul.go 文件。

func NewConsulRegistry(c *conf.Registry) *consul.Registry {
 client, err := api.NewClient(&api.Config{
  Address: c.Consul.Addr,
  Scheme:  c.Consul.Schema,
 })
 if err != nil {
  panic(err)
 }
 return consul.New(client)
}

編寫 blog-client/internal/registry/registry.go 文件。

var ProviderSet = wire.NewSet(NewConsulRegistry)

創建 RPC 客戶端

在 blog-client/internal 目錄中,創建 client 目錄,并創建 blog_client.go 和 client.go 文件。

編寫 blog-client/internal/client/blog_client.go 文件。

func NewBlogClient(registry *consul.Registry, logger log.Logger) (v1.UserClient, error) {
 conn, err := grpc.DialInsecure(
  context.Background(),
  grpc.WithEndpoint("discovery:///blog"),
  grpc.WithDiscovery(registry),
  grpc.WithMiddleware(
   recovery.Recovery(),
  ),
  grpc.WithNodeFilter(
   filter.Version("1.0.0")),
 )
 if err != nil {
  log.NewHelper(logger).WithContext(context.Background()).Errorw("err", err)
  return nil, err
 }
 return v1.NewUserClient(conn), nil
}

編寫 blog-client/internal/client/client.go 文件。

var ProviderSet = wire.NewSet(NewBlogClient)

拷貝 pb 文件

拷貝 /root/go/src/blog/api/user 目錄,粘帖到 /root/go/src/blog-client/api 目錄。

創建 domain 和 usecase 層

創建 blog-client/internal/biz/user.go 文件。

type User struct {
 Id       int64 `xorm:"autoincr"`
 Name     string
 Email    string
 Password string
 Created  int64 `xorm:"created"`
 Updated  int64 `xorm:"updated"`
}

type UserUsecase struct {
 rpcClient v1.UserClient
}

func NewUserUsecase(client v1.UserClient) *UserUsecase {
 return &UserUsecase{
  rpcClient: client,
 }
}

func (u *UserUsecase) GetUser(ctx context.Context, user *User) (reply *v1.GetUserReply, err error) {
 req := &v1.GetUserRequest{
  Id: user.Id,
 }
 reply, err = u.rpcClient.GetUser(ctx, req)
 if err != nil {
  return nil, err
 }
 return
}

編寫 blog-client/internal/biz/biz.go 文件。

var ProviderSet = wire.NewSet(NewUserUsecase)

生成 server 源碼

cd /root/go/src/blog-client
kratos proto server api/user/v1/user.proto

編寫生成文件 internal/service/user.go。

func (s *UserService) GetUser(ctx context.Context, req *v1.GetUserRequest) (*v1.GetUserReply, error) {
 user := &biz.User{
  Id: req.Id,
 }
 reply, err := s.userUcase.GetUser(ctx, user)
 if err != nil {
  return nil, err
 }
 return &v1.GetUserReply{
  Name: reply.Name,
 }, nil
}

編寫 blog-client/internal/service/service.go 文件。

var ProviderSet = wire.NewSet(NewUserService)

添加 wire 提供者

編寫 blog-client/cmd/blog-client/wire.go 文件。

func wireApp(*conf.Server, *conf.Data, *conf.Registry, log.Logger) (*kratos.App, func(), error) {
 panic(wire.Build(server.ProviderSet, biz.ProviderSet, registry.ProviderSet, service.ProviderSet, client.ProviderSet, newApp))
}

wire 生成文件

cd /root/go/src/blog-client/cmd/blog-client
wire

運行項目

cd /root/go/src/blog-client/cmd/blog
kratos run

curl 請求示例

curl -H "Content-Type: application/json" -X GET http://192.168.110.209:8001/user/get/1
{"name":"frank"}

4.總結

本文我們通過示例代碼,介紹 Kratos 項目怎么實現服務注冊與發現。

需要注意的是,RPC 服務端和 RPC 客戶端的端口不能相同。

責任編輯:武曉燕 來源: Golang語言開發棧
相關推薦

2025-01-13 00:00:07

Go語言微服務

2024-12-23 00:22:55

2024-12-30 00:38:23

Go語言微服務

2022-01-16 23:10:40

語言服務注冊

2022-06-17 12:05:25

微服務注冊

2025-01-06 00:00:01

KratosGo微服務

2017-06-25 13:33:25

Spring Clou微服務架構

2022-04-26 05:36:42

服務治理模式

2021-04-20 17:20:59

SpringColud EurekaNetflix開發

2015-12-25 11:00:52

Zookeeper的Python

2023-09-07 23:25:34

微服務服務發現

2023-06-02 08:33:43

微服務架構服務注冊

2023-11-29 16:21:30

Kubernetes服務注冊

2022-08-14 07:04:44

微服務架構設計模式

2023-12-13 07:19:01

微服務架構Golang

2022-01-26 09:36:53

Consul語言微服務

2018-09-14 09:23:03

微服務服務集成

2021-01-14 09:55:21

Java微服務Go

2020-10-14 15:37:04

Goconsul接口

2021-09-06 11:34:47

架構微服務Hystrix
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人国产在线视频 | 国产丝袜一区二区三区免费视频 | 欧美日本在线观看 | 性xxxxx | 激情五月婷婷综合 | 婷婷成人在线 | 午夜寂寞影院列表 | 久久精品中文 | 久久91av| 日本中文在线视频 | 在线欧美一区二区 | 日本中出视频 | 在线播放91| 亚洲精品456 | 成人深夜小视频 | 国产第一区二区 | 日本高清不卡视频 | 亚洲精品中文字幕在线观看 | 黑人精品欧美一区二区蜜桃 | 成人二区| 欧美亚洲日本 | 日韩中文一区 | 97人人澡人人爽91综合色 | 午夜午夜精品一区二区三区文 | 九热在线 | 欧美精品一区三区 | 产真a观专区 | 精品久久久久久久久久 | 你懂的国产 | 91九色麻豆| 波霸ol一区二区 | 福利视频一区 | 久草免费在线视频 | 国产农村妇女精品一二区 | 国产一区二区三区色淫影院 | 一级片在线播放 | 97精品超碰一区二区三区 | 无码一区二区三区视频 | av网站免费 | 日韩中文字幕在线观看 | 中文字幕一区二区三区乱码在线 |