偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Go-Zero微服務(wù)快速入門和最佳實(shí)踐

開發(fā) 架構(gòu)
微服務(wù)進(jìn)行服務(wù)拆分一個最好理解并且最基本的原則就是:每個服務(wù)對應(yīng)一個單獨(dú)的數(shù)據(jù)庫。做到服務(wù)與服務(wù)之間的解耦,劃清邊界。

并發(fā)編程和分布式微服務(wù)是我們Gopher升職加薪的關(guān)鍵。

畢竟Go基礎(chǔ)很容易搞定,不管你是否有編程經(jīng)驗,都可以比較快速的入門Go語言進(jìn)行簡單項目的開發(fā)。

雖說好上手,但是想和別人拉開差距,提高自己的競爭力,搞懂分布式微服務(wù)和并發(fā)編程還是灰常重要的,這也是我今年簽約文章的重點(diǎn)。

Go-Zero

我想和大家說一下安利gozero的原因:

Go-zero [1]在GitHub中已經(jīng)有27.2K的star,集成了各種工程實(shí)踐的 web 和 rpc 框架。通過彈性設(shè)計保障了大并發(fā)服務(wù)端的穩(wěn)定性,經(jīng)受了充分的實(shí)戰(zhàn)檢驗。

官網(wǎng)

Go-Zero官方地址[2]

一個神奇的事情,如果你直接在百度搜索gozero,前幾頁的檢索結(jié)果竟然都沒有g(shù)ozero官網(wǎng),而是各個技術(shù)社區(qū)作者的分享。

我建議你先認(rèn)真學(xué)習(xí)Go-Zero官網(wǎng)資料,掃清知識盲點(diǎn),然后再跟著我去實(shí)踐。

技巧 & 整體開發(fā)流程

為了吸引你繼續(xù)讀下去,我先分享技巧吧:“總結(jié)一句話:用好goctl開發(fā)就是快!”

先說技巧

goctl

  1. 能使用 goctl[3] 的一定要用 goctl , goctl 是 go-zero 的內(nèi)置腳手架,是提升開發(fā)效率的一大利器,可以一鍵生成代碼、文檔、部署 k8s yaml、dockerfile 等。
  2. gozero和go一樣也強(qiáng)調(diào)“少即是多”的思想,能用goctl生成的千萬不要手寫,不僅開發(fā)速度慢;在團(tuán)隊開發(fā)中也難以保證統(tǒng)一的開發(fā)規(guī)范。
  3. 更重要的 goctl 支持我們自定義,后面我也會單獨(dú)整理文章出來,和你分享如何結(jié)合你的項目,定制適合自己的goctl,進(jìn)一步提高效率。那具體goctl能生成什么呢?
  • api
  • grpc
  • MySQL
  • MongoDB
  • 格式化
  • 接口文檔
  • 還支持自定義
  • 甚至還支持生成php、Android等代碼

目錄結(jié)構(gòu)

先帶你了解一下整體項目目錄,這樣你能更好的理解下文中的開發(fā)流程,這也是新手最頭疼的地方,不知道從哪里著手開發(fā)。

圖片圖片

  • app 所有的微服務(wù)目錄

cmd

model model層 方便cmd目錄中api和rpc調(diào)用

etc

internal

pb

服務(wù)包名 由goctl生成

main.go

desc

etc

internal

main.go

xxx.api

api api接口層 對外提供服務(wù),可以用goctl生成

rpc rpc層 內(nèi)部服務(wù) 可以用goctl生成

user

mqueue 等不同的服務(wù)

  • common 服務(wù)共享的常量、工具類等統(tǒng)一封裝到這里
  • deploy 項目部署配置等 比如Nginx配置
  • go.mod

歡迎關(guān)注我,下期內(nèi)容會共享GitHub開源地址出來。

Go-Zero微服務(wù)項目開發(fā)流程

當(dāng)你把go和gozero的開發(fā)環(huán)境安裝好之后,建議按照下面的順序進(jìn)行開發(fā):

  1. 首先設(shè)計數(shù)據(jù)庫和數(shù)據(jù)表
  2. 使用工具先生成model
  3. 先開發(fā)api層
  4. 再開發(fā)rpc層
  5. 在api層注冊rpc服務(wù),調(diào)用rpc方法,對外提供接口
  6. 生成接口文檔

以上是整體的開發(fā)流程,請你按照這個順序開發(fā),會非常清晰。

詳解

1)首先設(shè)計數(shù)據(jù)庫和數(shù)據(jù)表

  1. 微服務(wù)進(jìn)行服務(wù)拆分一個最好理解并且最基本的原則就是:每個服務(wù)對應(yīng)一個單獨(dú)的數(shù)據(jù)庫。做到服務(wù)與服務(wù)之間的解耦,劃清邊界。
  2. 這就要求我們明確項目(服務(wù))需求之后,做好表結(jié)構(gòu)設(shè)計。3.** 我們后續(xù)項目中用到的model、proto、甚至api層的結(jié)構(gòu)體都可以通過工具根據(jù)數(shù)據(jù)庫生成,所以數(shù)據(jù)庫的設(shè)計至關(guān)重要!**

2)使用工具先生成model

使用goctl中的model命令生成即可:官網(wǎng)有講,不再贅述:mysql 代碼生成[4]

為了進(jìn)一步提高效率,我們對此進(jìn)行了封裝,方便我們更快更好的生成model,你也可以按照我們的方式來:

  1. 在項目根目錄下創(chuàng)建了script目錄,專門用于封裝各種常用的腳本
  2. 在script目錄下,我們創(chuàng)建了genModel目錄,用于生成model文件。
  3. 封裝genModel.sh腳本,內(nèi)容如下:
#!/usr/bin/env bash  
  
# 使用方法:  
# ./genModel.sh 數(shù)據(jù)庫名 表名稱
# 比如:
# ./genModel.sh lottery lottery  
# 再將./genModel下的生成的文件剪切到對應(yīng)服務(wù)的model目錄中即可  
  
#生成的表名  
tables=$2  
#表生成的genmodel目錄  
modeldir=./genModel  
  
# 數(shù)據(jù)庫配置  
host=127.0.0.1  
port=3306  
dbname=$1  
username=root  
passwd=xxxxx  
  
echo "開始創(chuàng)建庫:$dbname 的表:$2"  
goctl model mysql datasource -url="${username}:${passwd}@tcp(${host}:${port})/${dbname}" -table="${tables}" -dir="${modeldir}" -cache=true --home="${template}" --style=goZero

這樣,我們就可以很方便的使用./genModel.sh生成model,而不是需要拼接冗長的goctl命令

這個思路也同樣適用你使用goctl生成其他的代碼。

3)先開發(fā)api層

  1. 先定義xxx.api文件,可以參考 api demo 代碼生成[5]
  2. 使用goctl生成代碼:goctl api go -api main.api -dir ../ --style=goZero
  3. 配置生成代碼中的config目錄以及yaml文件,弄清它們兩者之間的聯(lián)系
  4. 配置生成代碼svc目錄中的文件(比如jwt之類的中間件)

4)再開發(fā)rpc層

  1. 再告訴你一個提效利器 sql2pb[6],這個工具適合我們開發(fā)新服務(wù)時使用。見名之意,也就是可以把sql轉(zhuǎn)成pb文件
  2. 注意:一旦我們的xx.proto文件有自定義修改之后,就不建議使用sql2pb了。如果不使用sql2pb的話,就直接修改xxx.proto文件
  3. 使用goctl生成pb.go文件:goctl rpc protoc lottery.proto --go_out=../ --go-grpc_out=../ --zrpc_out=../ --style=goZero
  4. 配置svc,注冊model
  5. 編寫logic,調(diào)用model,寫業(yè)務(wù)代碼

5)在api層注冊rpc服務(wù),調(diào)用rpc方法

  1. api層配置svc,注冊rpc客戶端
  2. 調(diào)用rpc方法
  3. 返回restful api

6)生成接口文檔

  1. 注意:雖然goctl不直接支持生成swagger,但是goctl的插件支持。-   goctl-swagger[7] 通過 api 文件生成 swagger 文檔
  2. 安裝好goctl-swagger插件之后,我們就可以在api層的xxx.api同級目錄下生成swagger了
  3. 參考命令如下:其中main.api是我在api層的desc目錄中定義的,我們也在同級目錄執(zhí)行g(shù)octl命令即可:
  4. goctl api plugin -plugin goctl-swagger="swagger -filename main.json" -api main.api -dir .

圖片圖片

  1. 執(zhí)行之后,就會出現(xiàn)如下圖所示的main.json,這就是swagger文件

圖片圖片

  1. 你可以直接使用swagger進(jìn)行測試,也可以導(dǎo)入到其他工具中,比如我習(xí)慣導(dǎo)入到Apifox中,可以自動生成參數(shù),方便我們進(jìn)行測試:

圖片圖片

圖片圖片

總結(jié)

這篇文章帶你梳理了使用gozero開發(fā)微服務(wù)項目的步驟和技巧,請你按我建議的方式開發(fā)和debug,會很清晰。下一篇文章將通過一個完整的功能,帶你跑通一個微服務(wù)的開發(fā),包括:需求分析+表結(jié)構(gòu)設(shè)計+api+rpc+goctl+apifox調(diào)試+細(xì)節(jié)處理。

本文轉(zhuǎn)載自微信公眾號「 王中陽Go」,作者「王中陽」,可以通過以下二維碼關(guān)注。

轉(zhuǎn)載本文請聯(lián)系「 程序員升級打怪之旅」公眾號。

責(zé)任編輯:武曉燕 來源: 王中陽Go
相關(guān)推薦

2025-05-26 04:00:00

2023-08-28 08:00:45

2023-08-10 08:00:42

令牌限流器計數(shù)器

2023-08-07 08:01:15

2018-12-17 16:44:49

Golang微服務(wù)

2018-12-17 16:39:20

Golang微服務(wù)

2024-05-16 13:13:39

微服務(wù)架構(gòu)自動化

2018-12-17 16:48:05

Golang微服務(wù)

2023-11-06 08:55:31

2021-09-08 10:32:29

微服務(wù)容器化Serverless

2022-11-02 12:17:41

2020-08-07 09:41:00

微服務(wù)架構(gòu)數(shù)據(jù)

2024-01-05 09:08:48

代碼服務(wù)管理

2023-11-20 16:06:34

軟件開發(fā)微服務(wù)架構(gòu)Spring

2020-04-27 10:20:07

微服務(wù)架構(gòu)數(shù)據(jù)庫

2017-06-09 09:42:07

解耦利器

2014-09-01 09:57:11

Go產(chǎn)品環(huán)境最佳語言

2023-10-24 08:00:00

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

2021-01-14 09:55:21

Java微服務(wù)Go

2023-06-28 09:00:00

微服務(wù)軟件開發(fā)
點(diǎn)贊
收藏

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