今天给大家推荐一款适合入门学习使用的微服务框架go-garden。
相对于go-micro、go-zero等重量级框架,这款框架非常轻量化,使用起来非常简单,而且常见的特性都支持。

go-garden是一款面向分布式系统架构的分布式服务框架

概念

为分布式系统架构的开发提供了核心需求,包括微服务的一些基础架构支持,减少开发者对微服务的基础开发,更着力于业务开发;
支持Http/Rpc协议,http框架使用gin,rpc框架使用rpcx;
rpc无需protobuf,只需要定义结构体即可;
没有集成数据库、缓存之类的扩展,这里考虑到使用者对服务的设计可能会使用到不同的包,建议开发者自己导入这类扩展包使用;
不限制代码结构,只需要配置文件和几行代码就可以启动一个服务,项目的结构完全由开发者自行设计,建议大家使用脚手架工具生成项目结构。

特性

服务注册发现

网关路由分发

网关负载均衡

Rpc/Http协议

-可配服务限流

-可配服务熔断

可配服务重试

可配超时控制

动态路由配置

集群自动同步

调用安全认证

分布式链路追踪

统一日志存储

脚手架工具


快速开始

// 安装项目脚手架
go install github.com/panco95/go-garden/tools/garden@v1.1.4

// 创建项目
garden new my-gateway gateway
garden new my-service service

// 修改服务配置和路由配置

// 启动网关
go run my-gateway/main.go
// 启动服务
go run my-service/main.go