go微服务示例(k8s istio grpc swagger postgres增量更新sql等功能)

xiaomeng · · 1351 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

## [github地址](https://github.com/xiaomeng79/istio-micro): https://github.com/xiaomeng79/istio-micro ## istio-micro [![Build Status](https://travis-ci.org/xiaomeng79/istio-micro.svg?branch=master)](https://travis-ci.org/xiaomeng79/istio-micro) [![codecov](https://codecov.io/gh/xiaomeng79/istio-micro/branch/master/graph/badge.svg)](https://codecov.io/gh/xiaomeng79/istio-micro) #### 使用go-micro构建微服务示例请到一下仓库 [go-example](https://github.com/xiaomeng79/go-example) ### 介绍 通过一个前后台都可以操作的用户接口,对用户服务进行操作 这是一个使用服务网格(istio)构建微服务的使用示例 ### 技术栈 |技术|描述| |---|---| |grpc+protobuf|服务层之间的通讯| |echo|应用层接口暴露| |mysql|存储层| |redis|缓存层| |kafka|服务之间异步通讯| |jaeger|链路跟踪| |EFK|日志收集存储查询(没涉及,只把日志打到文件)[go-log](https://github.com/xiaomeng79/go-log)| |statik|静态文件打包| |metric|监控报警(influxdb+grafana)| |docker-compose|容器部署| |istio|流量控制,服务降级,跟踪,服务发现,分流等| ### 模块 - api_backend 后台操作用户数据的RESTful接口 - api_frontend 前台查询用户的接口 - srv_user 用户服务 - srv_socket 推送服务 - srv_account 账户服务 ### 快速演示(docker-compose) ### 安装流程 - 依赖安装 go >=1.11 docker-compose >=1.19 ```go 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 ``` - 可选安装 istio >=1.1 k8s >=1.12 - 下载代码 ```go https://github.com/xiaomeng79/istio-micro.git ``` - 编译代码 ```go make allbuild ``` - 运行代码 ```go make compose up ``` #### 测试 1. 浏览器打开消息推送窗口`http://127.0.0.1:5002/public/` 2. 打开命令行插入mysql一条数据 ```go 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"}' ``` 也可使用grpc-gateway(网关端口:9998)发送信息 ```bash curl -X POST \ http://127.0.0.1:9998/user \ -H 'Cache-Control: no-cache' \ -H 'Content-Type: application/json' \ -d '{"user_name":"meng","iphone":"18201420251","sex":1,"password":"123456"}' ``` 3. 查看消息推送窗口是否有变化 #### 目录介绍 |技术|描述| |---|---| |api|api接口| |cinit|配置和初始化文件| |cmd|程序入口| |deployments|部署文件(docker,k8s,istio)| |internal|内部公共文件| |scripts|脚本文件| |srv|服务| #### 自动化 Makefile ```go //格式化代码 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 //打包静态文件 make builddata //提交代码到远程仓库 make push msg="提交信息" //开启代码性能分析(如type为api,project为frontend) make pprofon type=api project=frontend //关闭代码性能分析(如type为api,project为frontend) make pprofoff type=api project=frontend // 清空编译 make clean ``` #### 命令行 ```bash # 每个执行程序,可以查看版本和提交信息,如:srv_user ./srv_user version ``` #### 增量更新sql 原理:通过在程序上,加上版本号如:`v1.0.1`,在数据库记录上一个更新程序程序版本号如:`v0.1.1`,程序启动会判断更新记录,并将中间的版本号的sql,按照版本号从小 到大排序后,依次执行,执行完成后并更新数据库版本号为最新的版本号 [增量更新sql文件说明](./srv/account/README.md) #### 监控报警 influxdb提供采集数据存储,grafana提供数据展示,报警 http://127.0.0.1:3000 账号密码:admin ```bash # 新建数据源(influxdb) 地址:http://influxdb:8086 # 导入度量的信息(deployments/config/metrics/gc.json) 可以查看gc和内存信息 ``` #### 代码性能分析(可以线上临时开启分析) [pprof封装库](./pkg/pprof) 程序运行的时候会生成进程id(默认在运行目录下server.pid),通过kill命令发送一个信号(默认10)到程序**开启**性能分析,kill命令发送一个信号(默认12)到程序**关闭**性能分析 ```shell //比如进程id:3125 kill -10 3125 //开启代码性能分析 go tool pprof http://127.0.0.1:38888/debug/pprof/goroutine //goroutine go tool pprof http://127.0.0.1:38888/debug/pprof/heap //heap go tool pprof http://127.0.0.1:38888/debug/pprof/profile //profile kill -12 3125 //关闭代码性能分析 ``` #### 生成文档(swagger) ```bash # 安装grpc-gateway go get -u github.com/grpc-ecosystem/grpc-gateway/protoc-gen-grpc-gateway # 安装文档生成 go get -u github.com/grpc-ecosystem/grpc-gateway/protoc-gen-swagger # 生成网关和文档 make proto # 本地文档地址(istio-micro/deployments/config/swagger/srv/user/proto/user.swagger.json) # 在线文档地址(http://127.0.0.1:9998/swagger/user.swagger.json) # 可以使用swagger-ui(http://editor.swagger.io/)查看 ``` #### k8s部署 - 本地安装测试k8s [minikube](https://github.com/kubernetes/minikube) - k8s安装kafka [kubernetes-kafka](https://github.com/Yolean/kubernetes-kafka) - k8s安装redis,mysql [k8s-install-scripts](https://github.com/zhuchuangang/k8s-install-scripts) - k8s安装jaeger [jaeger-kubernetes](https://github.com/jaegertracing/jaeger-kubernetes) `kubectl create -f https://raw.githubusercontent.com/jaegertracing/jaeger-kubernetes/master/all-in-one/jaeger-all-in-one-template.yml` ```go 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流量控制 执行deployments/k8s目录下各个network文件和网关文件 #### TODO - 完善istio其他配置文件

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1351 次点击  ∙  1 赞  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传