2019-04-17 12:30:59 +08:00
|
|
|
# 快速开始
|
|
|
|
|
2020-10-28 15:48:00 +08:00
|
|
|
**在安装之前,请确认您的开发环境中正确安装了[golang](https://golang.org/), [git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git), 和[protoc](https://grpc.io/docs/protoc-installation/)**
|
|
|
|
|
|
|
|
创建kratos项目,可以使用`kratos`工具,如下:
|
2019-04-17 12:30:59 +08:00
|
|
|
|
|
|
|
```shell
|
2020-03-28 18:02:25 +08:00
|
|
|
go get -u github.com/go-kratos/kratos/tool/kratos
|
2019-04-27 22:08:06 +08:00
|
|
|
cd $GOPATH/src
|
|
|
|
kratos new kratos-demo
|
2019-04-17 12:30:59 +08:00
|
|
|
```
|
2019-04-27 22:08:06 +08:00
|
|
|
|
2020-03-28 18:02:25 +08:00
|
|
|
根据提示可以快速创建项目,如[kratos-demo](https://github.com/go-kratos/kratos-demo)就是通过工具创建生成。目录结构如下:
|
2019-04-17 12:30:59 +08:00
|
|
|
|
|
|
|
```
|
2019-11-03 18:13:52 +08:00
|
|
|
├── CHANGELOG.md
|
|
|
|
├── OWNERS
|
|
|
|
├── README.md
|
|
|
|
├── api # api目录为对外保留的proto文件及生成的pb.go文件
|
|
|
|
│ ├── api.bm.go
|
|
|
|
│ ├── api.pb.go # 通过go generate生成的pb.go文件
|
2019-04-17 12:30:59 +08:00
|
|
|
│ ├── api.proto
|
2019-11-03 18:13:52 +08:00
|
|
|
│ └── client.go
|
|
|
|
├── cmd
|
|
|
|
│ └── main.go # cmd目录为main所在
|
|
|
|
├── configs # configs为配置文件目录
|
|
|
|
│ ├── application.toml # 应用的自定义配置文件,可能是一些业务开关如:useABtest = true
|
|
|
|
│ ├── db.toml # db相关配置
|
|
|
|
│ ├── grpc.toml # grpc相关配置
|
|
|
|
│ ├── http.toml # http相关配置
|
|
|
|
│ ├── memcache.toml # memcache相关配置
|
|
|
|
│ └── redis.toml # redis相关配置
|
|
|
|
├── go.mod
|
|
|
|
├── go.sum
|
|
|
|
└── internal # internal为项目内部包,包括以下目录:
|
|
|
|
│ ├── dao # dao层,用于数据库、cache、MQ、依赖某业务grpc|http等资源访问
|
|
|
|
│ │ ├── dao.bts.go
|
|
|
|
│ │ ├── dao.go
|
|
|
|
│ │ ├── db.go
|
|
|
|
│ │ ├── mc.cache.go
|
|
|
|
│ │ ├── mc.go
|
|
|
|
│ │ └── redis.go
|
|
|
|
│ ├── di # 依赖注入层 采用wire静态分析依赖
|
|
|
|
│ │ ├── app.go
|
|
|
|
│ │ ├── wire.go # wire 声明
|
|
|
|
│ │ └── wire_gen.go # go generate 生成的代码
|
|
|
|
│ ├── model # model层,用于声明业务结构体
|
|
|
|
│ │ └── model.go
|
|
|
|
│ ├── server # server层,用于初始化grpc和http server
|
|
|
|
│ │ ├── grpc # grpc层,用于初始化grpc server和定义method
|
|
|
|
│ │ │ └── server.go
|
|
|
|
│ │ └── http # http层,用于初始化http server和声明handler
|
|
|
|
│ │ └── server.go
|
|
|
|
│ └── service # service层,用于业务逻辑处理,且为方便http和grpc共用方法,建议入参和出参保持grpc风格,且使用pb文件生成代码
|
|
|
|
│ └── service.go
|
|
|
|
└── test # 测试资源层 用于存放测试相关资源数据 如docker-compose配置 数据库初始化语句等
|
|
|
|
└── docker-compose.yaml
|
2019-04-17 12:30:59 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
生成后可直接运行如下:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cd kratos-demo/cmd
|
|
|
|
go build
|
|
|
|
./cmd -conf ../configs
|
|
|
|
```
|
|
|
|
|
|
|
|
打开浏览器访问:[http://localhost:8000/kratos-demo/start](http://localhost:8000/kratos-demo/start),你会看到输出了`Golang 大法好 !!!`
|
|
|
|
|
2019-04-27 22:08:06 +08:00
|
|
|
[kratos工具](kratos-tool.md)
|
2019-04-17 12:30:59 +08:00
|
|
|
|