傳送門 istio-micro
istio-micro
使用go-micro構建微服務示例請到一下倉庫
介紹
通過一個前后臺都可以操作的用戶接口,對用戶服務進行操作
這是一個使用服務網(wǎng)格(istio)構建微服務的使用示例
技術棧
技術 | 描述 |
---|---|
grpc+protobuf | 服務層之間的通訊 |
echo | 應用層接口暴露 |
mysql | 存儲層 |
redis | 緩存層 |
kafka | 服務之間異步通訊 |
jaeger | 鏈路跟蹤 |
EFK | 日志收集存儲查詢(沒涉及,只把日志打到文件)go-log |
statik | 靜態(tài)文件打包 |
docker-compose | 容器部署 |
istio | 流量控制,服務降級,跟蹤,服務發(fā)現(xiàn),分流等 |
模塊
- api_backend 后臺操作用戶數(shù)據(jù)的RESTful接口
- api_frontend 前臺查詢用戶的接口
- srv_user 用戶服務
- srv_socket 推送服務
快速演示
安裝流程
- 依賴安裝
go >=1.11
docker-compose
go get -u github.com/golang/protobuf/proto
go get -u github.com/golang/protobuf/protoc-gen-go
go get -u github.com/rakyll/statik
- 下載代碼
https://github.com/xiaomeng79/istio-micro.git
- 編譯代碼
make allbuild
- 運行代碼
make compose up
測試
瀏覽器打開消息推送窗口
http://127.0.0.1:5002/public/
打開命令行插入mysql一條數(shù)據(jù)
curl -X POST \
http://127.0.0.1:8888/backend/v1/user \
-H 'Cache-Control: no-cache' \
-H 'Content-Type: application/json' \
-d '{"user_name":"meng","iphone":"18201420251","sex":1,"password":"123456"}'
- 查看消息推送窗口是否有變化
目錄介紹
技術 | 描述 |
---|---|
api | api接口 |
cinit | 配置和初始化文件 |
cmd | 程序入口 |
deployments | 部署文件(docker,k8s,istio) |
internal | 內部公共文件 |
scripts | 腳本文件 |
srv | 服務 |
自動化
Makefile
//格式化代碼
make fmt
//vendor
make vendor
//代碼測試,代碼檢查
make test
//編譯單個服務
make build type=srv project=user
//編譯全部服務
make allbuild
//protobuf
make proto
//生成單個dockerfile
make dockerfile type=srv project=user
//生成全部dockerfile
make alldockerfile
//docker-compose部署
make compose up
//打包靜態(tài)文件
make builddata
//提交代碼到遠程倉庫
make push msg="提交信息"
k8s部署
kubectl apply -f deployments/k8s/api_backend/dev.yaml
kubectl apply -f deployments/k8s/api_frontend/dev.yaml
kubectl apply -f deployments/k8s/srv_user/dev.yaml
kubectl apply -f deployments/k8s/srv_socket/dev.yaml
istio部署
待完善
在k8s部署的基礎上,執(zhí)行deployments/k8s目錄下各個network文件和網(wǎng)關文件
TODO
- 完善istio配置文件
- 支持swagger接口文檔生成