/starter-kit

Quick Go-Micro 快速开发包

Primary LanguageGo

Micro 快速开发工具包项目进行中

本仓库旨在提供面向Go-Micro生产环境的快速开发包。项目结合维护者们十余年的工作经验,不同领域的实战沉淀,一切为了缩短大家的选型、开发周期。

目录

快速开始

Go环境

go 1.13

export GOSUMDB=off
export GOPROXY=https://mirrors.aliyun.com/goproxy/,direct

运行网关

micro api网关

$ cd gateway

# 编译
$ make build

# API网关(二选一)
$ make run_api                                  # 默认mdns + http
$ make run_api registry=etcd transport=tcp      # 使用etcd + tcp

# Web网关(二选一)
$ make run_web                                  # 默认mdns + http
$ make run_web registry=etcd transport=tcp      # 使用etcd + tcp

运行服务

  • Web应用
    • app/console/web控制台
  • 聚合API
    • app/console/api控制台
  • 基础服务
    • srv/account账户

注:registrytransport选择与网关一致

$ cd {指定服务目录}

# 运行服务(二选一)
$ make build run                                # 默认mdns + http
$ make build run registry=etcd transport=tcp    # 使用etcd + tcp

服务测试

注:console API由于有认证不能直接访问

Makefile说明

$ make build                                    # 编译
$ make run                                      # 运行
$ make run registry=etcd transport=tcp          # 运行,指定registry、transport

$ make build run                                # 编译&运行
$ make build run registry=etcd transport=tcp    # 编译&运行,指定registry、transport

$ make vue statik                               # 前端编译,并打包statik.go文件

$ make docker tag=xxx/xxx:v0.0.1

可选服务

Jaeger

浏览器访问:http://localhost:16686/

$ docker run -d --name=jaeger -e COLLECTOR_ZIPKIN_HTTP_PORT=9411 -p5775:5775/udp -p6831:6831/udp -p6832:6832/udp   -p5778:5778 -p16686:16686 -p14268:14268 -p9411:9411 jaegertracing/all-in-one:latest
Prometheus

浏览器访问:http://localhost:9090/

prometheus.yml参考gateway插件`metrics/prometheus.yml

$ docker run -d --name prometheus -p 9090:9090 -v ~/tmp/prometheus.yml:/etc/prometheus/prometheus.yml prom/prometheus
Grafana

浏览器访问:http://localhost:3000/

Grafana仪表盘importmetrics/grafan.json

$ docker run --name grafana -d -p 3000:3000 grafana/grafana

目标

架构设计

目录结构

├── app                 应用,API聚合、Web应用
│   ├── console         控制台
│   │   ├── api         go.micro.api.*,API
│   │   └── web         go.micro.web.*,Web,集成gin、echo、iris等web框架
│   ├── mobile          移动端
│   └── openapi         开放API
├── deploy              部署
│   ├── docker
│   └── k8s
├── doc                 文档资源
├── gateway             网关,自定义micro
├── pkg                 公共资源包
└── srv                 基础服务
    ├── account         账户服务,领域模型整洁架构示例
    │   ├── domain              领域
    │   │   ├── model           模型
    │   │   ├── repository      存储接口
    │   │   │   └── persistence ①存储接口实现   
    │   │   └── service         领域服务
    │   ├── interface           接口
    │   │   ├── handler         micro handler接口
    │   │   └── persistence     ②存储接口实现
    │   ├── registry            依赖注入,根据使用习惯,一般Go中不怎么喜欢这种方式
    │   └── usecase             应用用例
    │       ├── event           消息事件
    │       ├── service         应用服务
    ├── example         micro srv不同场景示例
    └── pb              基础服务协议统一.proto

系统架构图

业务架构图

TODO

领域模型&整洁架构参考

部署

Kubernetes环境

贡献

代码格式

  • IDE IDEA/Goland,Go->imports 设置
    • Sorting type gofmt
    • Group stdlib imports
      • Move all stdlib imports in a single group
    • Move all imports in a single declaration