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

Golang 語言編寫 gRPC 實(shí)戰(zhàn)項(xiàng)目

開發(fā) 前端
本文我們介紹怎么使用 grpc 開發(fā)“分布式系統(tǒng)”。這里使用引號(hào)是因?yàn)榉植际较到y(tǒng)是一個(gè)大概念,本文我們先介紹使用 grpc 開發(fā)分布式系統(tǒng)中的 service。

 [[425759]]

1、介紹

在之前的幾篇文章中,我們介紹了 protobuf 和 grpc,本文我們介紹怎么使用 grpc 開發(fā)“分布式系統(tǒng)”。這里使用引號(hào)是因?yàn)榉植际较到y(tǒng)是一個(gè)大概念,本文我們先介紹使用 grpc 開發(fā)分布式系統(tǒng)中的 service。

grpc 是 google 開源的 rpc 框架,使用 grpc 可以方便開發(fā) rpc service;protobuf 是一種接口設(shè)計(jì)語言(IDL),grpc 框架使用的 IDL 是 protobuf。如果有讀者朋友還不了解 protobuf 和 grpc,建議先翻閱之前的幾篇文章。

本文是介紹使用 grpc 開發(fā)一個(gè)實(shí)戰(zhàn)項(xiàng)目 - ToDoList,目標(biāo)是幫助讀者朋友們熟悉項(xiàng)目開發(fā)流程,該實(shí)戰(zhàn)項(xiàng)目包含 server service 和 client service。server 主要負(fù)責(zé)數(shù)據(jù)操作,client 主要負(fù)責(zé)業(yè)務(wù)邏輯處理。

2、server

首先,我們創(chuàng)建 proto 目錄,并創(chuàng)建 proto 文件,編寫 protobuf,設(shè)計(jì)項(xiàng)目的 service,接著創(chuàng)建 pb 目錄,使用 protoc 編譯我們編寫好的 proto 文件,生成 pb 文件。然后,我們創(chuàng)建 service 目錄,編寫生成的 pb 文件中接口定義的方法。最后,我們創(chuàng)建 grpc 服務(wù)器。

server 目錄

  1. ├── dao 
  2. │   ├── mysql.go 
  3. │   └── toDoList.go 
  4. ├── main.go 
  5. ├── pb 
  6. │   ├── todoPb 
  7. │   │   ├── toDoList.pb.go 
  8. │   │   └── toDoList_grpc.pb.go 
  9. │   └── userPb 
  10. │       ├── user.pb.go 
  11. │       └── user_grpc.pb.go 
  12. ├── proto 
  13. │   ├── toDoList.proto 
  14. │   └── user.proto 
  15. └── service 
  16.     └── toDoList.go 

編寫 proto 文件

讀者朋友們?nèi)绻€不熟悉 protobuf,建議翻閱之前介紹 protobuf 的文章,限于篇幅,本文不再贅述。示例代碼如下:

  1. syntax = "proto3"
  2.  
  3. option go_package = "./todoPb"
  4.  
  5. service ToDoList { 
  6.   rpc CreateToDoList (ToDoListDetail) returns (CreateToDoListResult) {} 
  7.   rpc ReadToDoList (ToDoListPage) returns (ReadToDoListByPage) {} 
  8.  
  9. message ToDoListDetail { 
  10.   // @inject_tag: form:"id" xorm:"'id' not null pk autoincr" 
  11.   int64 id = 1
  12.  
  13. ... 

完整代碼,請(qǐng)查閱 github。

生成 pb 文件

接著,我們使用 protoc 編譯 proto 文件,生成 pb 文件,關(guān)于怎么使用 protoc 編譯 proto 文件,在之前的文章已經(jīng)詳細(xì)介紹,限于篇幅,本文不再贅述,編譯命令如下:

  1. protoc --go_out=./pb --go-grpc_out=./pb proto/* && protoc-go-inject-tag -XXX_skip=xorm -input=./pb/todoPb/toDoList.pb.go 

執(zhí)行以上命令,將在 pb 目錄中自動(dòng)生成 pb 文件。

編寫接口定義的方法

至此,我們開始編寫 golang 代碼,在 service 目錄中創(chuàng)建 go 文件,實(shí)現(xiàn)生成的 pb 文件中接口定義的方法。

  1. ... 
  2.  
  3. type ToDoList struct { 
  4.  pb.UnimplementedToDoListServer 
  5.  
  6. func (t *ToDoList) CreateToDoList(ctx context.Context, in *pb.ToDoListDetail) (*pb.CreateToDoListResult, error) { 
  7.  log.Printf("id: %d content:%v datetime:%d\n", in.GetId(), in.GetContent(), in.GetDatetime()) 
  8.  record, err := dao.Add(ctx, in) 
  9.  data := &pb.CreateToDoListResult{Record: record} 
  10.  return data, err 
  11.  
  12. ... 

閱讀上面這段代碼,可以發(fā)現(xiàn)我們把數(shù)據(jù)庫操作相關(guān)代碼設(shè)計(jì)在 dao 包中。service 中通過調(diào)用 dao 包的方法操作數(shù)據(jù)庫,另外,其他數(shù)據(jù)操作組件也可以在 service 中調(diào)用。

完整代碼,請(qǐng)查閱 github。

創(chuàng)建 gRPC 服務(wù)器

在完成 service 代碼編寫之后,我們創(chuàng)建 grpc server,然后注冊(cè)服務(wù)。

  1. ... 
  2.  
  3. server := grpc.NewServer() 
  4.  pb.RegisterToDoListServer(server, new(service.ToDoList)) 
  5.  
  6. ... 

完整代碼,請(qǐng)查閱 github。

以上就是使用 grpc 創(chuàng)建 rpc service 的一般流程,在生產(chǎn)環(huán)境項(xiàng)目中,還需要完善一些公共方法,比如配置文件讀取、錯(cuò)誤碼定義、參數(shù)驗(yàn)證等。為了讀者朋友們?nèi)菀桌斫猓搶?shí)戰(zhàn)項(xiàng)目中未涉及這部分內(nèi)容,感興趣的讀者朋友們可以嘗試自己實(shí)現(xiàn)該部分內(nèi)容。

3、client

client 主要負(fù)責(zé)業(yè)務(wù)邏輯,本文介紹的實(shí)戰(zhàn)項(xiàng)目使用 gin 框架實(shí)現(xiàn)路由。通常,client service 的 pb 文件拷貝 server service 生成的 pb 文件。

首先,我們創(chuàng)建 controller 目錄,調(diào)用 server service 的方法,然后,使用 gin 框架設(shè)計(jì)路由。

client 目錄

  1. ├── controller 
  2. │   └── toDoList.go 
  3. ├── main.go 
  4. ├── pb 
  5. │   ├── todoPb 
  6. │   │   ├── toDoList.pb.go 
  7. │   │   └── toDoList_grpc.pb.go 
  8. │   └── userPb 
  9. │       ├── user.pb.go 
  10. │       └── user_grpc.pb.go 
  11. └── router 
  12.     └── router.go 

拷貝 server service 生成的 pb 文件

client 直接拷貝 server service 生成的 pb 文件,不需要編寫 proto 文件,然后使用 protoc 編譯 proto 文件,生成 pb 文件。

編寫 controller 代碼,調(diào)用 server service 的方法

在 controller 目錄中創(chuàng)建 go 文件,編寫 controller 方法,并創(chuàng)建客戶端,使用創(chuàng)建的客戶端調(diào)用 server service 的方法。

  1. func CreateToDoList(ctx *gin.Context) { 
  2.  
  3. ... 
  4.  
  5. cc := NewToDoListClient() 
  6.  defer func() { 
  7.   err := cc.Close() 
  8.   if err != nil { 
  9.    log.Fatalf("conn close error=%v", err) 
  10.   } 
  11.  }() 
  12.  cli := pb.NewToDoListClient(cc) 
  13.  ctx1, cancel := context.WithTimeout(context.Background(), time.Second) 
  14.  defer cancel() 
  15.  res, err := cli.CreateToDoList(ctx1, param) 
  16.    
  17. ... 

完整代碼,請(qǐng)查閱 github。

創(chuàng)建 gin 路由

編寫完 controller 之后,創(chuàng)建 router 目錄,在 router 目錄中創(chuàng)建 gin 路由,用于訪問 controller 中的方法。

  1. ... 
  2.  
  3. r := gin.Default() 
  4.  apiV1 := r.Group("/v1"
  5.  todolist := apiV1.Group("/todolist"
  6.  { 
  7.   todolist.POST("/add", controller.CreateToDoList) 
  8.  
  9. ... 

完整代碼,請(qǐng)查閱 github。

4、總結(jié)

本文我們介紹了怎么使用 grpc 開發(fā) service。讀者朋友們閱讀完本文,可以了解使用 grpc 開發(fā) service 的一般開發(fā)流程,建議感興趣的讀者朋友們,實(shí)現(xiàn)項(xiàng)目中 user service 的代碼編寫。

 

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

2021-09-13 05:02:49

GogRPC語言

2021-09-01 23:29:37

Golang語言gRPC

2021-10-10 23:02:49

Golang語言代碼

2022-02-20 23:15:46

gRPCGolang語言

2025-01-13 06:00:00

Go語言gRPC

2023-03-01 08:33:37

gRPC健康檢查代碼

2022-04-29 11:52:02

API代碼HTTP

2024-09-04 08:09:51

2021-06-09 23:36:46

Golang語言版本

2021-05-28 08:58:41

Golang網(wǎng)卡metrics

2018-08-01 15:10:02

GolangPython語言

2021-12-05 23:14:24

微服務(wù)GolanggRPC

2021-10-26 09:26:21

編程技能開發(fā)

2021-12-13 01:24:14

語言Golang panic

2021-06-29 23:40:19

Golang語言并發(fā)

2023-09-06 07:17:57

2020-11-01 17:13:22

DotNET 5語言gRPC

2021-11-08 23:09:07

Go排序數(shù)據(jù)

2021-12-27 03:36:09

語言For Golang

2021-08-03 09:07:39

GolangGrpc服務(wù)
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 黄色av网站在线免费观看 | 久久久精 | 国产一区高清 | 欧美成人激情视频 | 午夜影院操 | 国产999精品久久久久久绿帽 | 九九久久这里只有精品 | 91久久精 | 国产在线精品一区二区 | 日韩一区不卡 | 国产午夜精品福利 | 欧美二区三区 | 热re99久久精品国产99热 | 在线一级片 | 一区二区视频在线观看 | 亚洲精品中文字幕中文字幕 | 九九久久精品 | 欧美性video| 精品一级电影 | 黄片毛片免费看 | 日韩综合网 | 天堂视频免费 | 久久久久国产精品一区 | 综合伊人 | 精品视频一区二区 | 992人人草| 国产日韩一区二区三免费高清 | 亚洲一区二区网站 | 精品美女久久久 | 国产一区二区在线免费 | 九九色综合 | 91久久久久久久久 | 成人在线视频免费观看 | 欧美视频在线播放 | 欧美精品一区二区三区在线播放 | 精品日韩| 91在线免费视频 | 国产精品视频在线播放 | 久久一区二区免费视频 | 97人人草 | 精品国产免费人成在线观看 |