文章目录

  • 简介
  • 一、CLI 命令(spf13/cobra)
  • 二、配置读取器(spf13/viper)
  • 三、Web 框架(labstack/echo)
  • 四、依赖注入(uber-go/fx)
  • 五、Swagger Generator, UI 和 Validation
    • 1. Swagger generator (swaggo/swag)
    • 2. Swagger UI (swaggo/echo-swagger)
    • 3. Swagger validation (go-swagger/go-swagger)
  • 六、自定义 Logger (sirupsen/logrus)
  • 七、Mock 生成器 (vektra/mockery)
  • 八、Migrate (golang-migrate/migrate)
  • 九、Messaging (NSQ)
  • 十、10、SQL (jmoiron/sqlx)
  • 十一、附加的一些库
  • 小结
    • 参考资料

简介

现在,很多开源库都支持构建应用程序。我应该向你推荐一些库,它们可以帮助启动具有简单设计、干净代码和良好性能的项目。

一、CLI 命令(spf13/cobra)

Cobra 既是一个用于创建强大的现代 CLI 应用程序的库,也是一个用于生成应用程序和命令文件的程序。我使用这个库来管理命令应用程序,执行运行程序,初始化配置,并启动 Rest API。

基于 cobra 的应用组织结构:

├── app
│ ├── main.go
│ ├── cmd
│ └── root.go

app/main.go 的代码如下:

package main
import ( "app/cmd"
)
func main() { cmd.Execute()
}

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

package cmd
var rootCmd = &cobra.Command{ Use:   "hugo", Short: "Hugo is a very fast static site generator", 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`, Run: func(cmd *cobra.Command, args []string) { // Do Stuff Here },
}
func Execute() { if err := rootCmd.Execute(); err != nil { fmt.Println(err) os.Exit(1) }
}

项目地址:https://github.com/spf13/cobra。

二、配置读取器(spf13/viper)


iper 是 Go 应用程序的完整配置解决方案。Viper 支持以下格式配置:

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

例如 config/config.toml:

address="localhost"
port="9090"

响应操作的文件 config.go:

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

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

func main() { address := viper.Get("address") port := viper.Get("port") fmt.Printf("address: %s", address) fmt.Printf("port: %s", port)
}

项目地址:https://github.com/spf13/viper。

三、Web 框架(labstack/echo)


Echo 是一个高性能、极简主义的 Go Web 框架。

安装:

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

示例

package main import ( "net/http" "github.com/labstack/echo/v4" "github.com/labstack/echo/v4/middleware"
) func main() { // Echo instance e := echo.New() // Middleware e.Use(middleware.Logger()) e.Use(middleware.Recover()) // Routes e.GET("/", hello) // Start server e.Logger.Fatal(e.Start(":1323"))
} // Handler
func hello(c echo.Context) error { return c.String(http.StatusOK, "Hello, World!")
}

项目地址:https://github.com/labstack/echo。

四、依赖注入(uber-go/fx)


我发现这个库非常有用,你不需要生成任何东西。只有代码。非常模块化和清晰的层次。一个依赖注入的 Go 应用框架。

func main() { fx.New(injectModule()).Run()
} func injectModule() fx.Option { return fx.Options( fx.Provide(  NewTimeOutContext,  NewDbConn,  ), repository.Module,  service.Module,  outbound.Module,  server.Module,  controller.Module, )
}

项目地址:https://github.com/uber-go/fx。

五、Swagger Generator, UI 和 Validation


在 swagger 部分,我必须使用不同的 3 个库,因为我没有找到 1 个库同时包含这个 3 个库功能的。如果你有推荐,请评论告知。

1. Swagger generator (swaggo/swag)

Swag 将 Go 注释转换为 Swagger Documentation 2.0。我们为流行的 Go Webb 框架[1]创建了各种各样的插件。这允许你快速集成一个现有的 Go 项目(使用 Swagger UI)。支持的 Web 框架:

  • gin
  • echo
  • buffalo
  • net/http

Swag 已经处理了你那些 swagger 文件。所以你不再需要写 swagger.yml 或 swagger.json。你需要做的只是编写注释。看一个例子:

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

项目地址:https://github.com/swaggo/swag。

2. Swagger UI (swaggo/echo-swagger)

因为我正在使用 echo,所以我为 swagger 选择了这个 user interface。

使用示例:

package main
import ( "github.com/labstack/echo/v4" "github.com/swaggo/echo-swagger" _ "github.com/swaggo/echo-swagger/example/docs" // docs is generated by Swag CLI, you have to import it.
)
// @title Swagger Example API
// @version 1.0
// @description This is a sample server Petstore server.
// @termsOfService http://swagger.io/terms/
// @contact.name API Support
// @contact.url http://www.swagger.io/support
// @contact.email support@swagger.io
// @license.name Apache 2.0
// @license.url http://www.apache.org/licenses/LICENSE-2.0.html
// @host petstore.swagger.io
// @BasePath /v2
func main() { e := echo.New() e.GET("/swagger/*", echoSwagger.WrapHandler) e.Logger.Fatal(e.Start(":1323"))
}

项目地址:https://github.com/swaggo/echo-swagger。

3. Swagger validation (go-swagger/go-swagger)

这个包包含了 Swagger 2.0(又名 OpenAPI 2.0[2])的 golang 实现: 它知道如何序列化和反序列化 Swagger 规范。

安装:

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

运行以验证:

swagger validate api/docs/swagger.yaml

输出如下:

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

项目地址:https://github.com/go-swagger/go-swagger。

六、自定义 Logger (sirupsen/logrus)


Logrus 是 Go (golang)的结构化 Logger,完全兼容标准库 Log。

示例:

package main import ( log "github.com/sirupsen/logrus"
) func main() { log.WithFields(log.Fields{ "animal": "walrus", }).Info("A walrus appears")
}

项目地址:https://github.com/sirupsen/logrus。

七、Mock 生成器 (vektra/mockery)

一个 Mock 代码自动生成器

安装:

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

生成 mock:

./bin/mockery --all

输出:

项目地址:https://github.com/vektra/mockery。

八、Migrate (golang-migrate/migrate)

用 Go 编写的数据库迁移工具。作为 CLI[3] 使用或作为库[4]导入。支持如下数据库:

  • 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

安装:

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

创建迁移文件:

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

运行升级版本:

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

降版本:

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

项目地址:< https://github.com/golang-migrate/migrate>。

九、Messaging (NSQ)

NSQ 拓扑:

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)

version: '3'
services:
nsqlookupd:
image: nsqio/nsq
command: /nsqlookupd
ports:
- "4160:4160"
- "4161:4161"
nsqd:
image: nsqio/nsq
command: /nsqd --lookupd-tcp-address=nsqlookupd:4160
depends_on:
- nsqlookupd
ports:
- "4150:4150"
- "4151:4151"
nsqadmin:
image: nsqio/nsq
command: /nsqadmin --lookupd-http-address=nsqlookupd:4161
depends_on:
- nsqlookupd
ports:
- "4171:4171"

执行:

To run docker:
$ docker-compose up -d
or if use name (docker-compose-nsq.yml):
$ docker-compose -f docker-compose-nsq.yml up -d
To check container docker:
$ docker-compose ps
To see logs:
$ docker-compose logs
To check nsq web ui: (assuming port is 32770)
$ curl http://127.0.0.1:32770/ping

Go 代码目录:

Create Folder:
├── consume
│   └── consume.go
└── publish └── publish.go

consume.go 代码:

package main
import ( "log" "sync" "github.com/nsqio/go-nsq"
)
func main() { wg := &sync.WaitGroup{} wg.Add(1) decodeConfig := nsq.NewConfig() c, err := nsq.NewConsumer("My_NSQ_Topic", "My_NSQ_Channel", decodeConfig) if err != nil { log.Panic("Could not create consumer") } c.AddHandler(nsq.HandlerFunc(func(message *nsq.Message) error { log.Println("NSQ message received:") log.Println(string(message.Body)) return nil })) err = c.ConnectToNSQD("127.0.0.1:4150") if err != nil { log.Panic("Could not connect") } log.Println("Awaiting messages from NSQ topic \"My NSQ Topic\"...") wg.Wait()
}

运行 consume.go:

$ go run consume/consume.go

publish.go 代码:

package main
import ( "log" "github.com/nsqio/go-nsq"
)
func main() { config := nsq.NewConfig() p, err := nsq.NewProducer("127.0.0.1:4150", config) if err != nil { log.Panic(err) } err = p.Publish("My_NSQ_Topic", []byte("sample NSQ message")) if err != nil { log.Panic(err) }
}

运行 publish:

$ go run publish/publish.go

项目地址:https://github.com/nsqio/go-nsq。

十、10、SQL (jmoiron/sqlx)

sqlx 是一个库,它为 go 的标准 database/sql 库提供了一组扩展。我喜欢的 sqlx 是因为它们可以 scan 结构!使用简单。

StrucScan 的例子:

place := Place{}
rows, err := db.Queryx("SELECT * FROM place")
for rows.Next() { err := rows.StructScan(&place) if err != nil { log.Fatalln(err) }  fmt.Printf("%#v\n", place)
}

项目地址:https://github.com/jmoiron/sqlx。

十一、附加的一些库

  • 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

小结

要构建应用程序,我们应该知道有什么功能,特别是如果我们是团队协作,建议使用可读性强的代码,这样在成为遗留代码之前(也许 5-10 年之后) ,代码可以更容易维护。构建应用程序的三个关键:

  • 简单设计(项目结构和依赖关系)
  • Clean Code (可读性和可维护性)
  • Modular(模块化) (Solid & flexible skeleton)

为了封装所有这些库,我有一个模板或框架项目,其设计简单,代码清晰。看看这个:https://github.com/kecci/goscription。以上就是我常用的 10 大 Go 框架/库和一些附加库。

参考资料

  • [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]库: https://github.com/golang-migrate/migrate#use-in-your-go-project

Go:构建应用程序的10大框架相关推荐

  1. 程序员10大境界【走在路上,潜心修行】

    致应届毕业生 少走弯路的十条忠告 1.买个闹钟,以便按时叫醒你.贪睡和不守时,都将成为你工作和事业上的绊脚石,任何时候都一样.不仅要学会准时,更要学会提前.就如你坐车去某地,沿途的风景很美,你忍不住下 ...

  2. 【转】程序员10大境界【走在路上,潜心修行】

    致应届毕业生 少走弯路的十条忠告  原文地址:http://blog.csdn.net/itm_hadf/article/details/7424493   1.买个闹钟,以便按时叫醒你.贪睡和不守时 ...

  3. 程序员10大终极杀器,你get了几个?

    经常有同学问:作为程序员,终极杀器是什么? 其实有大佬早已回答过:持续学习,开阔视野才是程序员的终极杀器!基于此,给大家一个建议:不妨多听听业内一些大牛们的经验之谈,开阔思路,掌握高效法则黑科技. 今 ...

  4. 程序员10大推荐网站

    1.gitHub (https://github.com/) gitHub是一个面向开源及私有软件项目的托管平台,因为只支持git 作为唯一的版本库格式进行托管,故名gitHub. gitHub于20 ...

  5. 幽默:程序员10大口头禅,你都听过吗?

    0.这个昨天还是正常的 1.试试三连 2.在我的电脑上明明可以,你清理下缓存 3.这个实现不了 4.注释 5.一行代码 6.什么时候完成 7.电脑问题 8.这个功能,技术上没办法实现 9.之前都好好的 ...

  6. WINDOWS自启动程序的10大隐身之所

    Windows启动时通常会有一大堆程序自动启动.不要以为管好了"开始→程序→启动"菜单就万事大吉,实际上,在Windows XP/2K中,让Windows自动启动程序的办法很多,下 ...

  7. 程序员的10大境界,计算科学的10层楼,比尔盖茨看了会自卑,牛顿看了会落泪!

    程序员10大境界 作者简介:周伟明先生毕业于上海交通大学,1994年开始 从事专业软件开发,曾工作于美国加州硅谷的DASCOM Inc公司(现为IBM的全资子公司)和华为技术有限公司等企业.在网络安全 ...

  8. 2016深度学习统治人工智能?深度学习十大框架

    2019独角兽企业重金招聘Python工程师标准>>> 2015 年结束了,是时候看看 2016 年的技术趋势,尤其是关于深度学习方面. 新智元在 2015 年底发过一篇文章< ...

  9. python的web框架哪个最好学_2018年要学习的10大Python Web框架

    通过为开发人员提供应用程序开发结构,框架使开发人员的生活更轻松.他们自动执行通用解决方案,缩短开发时间,并允许开发人员更多地关注应用程序逻辑而不是常规元素. 在本文中,我们分享了我们自己的前十大Pyt ...

最新文章

  1. radio切换控制div显示_React 项目实践——搭建一个温度控制 App
  2. 参加51CTO学院软考培训,我通过啦
  3. OnTimer定时器使用踩坑实例和使用方法
  4. 交换环境下的冗余及负载分担技术(STP Channel HSRP)
  5. Dataset:GiveMeSomeCredit数据集的简介、下载、使用方法之详细攻略
  6. Java 异常(Java Exception)(一)
  7. vue element form中input等组件不能输入值
  8. android 如何动态设置margin,Android 动态设置margin
  9. undefined reference to `cv::VideoCapture::VideoCapture()'
  10. php form validator 下单,PHP Form表单验证:PHP form validator使_php
  11. VB 和Flex交互总结
  12. HBase——集群搭建
  13. 从头推导与实现 BP 网络
  14. java 集合转字符串工具类,浅谈常用字符串与集合类转换的工具类
  15. 让控件如此丝滑Scroller和VelocityTracker的API讲解与实战——Android高级UI
  16. 黑鲨重装计算机安装无法继续,一键重装失败不要怕,黑鲨教你解决一键重装系统失败问题...
  17. .Net学习平台有很多,最快捷的是在这里?
  18. YS-LDV7语音识别模块使用手册
  19. CISCO路由器交换机简介及Packet+Tracer使用说明
  20. [AV1] AV1 帧内预测

热门文章

  1. mysql项目酒店管理博客园_项目中常用的19条MySQL优化
  2. 大根堆 HYSBZ - 4919 线段树合并
  3. 解决URL请求的中文乱码问题
  4. python优点和缺点_python的优势和劣势
  5. AndroidStudio中* daemon not running; starting now at tcp:5037
  6. 道听途说先生谈投资投机
  7. 2019年1月份学习内容_我在2019年阅读的内容
  8. PPlive的上传很可怕~
  9. JavaScript实现水印效果
  10. python爬虫学习笔记-requests基础