装置
1.git clone https://github.com/ifconfigur...
2.go mod download
简介
联合了go-kit和grpc的学习应用,go-kit因为分层的关系,会使得代码生涩难读,再加上go-kit个别是配合gRpc应用,所以便有了这个demo。
能够应用它作为我的项目的初始化框架,在分层的体系上尽量放弃了精简,只须要略微花点工夫了解一下每层的意义,便能够疾速进行微服务开发。
TODO: 前期会引入服务注册/发现,熔断,降级,链路追踪,感激敌人star????一波
如果想运行纯GRPC的DEMO
1.启动gRPC Server
1) cd gRpc
2) go build grpc-server.go
3) ./grpc-server
2.启动gRPC Client
1) go build grpc-client.go
2) ./grpc-client
如果想运行go-kit + gRpc的demo
1) cd go-kit
2) go build rpc-server.go
3) ./rpc-server
4) 切换到grpc目录下编译并启动grpc-client,例:./grpc-client
目录构造形容
├── go-kitgo-kit的次要目录, go-kit的分层思维和微服务都应该写在这外面
│ ├── EndPoint负责业务逻辑,并且返回给Handler
│ ├── Handler负责调用EndPoint,也就是把EndPoint和TransPort层封装起来,并且返回给grpc调用,能够了解为中间人
│ ├── TransPort跟go-kit的思维一样,就是负责数据传入的解决,比方传入测验等
├── gRpcgrpc的业务逻辑
│ ├── PB生成的PB文件放这里
│ ├── ProtoProto3原始文件,为什么和PB要分凋谢是因为能够独自共享proto文件给其它团队生成调用
│ ├── Service这里能够独自写grpc里的业务逻辑,是和go-kit离开的,如果在go-kit的endpoint写了业务就不必在这里写,当然也能够在这里写业务通过endpoint调用
├── main.go暂无用