自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Golang 語言怎么使用 go-micro 和 gin 開發(fā)微服務(wù)?

開發(fā) 前端
Go Micro 是一個分布式系統(tǒng)開發(fā)框架。Go Micro 提供了分布式系統(tǒng)開發(fā)的核心需求,包括 RPC 和事件驅(qū)動的通信。

[[413123]]

01  介紹

Go Micro 是一個分布式系統(tǒng)開發(fā)框架。Go Micro 提供了分布式系統(tǒng)開發(fā)的核心需求,包括 RPC 和事件驅(qū)動的通信。Gin 是一個用 Golang 編寫的 web 框架。本文首先介紹怎么使用 go-micro 和 go-grpc 構(gòu)建微服務(wù),然后再介紹怎么集成 gin 和 go-micro。我們使用的 go-micro 版本是 v1.18.0,golang 版本是 v1.13,gin 版本是 v1.7.2。

02  使用 go-micro 和 go-grpc 構(gòu)建微服務(wù)

在我們開始使用 go-micro 之前,我們還需要提前做一些準(zhǔn)備工作。安裝 protoc、protoc-gen-go 和 protoc-gen-micro,關(guān)于如何安裝,讀者朋友們可以參閱官方文檔,我們在之前的文章中也介紹過,限于篇幅,本文不再贅述。

其實,我們可以使用 Go Micro 工具集以命令的方式快速生成模板文件,但是因為本文我們不準(zhǔn)備介紹工具集的相關(guān)內(nèi)容,所以我們使用手動創(chuàng)建文件的方式。

下面我們正式開始介紹如何構(gòu)建服務(wù),包括服務(wù)端服務(wù)和客戶端服務(wù)。

服務(wù)端

服務(wù)端代碼目錄:

  1. ├── go.mod 
  2. ├── go.sum 
  3. ├── handler 
  4. │   └── user 
  5. │       └── user.go 
  6. ├── main.go 
  7. └── proto 
  8.     └── user 
  9.         ├── user.pb.go 
  10.         ├── user.pb.micro.go 
  11.         └── user.proto 

構(gòu)建服務(wù)端服務(wù),分為以下幾個步驟:

  1. 編寫 protobuf 文件

    第一步是編寫 protobuf 文件,一般會將不同 package 的 protobuf 文件存放在單獨的文件目錄中。

    文件路徑: proto/user/user.proto

    1. syntax = "proto3"
    2.  
    3. package user; 
    4.  
    5. service User { 
    6.   rpc Login(LoginRequest) returns (LoginResponse) {} 
    7.  
    8. message LoginRequest { 
    9.   string email = 1
    10.   string password = 2
    11.  
    12. message LoginResponse { 
    13.   string username = 1

    閱讀上面這段代碼,我們在定義的 user.proto 文件中,創(chuàng)建了一個 rpc 服務(wù)。

  2. 生成文件

    第二步是生成文件,使用命令:

    1. protoc --proto_path=. --micro_out=. --go_out=. user.proto 

    執(zhí)行以上命令,將會自動生成兩個文件,分別是 user.pb.go 和  user.micro.go 。

    閱讀 user.micro.go 文件,可以發(fā)現(xiàn)在該文件中已經(jīng)自動生成了客戶端和服務(wù)端的代碼。

  3. 編寫 handler

    第三步是編寫服務(wù)端的 handler 代碼。

    文件路徑: handler/user/user.go

    1. type User struct{} 
    2.  
    3. func (u *User) Login(ctx context.Context, req *protoUser.LoginRequest, rsp *protoUser.LoginResponse) error { 
    4.   if req.Email != "gopher@88.com" || req.Password != "123456" { 
    5.     rsp.Username = "Sorry " + req.Email 
    6.     return nil 
    7.   } 
    8.   rsp.Username = "Welcome " + req.Email 
    9.   return nil 
  4. 定義服務(wù)端服務(wù)

    第四步是定義服務(wù)端服務(wù),需要注意的是,這里使用的是 grpc。在 main.go 文件中編寫如下代碼:

    文件路徑: main.go

    1. func main() { 
    2.   // 創(chuàng)建服務(wù) 
    3.   service := grpc.NewService( 
    4.     micro.Name("go.micro.srv.demo"), 
    5.     micro.Version("v0.0.0"), 
    6.     micro.RegisterTTL(time.Second * 10), 
    7.     micro.RegisterInterval(time.Second * 5), 
    8.   ) 
    9.   // 注冊處理器 
    10.   err := protoUser.RegisterUserHandler(service.Server(), new(user.User)) 
    11.   if err !=nil { 
    12.     log.Fatal(err) 
    13.   } 
    14.   // 運行服務(wù) 
    15.   if err = service.Run(); err != nil { 
    16.     log.Fatal(err) 
    17.   } 

完成以上 4 個步驟,我們就已經(jīng)實現(xiàn)了服務(wù)端 rpc 服務(wù),接下來,我們開始編寫客戶端代碼。

客戶端

客戶端代碼目錄:

  1. ├── go.mod 
  2. ├── go.sum 
  3. ├── main.go 
  4. ├── proto 
  5. │   └── user 
  6. │       ├── user.pb.go 
  7. │       ├── user.pb.micro.go 
  8. │       └── user.proto 
  9. └── router 
  10.     ├── router.go 
  11.     └── v1 
  12.         └── user.go 

構(gòu)建客戶端服務(wù),分為以下幾個步驟:

  1. 拷貝 proto 文件和生成文件

    第一步是拷貝服務(wù)端的 proto 文件和生成文件,目的是為了保證服務(wù)端和客戶端的類型一致性。

  2. 定義客戶端服務(wù)

    第二步是定義客戶端:

    文件路徑: router/v1/user.go

    1. func NewUserClient() protoUser.UserService { 
    2.   // 創(chuàng)建服務(wù) 
    3.   service := grpc.NewService() 
    4.  
    5.   // 創(chuàng)建客戶端 
    6.   userClient := protoUser.NewUserService("go.micro.srv.demo", service.Client()) 
    7.  
    8.   return userClient 
  3. rpc 調(diào)用遠(yuǎn)程服務(wù)的方法

    第三步是 rpc 調(diào)用遠(yuǎn)程服務(wù)的方法:

    文件路徑: router/v1/user.go

    1. client := NewUserClient() 
    2.  
    3. // rpc 調(diào)用遠(yuǎn)程服務(wù)的方法 
    4. resp, err := client.Login(context.TODO(), &protoUser.LoginRequest{Email: param.Email, Password: param.Password}) 
    5. if err != nil { 
    6.   fmt.Println(err) 

完成以上 3 步,我們就已經(jīng)基本編寫完客戶端的代碼。

03  gin 和 go-micro 集成

接下來,我們介紹如何集成 gin 和 go-micro,該部分代碼也是在客戶端中,共需要兩個步驟。

  1. 創(chuàng)建路由

    文件路徑: router/router.go

    1. func NewRouter() *gin.Engine { 
    2.   r := gin.New() 
    3.    
    4.   userControllerV1 := new(v1.User) 
    5.  
    6.   // 路由分組 
    7.   v1 := r.Group("/v1"
    8.   { 
    9.     v1.Use(gin.Logger(), gin.Recovery()) 
    10.     userV1 := v1.Group("/user"
    11.     { 
    12.       userV1.POST("/login", userControllerV1.Login) 
    13.     } 
    14.   } 
    15.  
    16.   return r 
  2. 啟動(監(jiān)聽)服務(wù)

    文件路徑: main.go

    1. func main() { 
    2.   r := router.NewRouter() 
    3.   server := &http.Server{ 
    4.     Addr:           ":8080"
    5.     Handler:        r, 
    6.     ReadTimeout:    time.Second * 10
    7.     WriteTimeout:   time.Second * 10
    8.     MaxHeaderBytes: 1 << 20
    9.   } 
    10.   if err := server.ListenAndServe(); err != nil { 
    11.     log.Fatal(err) 
    12.   } 

至此,我們已經(jīng)完成了集成 gin 和 go-micro,啟動服務(wù)端服務(wù)和客戶端服務(wù)后,我們就可以使用以下命令進行 cURL 測試:

  1. curl --location --request POST 'http://127.0.0.1:8080/v1/user/login' \ 
  2. --header 'Content-Type: application/json' \ 
  3. --data-raw '{ 
  4.     "email""gopher@88.com"
  5.     "password""123456" 
  6. }' 

04  總結(jié)

本文我們主要介紹怎么使用 go-micro 和 go-grpc 構(gòu)建微服務(wù),和怎么集成 gin 和 go-micro,并沒有介紹 gin 和 go-micro 的使用方法,如果讀者朋友們還不了解 gin 和 go-micro,建議先閱讀 gin 和 go-micro 官方文檔,也可以參考公眾號之前推送的關(guān)于 gin 的文章。

責(zé)任編輯:張燕妮 來源: Golang語言開發(fā)棧
相關(guān)推薦

2023-01-29 23:51:07

微服務(wù)框架Go

2024-12-23 00:22:55

2025-01-13 00:00:07

Go語言微服務(wù)

2018-12-17 16:44:49

Golang微服務(wù)

2018-12-17 16:39:20

Golang微服務(wù)

2018-12-17 16:48:05

Golang微服務(wù)

2021-09-13 05:02:49

GogRPC語言

2024-12-30 00:38:23

Go語言微服務(wù)

2022-02-27 23:10:26

微服務(wù)工具包Golang

2022-01-16 23:10:40

語言服務(wù)注冊

2025-02-04 13:53:18

NixGogRPC

2025-01-20 00:10:00

Go語言Kratos

2024-11-04 08:16:08

Go語言Web 框架

2022-12-31 14:51:48

微服務(wù)Golang

2023-07-16 23:43:05

Go語言模式

2022-06-07 08:19:30

gRPCBallerina微服務(wù)

2023-12-13 07:19:01

微服務(wù)架構(gòu)Golang

2021-06-07 23:19:44

Golang語言 Defer

2022-06-05 23:30:25

AES加密算法

2022-01-26 09:36:53

Consul語言微服務(wù)
點贊
收藏

51CTO技術(shù)棧公眾號