4.8 KiB
介绍
kratos包含了一批好用的工具集,比如项目一键生成、基于proto生成http&grpc代码,生成缓存回源代码,生成memcache执行代码,生成swagger文档等。
获取工具
执行以下命令,即可快速安装好kratos
工具
go get -u github.com/bilibili/kratos/tool/kratos
那么接下来让我们快速开始熟悉工具的用法~
kratos本体
kratos
是所有工具集的本体,就像go
一样,拥有执行各种子工具的能力,如go build
和go tool
。先让我们看看-h
的输出:
NAME:
kratos - kratos tool
USAGE:
kratos [global options] command [command options] [arguments...]
VERSION:
0.0.1
COMMANDS:
new, n create new project
build, b kratos build
run, r kratos run
tool, t kratos tool
version, v kratos version
self-upgrade kratos self-upgrade
help, h Shows a list of commands or help for one command
GLOBAL OPTIONS:
--help, -h show help
--version, -v print the version
可以看到kratos
有如:new
build
run
tool
等在内的COMMANDS,那么接下来一一演示如何使用。
kratos new
kratos new
是快速创建一个项目的命令,执行如下:
kratos new kratos-demo
即可快速在当前目录生成一个叫kratos-demo
的项目。此外还支持指定owner和path,如下:
kratos new kratos-demo -o YourName -d YourPath
注意,kratos new
默认是不会生成通过 protobuf 定义的grpc
和bm
示例代码的,如需生成请加--proto
,如下:
kratos new kratos-demo -o YourName -d YourPath --proto
特别注意,如果不是MacOS系统,需要自己进行手动安装protoc,用于生成的示例项目
api
目录下的proto
文件并不会自动生成对应的.pb.go
和.bm.go
文件。 也可以参考以下说明进行生成:protoc说明
kratos build & run
kratos build
和kratos run
是go build
和go run
的封装,可以在当前项目任意目录进行快速运行进行调试,并无特别用途。
kratos tool
kratos tool
是基于proto生成http&grpc代码,生成缓存回源代码,生成memcache执行代码,生成swagger文档等工具集,先看下的执行效果:
kratos tool
swagger(已安装): swagger api文档 Author(goswagger.io) [2019/05/05]
protoc(已安装): 快速方便生成pb.go和bm.go的protoc封装,windows、Linux请先安装protoc工具 Author(kratos) [2019/05/04]
kratos(已安装): Kratos工具集本体 Author(kratos) [2019/04/02]
安装工具: kratos tool install demo
执行工具: kratos tool demo
安装全部工具: kratos tool install all
详细文档: https://github.com/bilibili/kratos/blob/master/doc/wiki-cn/kratos-tool.md
小小说明:如未安装工具,第一次运行也可自动安装,不需要特别执行install
目前已经集成的工具有:
- kratos 为本体工具,只用于安装更新使用;
- protoc 用于快速生成gRPC、HTTP、Swagger文件,该命令Windows,Linux用户需要手动安装 protobuf 工具。
- swagger 用于显示自动生成的HTTP API接口文档,通过
kratos tool swagger serve api/api.swagger.json
可以查看文档。
kratos tool protoc
// generate all
kratos tool protoc api.proto
// generate gRPC
kratos tool protoc --grpc api.proto
// generate BM HTTP
kratos tool protoc --bm api.proto
// generate swagger
kratos tool protoc --swagger api.proto
执行对应生成 api.pb.go/api.bm.go/api.swagger.json
源文档。
该工具在Windows/Linux下运行,需提前安装好 protobuf 工具
该工具实际是一段shell
脚本,其中自动将protoc
命令进行了拼接,识别了需要的*.proto
文件和当前目录下的proto
文件,最终会拼接为如下命令进行执行:
export $KRATOS_HOME = kratos路径
export $KRATOS_DEMO = 项目路径
// 生成:api.pb.go
protoc -I$GOPATH/src:$KRATOS_HOME/tool/protobuf/pkg/extensions:$KRATOS_DEMO/api --gogofast_out=plugins=grpc:$KRATOS_DEMO/api $KRATOS_DEMO/api/api.proto
// 生成:api.bm.go
protoc -I$GOPATH/src:$KRATOS_HOME/tool/protobuf/pkg/extensions:$KRATOS_DEMO/api --bm_out=$KRATOS_DEMO/api $KRATOS_DEMO/api/api.proto
// 生成:api.swagger.json
protoc -I$GOPATH/src:$KRATOS_HOME/tool/protobuf/pkg/extensions:$KRATOS_DEMO/api --bswagger_out=$KRATOS_DEMO/api $KRATOS_DEMO/api/api.proto
大家也可以参考该命令进行proto
生成,也可以参考protobuf官方参数。
kratos tool swagger
kratos tool swagger serve api/api.swagger.json
执行命令后,浏览器会自动打开swagger文档地址。
同时也可以查看更多的 go-swagger 官方参数进行使用。