Golang 微服务工具包 Go kit

简介: Golang 微服务工具包 Go kit

介绍

Go kit 是 Go 包的集合,可帮助您构建健壮、可靠、可维护的微服务。它最初被设想为一个工具包,以帮助大型(所谓的现代企业)组织采用 Go 作为实现语言。但它很快就"向下增长",现在也为较小的初创公司和组织提供服务。

Go kit 服务分为三层:

  • Transport layer 传输层
  • Endpoint layer 端点层
  • Service layer 服务层

请求在传输层进入服务,向下传输经过端点层到达服务层,响应采用相反的过程。

Transports

Go kit 附带了对 HTTP、gRPC、Thrift 和 net/rpc 的支持。传输域绑定到具体的传输协议,比如 HTTP 或 gRPC。可以让我们的单个微服务同时支持 HTTP API 和 RPC 服务。

Endpoints

Endpoints 类似在 Controller 中的 action 或 handler,用于接收 transports 的请求。

Services

Services 实现核心业务逻辑,它通常将多个 Endpoints 组合在一起。在 Go kit 中,Services 通常会定义接口,通过实现接口去实现业务逻辑。

Services 应该不知道 Endpoints,尤其 Transport-domain 的概念。Services 也应该不知道有关 HTTP headers 或 gRPC 错误码的任何信息。

Middlewares

Go kit 尝试通过使用中间件(装饰器模式)来分离与业务逻辑无关的功能。中间件可以包装 Endpoints 或 Services,来添加功能,例如日志记录、限流、负载均衡或链路跟踪。通常围绕 Endpoints 或 Services 使用多个中间件。

02

Go kit 架构模型

在了解了 Transports、Endpoints、Services 和 Middlewares 的概念后,我们可以发现 Go kit 架构模型类似「洋葱」,包含多层。这些层从内到外可以分组到我们的三个域中。在最内层的 Service 域中,所有内容都基于特定 service 定义,并且所有核心业务逻辑都在 service 中实现;中间层 Endpoint 域是将 Service 的每个方法抽象到通用的 Endpoint;在最外层的 Transport 域是 Endpoints 绑定到 HTTP 或 gRPC。

图片来自 Go kit 官网

我们可以通过为 service 定义 interface,并提供具体实现来实现核心业务逻辑。然后,通过编写 service 中间件添加额外功能,比如日志记录、分析、检测等。

Go kit 提供 Endpoint 域和 Transport 域中间件,用于限流、熔断、负载均衡和链路跟踪等功能。

03

微服务示例

在了解以上关于 Go kit 的知识之后,我们通过一个简单的微服务示例,学习怎么使用 Go kit 开发项目。

项目包含服务端和客户端,并采用 Consul 作为服务注册与发现组件。

代码目录:

.
├── README.md
├── client
│   ├── endpoint
│   ├── main.go
│   └── transport
├── go.mod
├── go.sum
└── server
    ├── config
    ├── endpoint
    ├── main.go
    ├── service
    └── transport

完整代码,请参阅 Github。

04

总结

本文我们介绍 Golang 微服务工具包 Go kit 的基础知识和架构设计,并提供了一个简单的微服务示例代码,读者朋友们在了解 Go kit 之后,可以通过阅读代码,学习怎么使用 Go kit 开发项目。

推荐阅读:

参考资料:

https://gokit.io/faq/#architecture-and-design 

https://pkg.go.dev/github.com/go-kit/kit@v0.12.0 


目录
相关文章
|
4月前
|
监控 算法 NoSQL
Go 微服务限流与熔断最佳实践:滑动窗口、令牌桶与自适应阈值
🌟蒋星熠Jaxonic:Go微服务限流熔断实践者。分享基于滑动窗口、令牌桶与自适应阈值的智能防护体系,助力高并发系统稳定运行。
Go 微服务限流与熔断最佳实践:滑动窗口、令牌桶与自适应阈值
|
4月前
|
Java 编译器 Go
【Golang】(1)Go的运行流程步骤与包的概念
初次上手Go语言!先来了解它的运行流程吧! 在Go中对包的概念又有怎样不同的见解呢?
250 4
|
4月前
|
Java 编译器 Go
【Golang】(5)Go基础的进阶知识!带你认识迭代器与类型以及声明并使用接口与泛型!
好烦好烦好烦!你是否还在为弄不懂Go中的泛型和接口而烦恼?是否还在苦恼思考迭代器的运行方式和意义?本篇文章将带你了解Go的接口与泛型,还有迭代器的使用,附送类型断言的解释
244 3
|
4月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
276 1
|
JavaScript Java Go
探索Go语言在微服务架构中的优势
在微服务架构的浪潮中,Go语言以其简洁、高效和并发处理能力脱颖而出。本文将深入探讨Go语言在构建微服务时的性能优势,包括其在内存管理、网络编程、并发模型以及工具链支持方面的特点。通过对比其他流行语言,我们将揭示Go语言如何成为微服务架构中的一股清流。
321 53
|
7月前
|
设计模式 Kubernetes Go
​​什么是Golang项目的“主包精简,逻辑外置”?​
“主包精简,逻辑外置”是Go语言项目的一种设计原则,强调将程序入口保持简单,核心逻辑拆分至其他包,以提升代码可维护性、可测试性及扩展性,适用于CLI工具、Web服务等场景。
167 7
|
7月前
|
人工智能 测试技术 持续交付
Golang深入浅出之-Go语言中的持续集成与持续部署(CI/CD)
持续集成与持续部署(CI/CD)是现代软件开发的关键实践,尤其适用于Go语言项目。本文探讨了Go项目中常见的CI/CD问题,如测试覆盖不足、版本不一致和构建时间过长,并提供解决方案及GitHub Actions示例代码,帮助开发者优化流程,提升交付效率和质量。
240 5
|
12月前
|
Shell Go 开发工具
【环境】Rocky8使用gvm配置Go多版本管理的微服务开发环境(go-zero)
通过本文的介绍,我们详细讲解了如何在Rocky8上使用gvm来管理多个Go版本,并配置go-zero框架的开发环境。通过gvm的灵活管理,开发者可以轻松切换不同的Go版本,以适应不同项目的需求。同时,go-zero框架的使用进一步提升了微服务开发的效率和质量。希望本文能帮助开发者构建高效的Go语言开发环境,提高项目开发的灵活性和稳定性。
375 63
|
11月前
|
Go 开发者
go-carbon v2.6.0 重大版本更新,轻量级、语义化、对开发者友好的 golang 时间处理库
carbon 是一个轻量级、语义化、对开发者友好的 Golang 时间处理库,提供了对时间穿越、时间差值、时间极值、时间判断、星座、星座、农历、儒略日 / 简化儒略日、波斯历 / 伊朗历的支持
237 3
|
JSON Go 开发者
go-carbon v2.5.0 发布,轻量级、语义化、对开发者友好的 golang 时间处理库
carbon 是一个轻量级、语义化、对开发者友好的 Golang 时间处理库,提供了对时间穿越、时间差值、时间极值、时间判断、星座、星座、农历、儒略日 / 简化儒略日、波斯历 / 伊朗历的支持。
300 4

推荐镜像

更多