日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
構(gòu)建微服務(wù)的十大Go框架/庫(kù)

現(xiàn)在,很多開源庫(kù)都支持構(gòu)建應(yīng)用程序。我應(yīng)該向你推薦一些庫(kù),它們可以幫助啟動(dòng)具有簡(jiǎn)單設(shè)計(jì)、干凈代碼和良好性能的項(xiàng)目。

創(chuàng)新互聯(lián)建站作為成都網(wǎng)站建設(shè)公司,專注成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì),有關(guān)成都企業(yè)網(wǎng)站建設(shè)方案、改版、費(fèi)用等問(wèn)題,行業(yè)涉及雨棚定制等多個(gè)領(lǐng)域,已為上千家企業(yè)服務(wù),得到了客戶的尊重與認(rèn)可。

01 CLI 命令(spf13/cobra)

你想要構(gòu)建一些 CLI 命令嗎?

  • Cobra 既是一個(gè)用于創(chuàng)建強(qiáng)大的現(xiàn)代 CLI 應(yīng)用程序的庫(kù),也是一個(gè)用于生成應(yīng)用程序和命令文件的程序。

我使用這個(gè)庫(kù)來(lái)管理命令應(yīng)用程序,執(zhí)行運(yùn)行程序,初始化配置,并啟動(dòng) Rest API。

基于 cobra 的應(yīng)用組織結(jié)構(gòu):

 
 
 
 
  1. ├── app
  2. │ ├── main.go
  3. │ ├── cmd
  4. │ └── root.go

app/main.go 的代碼如下:

 
 
 
 
  1. package main
  2. import (
  3.    "app/cmd"
  4. )
  5. func main() {
  6.    cmd.Execute()
  7. }

app/cmd/root.go 代碼如下:

 
 
 
 
  1. package cmd
  2. var rootCmd = &cobra.Command{
  3.    Use:   "hugo",
  4.    Short: "Hugo is a very fast static site generator",
  5.    Long: `A Fast and Flexible Static Site Generator built with love by spf13 and friends in Go. Complete documentation is available at http://hugo.spf13.com`,
  6.    Run: func(cmd *cobra.Command, args []string) {
  7.       // Do Stuff Here
  8.    },
  9. }
  10. func Execute() {
  11.    if err := rootCmd.Execute(); err != nil {
  12.       fmt.Println(err)
  13.       os.Exit(1)
  14.    }
  15. }

項(xiàng)目地址:https://github.com/spf13/cobra。

02 配置讀取器(spf13/viper)

Viper 是 Go 應(yīng)用程序的完整配置解決方案。

Viper 支持以下格式配置:

  • JSON
  • TOML
  • YAML
  • HCL
  • INI
  • envfile
  • Java properties config files

例如 config/config.toml:

 
 
 
 
  1. address="localhost"
  2. port="9090"

響應(yīng)操作的文件 config.go:

 
 
 
 
  1. func ReadConfig() {
  2.    viper.SetConfigName("config/config.toml")
  3.    viper.SetConfigType("toml")
  4.    err := viper.ReadInConfig()
  5.    if err != nil {
  6.       panic(fmt.Errorf("Fatal error config file: %s \n", err))
  7.    }
  8. }

然后在 main.go 中使用 config 的值:

 
 
 
 
  1. func main() {
  2.    address := viper.Get("address")
  3.    port := viper.Get("port")
  4.    fmt.Printf("address: %s", address)
  5.    fmt.Printf("port: %s", port)
  6. }

項(xiàng)目地址:https://github.com/spf13/viper。

03 Web 框架(labstack/echo)

Echo 是一個(gè)高性能、極簡(jiǎn)主義的 Go Web 框架。

安裝

 
 
 
 
  1. // go get github.com/labstack/echo/{version}
  2. go get github.com/labstack/echo/v4

例子

 
 
 
 
  1. package main
  2. import (
  3.   "net/http"
  4.   "github.com/labstack/echo/v4"
  5.   "github.com/labstack/echo/v4/middleware"
  6. )
  7. func main() {
  8.   // Echo instance
  9.   e := echo.New()
  10.   // Middleware
  11.   e.Use(middleware.Logger())
  12.   e.Use(middleware.Recover())
  13.   // Routes
  14.   e.GET("/", hello)
  15.   // Start server
  16.   e.Logger.Fatal(e.Start(":1323"))
  17. }
  18. // Handler
  19. func hello(c echo.Context) error {
  20.   return c.String(http.StatusOK, "Hello, World!")
  21. }

項(xiàng)目地址:https://github.com/labstack/echo。

04 依賴注入(uber-go/fx)

我發(fā)現(xiàn)這個(gè)庫(kù)非常有用,你不需要生成任何東西。只有代碼。非常模塊化和清晰的層次。

一個(gè)依賴注入的 Go 應(yīng)用框架。

 
 
 
 
  1. func main() {
  2.  fx.New(injectModule()).Run()
  3. }
  4. func injectModule() fx.Option {
  5.  return fx.Options(
  6.   fx.Provide( 
  7.        NewTimeOutContext, 
  8.        NewDbConn, 
  9.   ),
  10.   repository.Module, 
  11.   service.Module, 
  12.   outbound.Module, 
  13.   server.Module, 
  14.   controller.Module,
  15.  )
  16. }

項(xiàng)目地址:https://github.com/uber-go/fx。

04 Swagger Generator, UI 和 Validation

在 swagger 部分,我必須使用不同的 3 個(gè)庫(kù),因?yàn)槲覜](méi)有找到 1 個(gè)庫(kù)同時(shí)包含這個(gè) 3 個(gè)庫(kù)功能的。如果你有推薦,請(qǐng)?jiān)u論告知。

a、Swagger generator (swaggo/swag)

Swag 將 Go 注釋轉(zhuǎn)換為 Swagger Documentation 2.0。

我們?yōu)榱餍械?Go Webb 框架[1]創(chuàng)建了各種各樣的插件。這允許你快速集成一個(gè)現(xiàn)有的 Go 項(xiàng)目(使用 Swagger UI)。

支持的 Web 框架:

  • gin
  • echo
  • buffalo
  • net/http

Swag 已經(jīng)處理了你那些 swagger 文件。所以你不再需要寫 swagger.yml 或 swagger.json。你需要做的只是編寫注釋??匆粋€(gè)例子:

 
 
 
 
  1. // @title Blueprint Swagger API
  2. // @version 1.0
  3. // @description Swagger API for Golang Project Blueprint.
  4. // @termsOfService http://swagger.io/terms/
  5. // @contact.name API Support
  6. // @contact.email martin7.heinz@gmail.com
  7. // @license.name MIT
  8. // @license.url https://github.com/MartinHeinz/go-project-blueprint/blob/master/LICENSE
  9. // @BasePath /api/v1
  10. func main() {
  11.     ...
  12.     r.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerFiles.Handler))
  13.     ...
  14. }

項(xiàng)目地址:https://github.com/swaggo/swag。

b、Swagger UI (swaggo/echo-swagger)

因?yàn)槲艺谑褂?echo,所以我為 swagger 選擇了這個(gè) user interface。

使用示例:

 
 
 
 
  1. package main
  2. import (
  3.  "github.com/labstack/echo/v4"
  4.  "github.com/swaggo/echo-swagger"
  5.  _ "github.com/swaggo/echo-swagger/example/docs" // docs is generated by Swag CLI, you have to import it.
  6. )
  7. // @title Swagger Example API
  8. // @version 1.0
  9. // @description This is a sample server Petstore server.
  10. // @termsOfService http://swagger.io/terms/
  11. // @contact.name API Support
  12. // @contact.url http://www.swagger.io/support
  13. // @contact.email support@swagger.io
  14. // @license.name Apache 2.0
  15. // @license.url http://www.apache.org/licenses/LICENSE-2.0.html
  16. // @host petstore.swagger.io
  17. // @BasePath /v2
  18. func main() {
  19.  e := echo.New()
  20.  e.GET("/swagger/*", echoSwagger.WrapHandler)
  21.  e.Logger.Fatal(e.Start(":1323"))
  22. }

項(xiàng)目地址:https://github.com/swaggo/echo-swagger。

c、Swagger validation (go-swagger/go-swagger)

這個(gè)包包含了 Swagger 2.0(又名 OpenAPI 2.0[2])的 golang 實(shí)現(xiàn): 它知道如何序列化和反序列化 Swagger 規(guī)范。

安裝:

 
 
 
 
  1. go get github.com/go-swagger/go-swagger/cmd/swagger

運(yùn)行以驗(yàn)證:

 
 
 
 
  1. swagger validate api/docs/swagger.yaml

輸出如下:

 
 
 
 
  1. 2021/01/30 22:47:01 
  2. The swagger spec at "api/docs/swagger.yaml" is valid against swagger specification 2.0

項(xiàng)目地址:https://github.com/go-swagger/go-swagger。

06、自定義 Logger (sirupsen/logrus)

Logrus 是 Go (golang)的結(jié)構(gòu)化 Logger,完全兼容標(biāo)準(zhǔn)庫(kù) Log。

例子:

 
 
 
 
  1. package main
  2. import (
  3.   log "github.com/sirupsen/logrus"
  4. )
  5. func main() {
  6.   log.WithFields(log.Fields{
  7.     "animal": "walrus",
  8.   }).Info("A walrus appears")
  9. }

項(xiàng)目地址:https://github.com/sirupsen/logrus。

07、Mock 生成器 (vektra/mockery)

一個(gè) Mock 代碼自動(dòng)生成器

安裝:

 
 
 
 
  1. go get github.com/vektra/mockery/v2/.../

生成 mock:

 
 
 
 
  1. ./bin/mockery --all

輸出:

項(xiàng)目地址:https://github.com/vektra/mockery。

08、Migrate (golang-migrate/migrate)

用 Go 編寫的數(shù)據(jù)庫(kù)遷移工具。作為 CLI[3] 使用或作為庫(kù)[4]導(dǎo)入。

支持如下數(shù)據(jù)庫(kù):

  • PostgreSQL
  • Redshift
  • Ql
  • Cassandra
  • SQLite (todo #165)
  • SQLCipher
  • MySQL/ MariaDB
  • Neo4j
  • MongoDB
  • CrateDB (todo #170)
  • Shell (todo #171)
  • Google Cloud Spanner
  • CockroachDB
  • ClickHouse
  • Firebird
  • MS SQL Server

安裝:

 
 
 
 
  1. $ go get -u -d github.com/golang-migrate/migrate/cmd/migrate

創(chuàng)建遷移文件:

 
 
 
 
  1. migrate create -ext sql -dir database/migrations -seq create_user

運(yùn)行升級(jí)版本:

 
 
 
 
  1. migrate -database "mysql://user:pass@tcp(localhost:3600)/user" -path=database/migrations up

降版本:

 
 
 
 
  1. migrate -database "mysql://user:pass@tcp(localhost:3600)/user" -path=database/migrations down

項(xiàng)目地址:< https://github.com/golang-migrate/migrate>。

09、Messaging (NSQ)

NSQ 拓?fù)洌?/p>

NSQ 組件:

  • nsqlookupd (daemon manage topologies / routes)
  • nsqd (daemon manage receives, queues, and delivers messages)
  • nsqadmin (default Web UI of nsq)

基于 docker-compose 示例:(nsqlookupd,nsqd,nsqadmin)

 
 
 
 
  1. version: '3'
  2. services:
  3. nsqlookupd:
  4. image: nsqio/nsq
  5. command: /nsqlookupd
  6. ports:
  7. - "4160:4160"
  8. - "4161:4161"
  9. nsqd:
  10. image: nsqio/nsq
  11. command: /nsqd --lookupd-tcp-address=nsqlookupd:4160
  12. depends_on:
  13. - nsqlookupd
  14. ports:
  15. - "4150:4150"
  16. - "4151:4151"
  17. nsqadmin:
  18. image: nsqio/nsq
  19. command: /nsqadmin --lookupd-http-address=nsqlookupd:4161
  20. depends_on:
  21. - nsqlookupd
  22. ports:
  23. - "4171:4171"

執(zhí)行:

 
 
 
 
  1. To run docker:
  2. $ docker-compose up -d
  3. or if use name (docker-compose-nsq.yml):
  4. $ docker-compose -f docker-compose-nsq.yml up -d
  5. To check container docker:
  6. $ docker-compose ps
  7. To see logs:
  8. $ docker-compose logs
  9. To check nsq web ui: (assuming port is 32770)
  10. $ curl http://127.0.0.1:32770/ping

Go 代碼目錄:

 
 
 
 
  1. Create Folder:
  2. ├── consume
  3. │   └── consume.go
  4. └── publish
  5.     └── publish.go

consume.go 代碼:

 
 
 
 
  1. package main
  2. import (
  3.     "log"
  4.     "sync"
  5.     "github.com/nsqio/go-nsq"
  6. )
  7. func main() {
  8.     wg := &sync.WaitGroup{}
  9.     wg.Add(1)
  10.     decodeConfig := nsq.NewConfig()
  11.     c, err := nsq.NewConsumer("My_NSQ_Topic", "My_NSQ_Channel", decodeConfig)
  12.     if err != nil {
  13.       log.Panic("Could not create consumer")
  14.     }
  15.     c.AddHandler(nsq.HandlerFunc(func(message *nsq.Message) error {
  16.         log.Println("NSQ message received:")
  17.         log.Println(string(message.Body))
  18.       return nil
  19.     }))
  20.     err = c.ConnectToNSQD("127.0.0.1:4150")
  21.     if err != nil {
  22.       log.Panic("Could not connect")
  23.     }
  24.     log.Println("Awaiting messages from NSQ topic \"My NSQ Topic\"...")
  25.     wg.Wait()
  26. }

運(yùn)行 consume.go:

 
 
 
 
  1. $ go run consume/consume.go

publish.go 代碼:

 
 
 
 
  1. package main
  2. import (
  3.     "log"
  4.     "github.com/nsqio/go-nsq"
  5. )
  6. func main() {
  7.     config := nsq.NewConfig()
  8.     p, err := nsq.NewProducer("127.0.0.1:4150", config)
  9.     if err != nil {
  10.       log.Panic(err)
  11.     }
  12.     err = p.Publish("My_NSQ_Topic", []byte("sample NSQ message"))
  13.     if err != nil {
  14.       log.Panic(err)
  15.     }
  16. }

運(yùn)行 publish:

 
 
 
 
  1. $ go run publish/publish.go

項(xiàng)目地址:https://github.com/nsqio/go-nsq。

10、SQL (jmoiron/sqlx)

sqlx 是一個(gè)庫(kù),它為 go 的標(biāo)準(zhǔn) database/sql 庫(kù)提供了一組擴(kuò)展。

我喜歡的 sqlx 是因?yàn)樗鼈兛梢?scan 結(jié)構(gòu)!使用簡(jiǎn)單。

StrucScan 的例子:

 
 
 
 
  1. place := Place{}
  2. rows, err := db.Queryx("SELECT * FROM place")
  3. for rows.Next() {
  4.     err := rows.StructScan(&place)
  5.     if err != nil {
  6.        log.Fatalln(err)
  7.     } 
  8.     fmt.Printf("%#v\n", place)
  9. }

項(xiàng)目地址:https://github.com/jmoiron/sqlx。

11、附加的一些庫(kù)

  • Go routine grouping (sync/errgroup):https://pkg.go.dev/golang.org/x/sync/errgroup
  • Fluent SQL generation for golang (Masterminds/squirrel):https://github.com/Masterminds/squirrel
  • Golang Linter (golangci/golangci-lint):https://github.com/golangci/golangci-lint
  • Circuit Breaker (gojek/heimdall):https://github.com/gojek/heimdall
  • Go tool generate tags (fatih/gomodifytags):https://github.com/fatih/gomodifytags

12、總結(jié)

要構(gòu)建應(yīng)用程序,我們應(yīng)該知道有什么功能,特別是如果我們是團(tuán)隊(duì)協(xié)作,建議使用可讀性強(qiáng)的代碼,這樣在成為遺留代碼之前(也許 5-10 年之后) ,代碼可以更容易維護(hù)。

構(gòu)建應(yīng)用程序的三個(gè)關(guān)鍵:

  • 簡(jiǎn)單設(shè)計(jì)(項(xiàng)目結(jié)構(gòu)和依賴關(guān)系)
  • Clean Code (可讀性和可維護(hù)性)
  • Modular(模塊化) (Solid & flexible skeleton)

為了封裝所有這些庫(kù),我有一個(gè)模板或框架項(xiàng)目,其設(shè)計(jì)簡(jiǎn)單,代碼清晰??纯催@個(gè):https://github.com/kecci/goscription。

以上就是我常用的 10 大 Go 框架/庫(kù)和一些附加庫(kù)。

我希望你喜歡我的推薦,如果你有其他的推薦,請(qǐng)留言!

參考資料

[1]Go Webb 框架: https://github.com/swaggo/swag#supported-web-frameworks

[2]OpenAPI 2.0: https://github.com/OAI/OpenAPI-Specification/blob/master/versions/2.0.md

[3]CLI: https://github.com/golang-migrate/migrate#cli-usage

[4]庫(kù): https://github.com/golang-migrate/migrate#use-in-your-go-project


名稱欄目:構(gòu)建微服務(wù)的十大Go框架/庫(kù)
瀏覽地址:http://www.dlmjj.cn/article/dpggpeg.html