微服务架构Gin-etcd-gRPC接合的入门实践

最近在学习微服务,先后学习gRPC、etcd。学习过这两个技术之后,结合Gin框架,简单实现了一个微服务的小demo了。
以下是各技术在微服务架构中的功能。

  • Gin框架作为网关,外部请求的统一出口。负责将外部的HTTP请求转化为RPC请求,并转发给对应模块的RPC方法进行处理。
  • etcd储存和监听服务模块的ip和port信息。负责服务注册和服务发现。
  • gRPC微服务系统内部的通信方式。

项目地址:

GIn_etcd_gRPC: 使用Gin_etcd_gRPC实现的一个微服务的架构的小demo (gitee.com)

项目目录: 

 

 项目一共有四个模块,每一个模块都是单独的服务,可以独立打包部署。

  • serviceHub服务中心,主要负责服务注册和服务发现,对外提供etcd的读写RPC方法。
  • gateway网关,使用Gin,相当于外部HTTP和内部gRPC的桥梁,主要负责将外部的HTTP请求转换转发给对应模块的RPC方法并将结果返回给客户端。
  • user、post业务模块,负责具体处理请求,并将结构返回给调用者。

项目中的端口信息:

  • etcd:127.0.0.1:2379
  • serviceHub:127.0.0.1:8004
  • post:127.0.0.1:8005
  • user:127.0.0.1:8006
  • gateway:127.0.0.1:8008

注意项目的启动顺序,先启动etcd,之后启动serviceHub、然后是post、user、gateway。

项目调用流程图:

 在getway当中,我们需要进行路由注册,将路径和对应的处理方法关联起来。因此,我们需要进行服务发现和服务调用。让/user/login请求路径被user模块的login方法所处理。具体看仓库中的路由注册的代码。

func main() {r := gin.Default()//1. 获取服务注册与发现的模块信息DiscoveryConn, err := grpc.Dial("127.0.0.1:8004", grpc.WithTransportCredentials(insecure.NewCredentials()))if err != nil {log.Fatalf("get DiscoveryConn err %v", DiscoveryConn)}discoveryClient := discoveryPb.NewDiscoveryClient(DiscoveryConn)_, err = discoveryClient.WatchService(context.Background(), &discoveryPb.Prefix{Prefix: "/"})if err != nil {log.Fatal("watch prefix / is error:", err)}//进行路由注册router.Register(r, discoveryClient)//启动服务r.Run("127.0.0.1:8008")
}
func Register(r gin.IRouter, client discoveryPb.DiscoveryClient) {userRouter(r, client)postRouter(r, client)
}func userRouter(r gin.IRouter, client discoveryPb.DiscoveryClient) {userGroup := r.Group("/user")//通过 服务发现 获取/user模块的ip和端口信息,之后创建user模块的RPC客户端,让服务端处理对应的请求。//由于使用的是Gin框架,因此,在路径对应Handle方法中调用服务端的请求.userModelInfo, userErr := client.GetServices(context.Background(), &discoveryPb.ServiceName{Name: "/user"})if userErr != nil {log.Fatalf("get userServiceInfo error %v", userErr)}userModelConn, userConnErr := grpc.Dial(userModelInfo.Address, grpc.WithTransportCredentials(insecure.NewCredentials()))if userConnErr != nil {log.Fatalf("get userServiceInfo error %v", userConnErr)}userClient := userPb.NewUserClient(userModelConn)//user模块的路由注册.user := api.User{Client: userClient}userGroup.POST("/login", user.Login)userGroup.POST("/register", user.Register)
}
type User struct {Client userPb.UserClient
}func (u *User) Register(c *gin.Context) {registerInfo := userRegLog{}if err := c.ShouldBindJSON(&registerInfo); err != nil {log.Fatalf("get userLogin info err, %v", err)}res, err := u.Client.UserRegister(context.Background(), &userPb.LoginOrRegisterInfo{PhoneNumber:  registerInfo.phoneNumber,UserPassword: registerInfo.userPassword,})if err != nil {c.JSON(http.StatusExpectationFailed, res)}c.JSON(http.StatusOK, res)
}

总结:

在编写Demo的过程中,遇到的难点:

构思的难点:整个项目的调用流程,由于第一次接触微服务,对项目内部整体的gRPC调用流程不太熟悉,比如谁去调用业务的gRPC以及什么时候进行服务注册和服务发现。

实现的难点:etcd中的续租和健康检查部分,由于当时对这方法的知识点和API不太熟悉,导致代码编写错误,一直续租失败。

目前自己对微服务的理解:

微服务并不是一个全新的技术,而是一种架构的思想。相比于单体项目的能够方便地进行横向扩容,提高系统整体的处理能力。并且项目的迭代和部署是非常方便的。应用微服务的难点在于项目拆分的粒度以及各服务之间的通信、链路追踪。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1558270.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

量子数字签名概述

我们都知道,基于量子力学原理研究密钥生成和使用的学科称为量子密码学。其内容包括了量子密钥分发、量子秘密共享、量子指纹识别、量子比特承诺、量子货币、秘密通信扩展量子密钥、量子安全计算、量子数字签名、量子隐性传态等。虽然各种技术发展的状态不同&#xf…

YOLOv8实战TT100K中国交通标志检测【数据集+YOLOv8模型+源码+PyQt5界面】

YOLOv8实战TT100k交通标志识别 文章目录 研究背景资源获取1.前言1.1 YOLO 系列:中国交通标志检测领域的璀璨明星1.2 Transformer与注意力机制:为中国交通标志检测注入新活力1.3 中国交通标志检测技术:迎接挑战,砥砺前行1.4 YOLOv8…

『网络游戏』协程回调事件实现Tips弹窗【09】

创建脚本:DynamicWnd.cs 编写脚本:DynamicWnd.cs 修改脚本:WindowRoot.cs - 适配修改错误 修改脚本:GameRoot.cs 拖拽框选 运行项目 - 显示Tips弹窗 本章结束

3.C语言入门:解锁基础概念,动手实现首个C程序

C语言入门:解锁基础概念,动手实现首个C程序 文章目录 C语言入门:解锁基础概念,动手实现首个C程序前言一、源文件和头文件1.1 如何新建项目1.2 添加头文件和源文件 二、第一个C语言程序1.创建一个源文件2.写代码3.运行代码 三、mai…

水库大坝安全监测预警系统守护大坝安全卫士

一、系统背景 近年来,受全球气候变化和人类活动影响,极端天气发生频度强度增加,加之我国城市化进程中,水库下游人口聚集、基础设施密集,对水库工程安全运行提出了新的更高要求。“十四五”以来我国建成并投入使用37593…

微服务架构---认识Zuul

目录 认识Zuul简单的例子 第一个Zuul程序步骤1:创建父工程zuul-1步骤2:创建HystrixController类步骤3:搭建服务消费者eureka-consumer项目(1)创建一个config包,在config包下新建配置类RestConfig&#xff0…

跨境卖家品牌出海要注意哪些方面

随着目前互联网的发展,市场由线下扩张到全国,再扩张到了全球,但是海外市场和国内并不相同跨境卖家品牌想要出海,需要注意多个方面,以确保能够在国际市场上成功立足并发展。以下是一些关键点: 首先想得拥有…

基于matlab的语音信号处理

摘要 利用所学习的数字信号处理知识,设计了一个有趣的音效处理系统,首先设计了几种不同的滤波器对声音进行滤波处理,分析了时域和频域的变化,比较了经过滤波处理后的声音与原来的声音有何变化。同时设计实现了语音的倒放&#xf…

【HarmonyOS开发笔记 2 】 -- ArkTS语法中的变量与常量

ArkTS是HarmonyOS开发的编程语言 ArkTS语法中的变量 【语法格式】: let 变量名: 类型 值 let:是定义变量的关键字类型: 值数据类型, 常用的数据类型 字符型(string)、数字型(number&#xf…

最新发布!Windows 11 24H2 纯净版:无捆绑,即刻升级!

今日,系统之家小编给大家带来最新的Windows11 24H2纯净版系统下载,该版本系统基于微软官方Windows11 24H2 26100.1882专业版进行离线制作,删除各种流氓软件,确保系统安全纯净,大家日常操作更放心。系统的兼容性出色&am…

人工智能的未来:从知识廉价时代到AI主导国家模式

随着人工智能(AI)技术的飞速发展,知识的获取和使用正变得更加普及与廉价。这不仅引发了技术领域的深刻变革,也将对全球社会经济模式产生广泛影响。特别是在《时代》杂志对风险投资巨头维诺德科斯拉(Vinod Khosla&#…

免费送源码:Apache+B/S+Springboot+MySQL 商城综合项目自动化系统 计算机毕业设计原创定制

摘 要 目前电商系统商城项目管理极其频繁,迫切地需要自动化测试来代替人工繁琐而又重复的劳动。自动化测试相关的研究已经很多,但多数只是针对某一方面,比如单一接口或者单一页面或者性能等,而缺乏将接口、页面、持续集成系统和缺陷管理系统整合的自动化测试平台。本研究采用混…

解决雪花ID在前端精度丢失问题

解决雪花ID在前端精度丢失问题 在现代分布式系统中,雪花算法(Snowflake)被广泛用于生成唯一的ID。这些ID通常是Long类型的整数。然而,当这些ID从后端传递到前端时,JavaScript的精度限制可能会导致精度丢失&#xff0c…

No.14 笔记 | XSS漏洞:原理、类型与防御策略

一、HTML和JavaScript基础 1. HTML基础 HTML概述&#xff1a;超文本标记语言&#xff0c;用于实现页面跳转和显示数据。结构标准&#xff1a;包括<!doctype html>声明文档类型&#xff0c;<html>根标签&#xff0c;<head>头部标签和<body>主体标签等。…

鸿鹄企业电子招投标采购系统视频详解|在线招投标|评标|竞标|单一采购|询价|邀标|在线开标|招标公告发布|评审专家|招标代理机构|招投标采购系统视频讲解

鸿鹄企业电子招投标采购系统视频详解|在线招投标|评标|竞标|单一采购|询价|邀标|在线开标|招标公告发布|评审专家|招标代理机构|招投标采购系统视频讲解 鸿鹄企业招投标采购系统视频讲解地址企业软件定制擅长跟我学习springcloud,honghu b2b2c,知识付费,等方面的知识,企业软件定…

了解网页 blob 链接

blob 链接 自从 HTML5 提供了 video 标签&#xff0c;在网页中播放视频变得非常简单&#xff0c;只要在代码中插入一个 video 标签&#xff0c;再将 video 标签的 src 属性设置为视频的链接就可以了。由于 src 指向的是视频文件真实的地址&#xff0c;所以当我们通过浏览器的调…

自动驾驶系列—从IMU到惯性定位算法:自动驾驶精准定位的幕后科技

&#x1f31f;&#x1f31f; 欢迎来到我的技术小筑&#xff0c;一个专为技术探索者打造的交流空间。在这里&#xff0c;我们不仅分享代码的智慧&#xff0c;还探讨技术的深度与广度。无论您是资深开发者还是技术新手&#xff0c;这里都有一片属于您的天空。让我们在知识的海洋中…

ACM(Association for Computing Machinery)简介

ACM&#xff08;Association for Computing Machinery&#xff09;简介 ACM&#xff0c;全称为 Association for Computing Machinery&#xff0c;中文译作“计算机协会”&#xff0c;是全球历史最悠久、规模最大的计算机领域专业组织。成立于1947年&#xff0c;ACM致力于推动…

JavaEE一条龙学习----前端开发准备(二)

上一章为大家推荐了几款前端开发软件 我个人习惯使用VS Code Microsoft出品&#xff0c;轻量但强大&#xff0c;针对于编写现代Web和云应用的跨平台源代码编辑器。可以在MacOS X、Windows和 Linux等操作平台使用。 具有对JavaScript、TypeScript和Node.js的内置支持&#xff0…

20.数据结构与算法-树和二叉树/满二叉树/完全二叉树/二叉树的性质/二叉树的存储结构

树的定义 树的其它表示方法 树的基本术语 树结构和线性结构的比较 二叉树的定义 二叉树案例引入 二叉树的抽象数据类型定义 二叉树的性质 两种特殊形式的二叉树 满二叉树 完全二叉树 完全二叉树的性质 二叉树的存储结构 二叉树的顺序存储 二叉树的链式存储结构 二叉链表 三叉链…