Golang 下的微服务 - 第 5 部分 - Go Micro 的事件代理
yuyutoo 2024-10-13 09:10 5 浏览 0 评论
在本系列的Golang 中的微服务-第 4 部分-使用 JWT 做认证,我们谈到了用户认证和 JWT。在这一部分中,我们将快速浏览 go-micro 的代理功能。
正如前面的文章提到的,go-micro 是一个可插拔的框架,它连接了许多不同的常用技术。如果你看看插件仓库,你会看到它支持多少插件。
在我们的例子中,我们将使用 NATS 代理插件。
基于事件驱动的架构
事件驱动的架构是一个非常简单的概念。我们通常认为好的架构是要解耦的,一个服务不应该与其他服务耦合或者感知到其他服务。当我们使用诸如 gRPC 协议时,在某些情况下是正确的,我们以向 go.srv.user-service 发布请求为例。其中就使用了服务发现的方式来查找该服务的实际位置。 尽管这并不直接将我们与实现耦合,但它确实将该服务耦合到了其他名为 go.srv.user-service 的服务,因此它不是完全的解耦,因为它直接与其他服务进行交互。
那么什么让事件驱动架构真正的解耦呢?为了理解这一点,我们首先看看发布和订阅事件的过程。服务 a 完成了一项任务 x,然后向系统发布一个事件 x 刚刚发生了。服务并不需要知道或者关心谁在监听这个事件,或者该事件正在发生什么影响。这些事情留给了监听事件的客户端。如果你期待 n 个服务对某个事件采取行动,那么也很容易。例如,你想 12 个不同的服务针对使用 gRPC 创建新用户采取行动,可能需要在用户服务中实例化 12 个客户端。而借助事件发布订阅或事件驱动架构,你的服务就不需要关心这些。
现在,客户端服务只需要简单的监听事件。这意味着,你需要中间的介质来接收这些事件,并通知订阅了事件的客户端。
这篇文章中,我们将在每次创建用户时创建一个事件,并且将创建一个用于发送电子邮件的新服务。我们不会真的去实现发邮件的功能,只是模拟它。
代码
首先,我们需要将 NATS 代理插件集成到我们的用户服务中:
现在让我们在创建新用户时发布事件(请参阅此处的完整更改)
确保你正在运行 Postgres,然后让我们运行这个服务:
现在我们创建我们的电子邮件服务。 我为此创建了一个新的仓库:
在运行之前,我们需要启动 NATS...
$ docker run -d -p 4222:4222 nats
另外,我想快速解释一下 go-micro 的一部分,我觉得这对于理解它作为框架如何工作很重要。你会注意到:
让我们来快速浏览一下。当我们用 go-micro 创建服务时,srv.Init() 会自动去查找所有的配置,例如所有配置的插件、环境变量或命令行选项。它将会将这些集成实例化为服务的一部分。为了使用这些实例,我们需要将它们从服务中提取出来。在 srv.Server().Options() 中,你还可以找到 Transport (go-micro 框架的一个核心组件,传输是服务之间的同步请求/响应通信的接口) 和 Registry (go-micro 框架的一个核心组件,叫注册表,提供了一个服务发现机制来将名称解析为地址)。
在我们的例子中,会用到 GO_MICRO_BROKER 环境变量,会用到 NATS 代理插件,并创建一个该插件的实例,准备好我们连接和使用。
如果你正在创建一个命令行工具,你可以使用 cmd.Init(),确保你导入了 github.com/micro/go-micro/cmd。这会产生同样的影响。
现在构建并运行此服务:$ make build && make run,确保你也在运行用户服务。然后转到 shippy-user-cli 项目,并运行 $ make run,看我们的电子邮件服务输出。你应该看到类似... 2017/12/26 23:57:23 Sending email to: Ewan Valentine
就是这样!这是一个简单的例子,因为我们的电子邮件服务隐式地收听单个 user.created 事件,但希望你能看到这种方法如何让你编写解耦的服务。
值得一提的是,使用 JSON over NATS 会比 gRPC 带来更高的性能开销,因为我们已经回到串行化json字符串的领域。但是,对于某些使用情况,这是完全可以接受的。 NATS 非常高效,非常适合消息最多交付一次的事件(fire and forget 有消息最多交付一次的意思,这个链接可以帮助做更深入的理解)。
Go-micro 还支持一些最广泛使用的队列 / pubsub 技术供你使用。你可以在这里看到它们的列表。你不需要改变你的实现因为 go-micro 为你提供了抽象。你只需要将环境变量从 MICRO_BROKER=nats 更改为 MICRO_BROKER=googlepubsub,然后将 main.go 的导入从 _ "github.com/micro/go-plugins/broker/nats"更改为 _ "github.com/micro/go-plugins/broker/googlepubsub"。
如果你不使用 go-micro,那么有一个 NATS go 库(NATS 是用 go 写的,所以对 Go 的支持非常稳固)。
发布一个事件:
订阅一个事件:
我之前提到过,在使用第三方消息代理(如 NATS)时,会失去对 protobuf 的使用。这是一种耻辱,因为我们失去了使用二进制流进行通信的能力,这当然比串行化的 JSON 字符串的开销要低得多。 但是,像大多数人所关心的那样,go-micro 也可以解决这个问题。
内置 go-micro 是 pubsub 层,位于代理层之上,但不需要第三方代理(如 NATS)。 但是这个功能真正棒的部分在于它利用了 protobuf 的定义。 所以我们回到了低延迟二进制流的领域。 因此,让我们更新我们的用户服务,用 go-micro 的 pubsub 替换现有的 NATS 代理:
现在我们在我们的服务中使用我们的底层 User protobuf 定义,通过 gRPC,并且不使用第三方代理。太棒了!
这是一个包装! 接下来的教程我们将着眼于为我们的服务创建一个用户界面,并研究 Web 客户端如何开始与我们的服务进行交互。
本文中的任何错误、反馈,或任何您会发现有用的东西,请给我发电子邮件。
via: https://ewanvalentine.io/microservices-in-golang-part-5/
作者:André Carvalho 译者:shniu 校对:polaris1119
本文由 GCTT 原创编译,Go语言中文网 荣誉推出
相关推荐
- 微软Win10/Win11版Copilot上线:支持OpenAI o3推理模型
-
IT之家4月3日消息,科技媒体WindowsLatest昨日(4月2日)发布博文,报道称Windows10、Windows11新版Copilot应用已摘掉Beta帽...
- WinForm 双屏幕应用开发:原理、实现与优化
-
在当今的软件开发领域,多屏幕显示技术的应用越来越广泛。对于WinForm应用程序来说,能够支持双屏幕显示不仅可以提升用户体验,还能满足一些特定场景下的业务需求,比如在演示、监控或者多任务处理等场景...
- OpenJDK 8 安装(openjdk 8 windows)
-
通常OpenJDK8和11都能互相编译和通用。我们建议使用11,但是如果你使用JDK8的话也是没有问题的。建议配置使用OpenJDK,不建议使用OracleJDK,主要是因为版...
- 基于 Linux 快速部署 OpenConnect VPN 服务(ocserv 实战指南)
-
一、前言在如今远程办公和内网穿透需求日益增长的背景下,搭建一套安全、稳定、高效的VPN系统显得尤为重要。OpenConnectServer(ocserv)是一个开源、高性能的VPN服务端软件...
- 巧妙设置让Edge浏览器更好用(edge怎么设置好用)
-
虽然现在新版本的Edge浏览器已经推出,但是毕竟还处于测试的状态中。而Win10系统里面自带的老版Edge浏览器,却越来越不被人重视。其实我们只需要根据实际情况对老版本的Edge浏览器进行一些简单的设...
- 微软开源博客工具Open Live Writer更新:多项Bug修复
-
OpenLiveWriter前身是WindowsLiveWriter,是微软WindowsLive系列软件之一,曾经是博主们非常喜爱的一款所见即所得博文编辑工具,支持离线保存,还支持图像编辑...
- 基于OpenVINO的在线设计和虚拟试穿 | OPENAIGC大赛企业组优秀作品
-
在第二届拯救者杯OPENAIGC开发者大赛中,涌现出一批技术突出、创意卓越的作品。为了让这些优秀项目被更多人看到,我们特意开设了优秀作品报道专栏,旨在展示其独特之处和开发者的精彩故事。...
- Python open函数详解(python open函数源码)
-
演示环境,操作系统:Win1021H2(64bit);Python解释器:3.8.10。open是Python的一个内置函数,一般用于本地文件的读写操作。用法如下。my_file=open(fi...
- 世界上最好用的Linux发行版之一,OpenSUSE安装及简单体验
-
背景之前无意在论坛里看到openSUSE的Linux发行版,被称为世界上最好用的Linux发行版之一(阔怕),一直想体验一下,于是这期做一个安装和简单体验教程吧。...
你 发表评论:
欢迎- 一周热门
-
-
前端面试:iframe 的优缺点? iframe有那些缺点
-
带斜线的表头制作好了,如何填充内容?这几种方法你更喜欢哪个?
-
漫学笔记之PHP.ini常用的配置信息
-
其实模版网站在开发工作中很重要,推荐几个参考站给大家
-
推荐7个模板代码和其他游戏源码下载的网址
-
[干货] JAVA - JVM - 2 内存两分 [干货]+java+-+jvm+-+2+内存两分吗
-
正在学习使用python搭建自动化测试框架?这个系统包你可能会用到
-
织梦(Dedecms)建站教程 织梦建站详细步骤
-
【开源分享】2024PHP在线客服系统源码(搭建教程+终身使用)
-
2024PHP在线客服系统源码+完全开源 带详细搭建教程
-
- 最近发表
-
- 微软Win10/Win11版Copilot上线:支持OpenAI o3推理模型
- WinForm 双屏幕应用开发:原理、实现与优化
- 推荐一个使用 C# 开发的 Windows10 磁贴美化小工具
- OpenJDK 8 安装(openjdk 8 windows)
- 基于 Linux 快速部署 OpenConnect VPN 服务(ocserv 实战指南)
- 巧妙设置让Edge浏览器更好用(edge怎么设置好用)
- WPF做一个漂亮的登录界面(wpf页面设计)
- 微软开源博客工具Open Live Writer更新:多项Bug修复
- 基于OpenVINO的在线设计和虚拟试穿 | OPENAIGC大赛企业组优秀作品
- C#开源免费的Windows右键菜单管理工具
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)