当前位置: 首页 > news >正文

golang学习笔记19——golang做服务发现与注册的深度剖析

  • 推荐学习文档
    • golang应用级os框架,欢迎star
    • golang应用级os框架使用案例,欢迎star
    • 案例:基于golang开发的一款超有个性的旅游计划app经历
    • golang实战大纲
    • golang优秀开发常用开源库汇总
    • 想学习更多golang知识,这里有免费的golang学习笔记专栏

文章目录

    • 引言
    • 服务发现与注册的基本概念
      • 1.服务发现
      • 2.服务注册
    • 常见问题及解决方案
      • 1.注册中心的高可用性
      • 2.服务实例的健康检查
      • 3.服务发现的实时性
      • 4.服务发现的负载均衡
    • 总结

引言

在微服务架构中,服务发现与注册是核心组件之一。它确保各个微服务能够相互找到并进行通信。在 Go 语言开发中,虽然有多种工具和库可用于服务发现与注册,但仍会遇到一些问题。本文将详细探讨这些问题并给出相应的解决方案,同时配合代码示例进行说明。

服务发现与注册的基本概念

1.服务发现

服务发现是指在一个分布式系统中,服务消费者能够自动地找到服务提供者的网络位置(如 IP 地址和端口号)的过程。

2.服务注册

服务注册是指服务提供者在启动时,将自身的服务信息(如服务名称、IP 地址、端口号等)注册到一个中心化的服务注册中心或者分布式的注册网络中。

常见问题及解决方案

1.注册中心的高可用性

注册中心本身可能成为单点故障。如果注册中心出现故障,新的服务实例无法注册,已有的服务实例也无法被发现,这将导致整个微服务架构陷入混乱。

  • 解决方案
    • 使用高可用的注册中心集群。例如,Consul 支持多数据中心的部署,可以在不同的数据中心部署多个 Consul 节点,通过数据同步来保证服务注册信息的一致性和高可用性。
  • 代码示例(以 Consul 为例):
package mainimport ("log"consulapi "github.com/hashicorp/consul/api"
)func main() {// 创建 Consul 客户端config := consulapi.DefaultConfig()client, err := consulapi.NewClient(config)if err!= nil {log.Fatal("创建 Consul 客户端失败: ", err)}// 注册服务registration := new(consulapi.AgentServiceRegistration)registration.ID = "my-service-1"registration.Name = "my-service"registration.Address = "127.0.0.1"registration.Port = 8080err = client.Agent().ServiceRegister(registration)if err!= nil {log.Fatal("服务注册失败: ", err)}log.Println("服务注册成功")
}

2.服务实例的健康检查

注册中心可能仍然保留着已经故障或者不健康的服务实例的注册信息,这会导致服务消费者调用到不可用的服务实例。

  • 解决方案
    • 配置服务注册中心的健康检查机制。服务提供者在注册服务时,同时注册健康检查的接口或者脚本。注册中心定期调用这些健康检查接口来判断服务实例是否健康。
  • 继续以 Consul 为例的代码示例:
registration.Check = &consulapi.AgentServiceCheck{HTTP:     "http://127.0.0.1:8080/health",Interval: "10s",
}

3.服务发现的实时性

服务注册信息的更新可能存在延迟,导致服务消费者不能及时发现新的服务实例或者已下线的服务实例的变化。

  • 解决方案
    • 优化注册中心的内部数据同步机制,尽量减少数据同步的延迟。
      服务消费者可以采用主动拉取和被动通知相结合的方式。例如,定期主动从注册中心拉取服务实例列表,同时注册中心在服务实例状态发生变化时,主动通知服务消费者。
  • 以下是一个简单的服务消费者示例,使用 Go 语言的 channel 来模拟被动通知:
package mainimport ("fmt""time"
)func serviceConsumer(serviceList chan []string) {for {services := <-serviceListfmt.Println("当前可用服务列表: ", services)// 进行服务调用等操作time.Sleep(5 * time.Second)}
}func main() {serviceList := make(chan []string)go serviceConsumer(serviceList)// 模拟注册中心通知服务实例变化for i := 0; i < 5; i++ {serviceList <- []string{"service1", "service2"}time.Sleep(10 * time.Second)}
}

4.服务发现的负载均衡

即使服务发现机制能够正确地找到所有可用的服务实例,但如果没有合理的负载均衡策略,可能会导致某些服务实例负载过重,而其他服务实例负载过轻。

  • 解决方案
    • 实现多种负载均衡算法,如轮询、随机、加权轮询、一致性哈希等。根据服务的特性和实际需求选择合适的负载均衡算法。
  • 以下是一个简单的加权轮询负载均衡示例:
package mainimport ("fmt""math/rand""time"
)type ServiceInstance struct {name    stringweight  intcurrent int
}func weightedRoundRobin(instances []ServiceInstance) string {totalWeight := 0for _, instance := range instances {totalWeight += instance.weight}rand.Seed(time.Now().UnixNano())randomValue := rand.Intn(totalWeight)for _, instance := range instances {if randomValue < instance.current+instance.weight {instance.current += totalWeightreturn instance.name}instance.current += instance.weight}return ""
}func main() {instances := []ServiceInstance{{name: "service1", weight: 3},{name: "service2", weight: 2},{name: "service3", weight: 1},}for i := 0; i < 10; i++ {selected := weightedRoundRobin(instances)fmt.Println("选择的服务实例: ", selected)}
}

总结

在 Go 语言的微服务开发中,服务发现与注册是至关重要的环节。通过解决注册中心的高可用性、服务实例的健康检查、服务发现的实时性以及负载均衡等问题,可以构建更加稳定、高效的微服务架构。

关注我看更多有意思的文章哦!👉👉

相关文章:

golang学习笔记19——golang做服务发现与注册的深度剖析

推荐学习文档 golang应用级os框架&#xff0c;欢迎stargolang应用级os框架使用案例&#xff0c;欢迎star案例&#xff1a;基于golang开发的一款超有个性的旅游计划app经历golang实战大纲golang优秀开发常用开源库汇总想学习更多golang知识&#xff0c;这里有免费的golang学习笔…...

ROS和ROS2借助智能大模型的学习和研究方法

机器人相关知识的本身和价值-CSDN博客 知识本身在智能时代毫无价值&#xff0c;需要基于知识应用和创新才有价值。 学历报废并非来自扩招&#xff0c;而是智能模型的快速发展。-CSDN blink-领先的开发者技术社区 2024年中秋&#xff0c;智能模型实力已经如此&#xff0c;但还…...

弹性负载均衡ELB 详解和设置方法

一、弹性负载均衡ELB 详解 1. 定义与概念 弹性负载均衡&#xff08;Elastic Load Balancing&#xff0c;简称ELB&#xff09;是一种将访问流量自动分发到多台云服务器的流量分发控制服务。它通过在多个后端服务器之间均衡分配请求&#xff0c;提高应用程序的可用性、可扩展性…...

Python3网络爬虫开发实战(15)Scrapy 框架的使用(第一版)

文章目录 一、Scrapy 框架介绍1.1 数据流1.2 项目结构1.3 Scrapy 入门 二、Selector 解析器2.1 XPath 和 CSS 选择器2.2 信息提取2.3 正则提取 三、Spider 的使用3.1 Spider 运行流程3.2 Spider 类分析3.3 Request3.4 Response 四、Download Middleware 的使用4.1 process_requ…...

大众点评代发排名骗局

大众点评代发排名骗局 不诋毁同行&#xff0c;不贬低对手&#xff0c;请各位老板擦亮眼睛&#xff0c;认真看完这篇文章&#xff0c;以防上当受骗#网络宣传&#xff03;企业推广&#xff03;企业推广 大众点评代发排名&#xff1a;一场精心编织的骗局 在这个美食如云的时代&…...

硬件基础知识

驱动开发分为&#xff1a;裸机驱动、linux驱动 嵌入式&#xff1a;以计算机技术为基础&#xff0c;软硬结合的、可移植、可剪裁的专用计算机 单片机最小单元&#xff1a;vcc gnd reset 晶振 cpu --- soc :system on chip 片上外设 所有的程序都是在soc&#xff08;cpu&…...

使用gitee如何回滚上一个版本,简单操作方式-gitee自带功能无需使用代码

使用gitee如何回滚上一个版本&#xff0c;简单操作方式-gitee自带功能无需使用代码&#xff0c;很多朋友使用代码的话容易出错&#xff0c;gitee自带了本功能&#xff1a; 找到gitee代码仓库&#xff0c;找到对应的想要回滚的版本点击进去 点击revert&#xff0c;选择自己对应的…...

独立站技能树之建站33项自检清单 1.0丨出海笔记

很多时候大家建好站之后很嗨&#xff0c;但过一会就开始担忧各种纠结我是不是还有什么点没做好&#xff0c;或者我的站漏了什么东西&#xff0c;那么接下来以下这个独立站自检清单能很好的帮到你。其实对于新手我还是建议大家直接用一些模板&#xff0c;因为模板上面基本该有的…...

js进阶-作用域是什么

经过前面80多篇文章对js相关内容的讲解&#xff0c;相信大家对js这门语言已经有了一定的知识储备&#xff0c;也掌握了这门语言的相关特性&#xff0c;领会到这门语言的魅力所在&#xff0c;所以从今天开始&#xff0c;会定期更新js进阶相关知识&#xff0c;大家可以持续关注&a…...

ant-design表格自动合并相同内容的单元格

表格自动合并相同内容的单元格 合并hooks import { TableColumnProps } from antdexport const useAutoMergeTableCell <T extends object>(dataSource: Array<T>,columns: Array<TableColumnProps> | Array<keyof T> ): Map<keyof T, Array<…...

通过多模态关系图学习实现可解释的医学图像视觉问答|文献速递--Transformer架构在医学影像分析中的应用

Title 题目 Interpretable medical image Visual Question Answering via multi-modal relationship graph learning 通过多模态关系图学习实现可解释的医学图像视觉问答。 01 文献速递介绍 医学视觉问答&#xff08;VQA&#xff09;是医学多模态大语言模型&#xff08;LL…...

从入门到精通,带你探索适合新手的视频剪辑工具

用视频来分享生活已经变成越来越多人的一种习惯&#xff0c;很多时候视频并不能一镜到底&#xff0c;所以还需要一些的修改、剪辑操作&#xff0c;那么这次我将介绍几款视频剪辑工具&#xff0c;希望能够让你分享的道路更加通畅。 1.FOXIT视频剪辑 连接直达>>https://w…...

线性规划------ + 案例 + Python源码求解(见文中)

目录 一、代数模型(Algebraic Models)详解1.1什么是代数模型?1.2代数模型的基本形式1.3 安装所需要的Python包--运行下述案例1.4代数模型的应用案例案例 1:市场供需平衡模型Python求解代码Python求解结果如下图:案例 2:运输问题中的线性规划模型进行数学建模分析1. 目标函…...

用Java实现人工智能

用Java实现人工智能 #Java #人工智能 #AI #机器学习 #深度学习 #数据科学 #技术博客 #编程技巧 文章目录 前言环境准备1. 安装Java2. IDE选择3. 依赖管理 数据准备模型训练模型评估分类模型评估回归模型评估模型的交叉验证 模型部署部署模型的基本步骤模型保存与加载Docker容器…...

MobaXterm使用技巧

引言 在现代IT环境中&#xff0c;远程管理和SSH连接已经成为管理员和开发者日常工作的重要组成部分。MobaXterm是一款功能强大的终端模拟器&#xff0c;它集成了多种网络工具&#xff0c;非常适合用于远程管理、编程和网络调试。本文将汇总一些MobaXterm的使用技巧&#xff0c…...

openstack中的rabbitmq

基本概念 基础介绍 exchange&#xff1a;用于分发信息&#xff0c;有direct、fanout、topic、headers&#xff1b; binding&#xff1a;exchange、queue之间的虚拟连接&#xff0c;由一个或者多个routing key组成&#xff1b; queues&#xff1a;用来暂存消息&#xff0c;供…...

etcd三节点,其中一个坏掉了的恢复办法

一、配置etcdctl环境变量 --------------------------------------------------------------------------------------------- #其中证书实际路径和endpoints,以环境情况为准,查询方式 # ps -ef | grep etcd-cafile # ps -ef | grep etcd-servers export ETCDCTL_API3 export…...

计算机毕业设计 基于SpringBoot框架的网上蛋糕销售系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…...

C编程控制PC蜂鸣器方法2

在《C编程控制PC蜂鸣器》一文中,我们了解并使用了通过IO端口控制的方式操作硬件,而有些时候这对于一些朋友来说太模糊了,很容易让人迷糊,这次采用最基本的write系统调用来写入input_event数据实现相同功能。这里涉及到的input_event可参考《C编程实现键盘LED闪烁方法2》一文…...

C# SQL 辅助工具

{/// <summary>/// sql 辅助工具/// </summary>public class SqlStructureHelps{#region 增删改查/// <summary>/// 截断/// </summary>/// <typeparam name"T"></typeparam>/// <returns></returns>public static …...

eNSP简单用法

建立一个简单的拓扑图 点击绿色三角开启设备 双击设备可以进行命令编辑 视图 分为三个视图&#xff1a;用户视图、系统视图、接口视图 用户视图 在默认模式下就是&#xff0c;为<huawei> 按ctrlz返回用户视图 系统视图&#xff1a; 在用户视图下输入sys切换&#…...

1035. 不相交的线

1. 题目 1035. 不相交的线 2. 解题思路 题目一看是求最值&#xff0c;那就可以考虑用DP来做。 核心点就是确定DP数组的含义以及状态转移方程&#xff1a; dp数组含义&#xff1a;dp[i][j]&#xff0c;nums1 前 i 个数和 nums2 前 j 个数的最大连线数dp[i][j] dp[i - 1][j …...

1.pytest基础知识(默认的测试用例的规则以及基础应用)

一、pytest单元测试框架 1&#xff09;什么是单元测试框架 单元测试是指再软件开发当中&#xff0c;针对软件的最小单位&#xff08;函数&#xff0c;方法&#xff09;进行正确性的检查测试。 2&#xff09;单元测试框架 java&#xff1a;junit和testing python&#xff1a;un…...

Linux常见查看文件命令

目录 一、cat 1.1. 查看文件内容 1.2. 创建文件 1.3. 追加内容到文件 1.4. 连接文件 1.5. 显示多个文件的内容 1.6. 使用管道 1.7. 查看文件的最后几行 1.8. 使用 -n 选项显示行号 1.9. 使用 -b 选项仅显示非空行的行号 二、tac 三、less 四、more 五、head 六、…...

初识 performance_schema:轻松掌握MySQL性能监控

什么是 performance_schema performance_schema 是 MySQL 5.8 版本的一个强大功能&#xff0c;它就像是一个内置的**“性能侦探”**&#xff0c;专门用来监控和分析 MySQL 服务器的资源消耗和等待情况。有了它&#xff0c;数据库管理员和开发者就能实时了解服务器的运行状态&a…...

linux下top命令查看和解释

怎么看top结果&#xff1a; top - 10:20:48 up 8 days, 14:07, 2 users, load average: 6.04, 5.82, 4.73 Tasks: 11099 total, 1 running, 10916 sleeping, 0 stopped, 1 zombie %Cpu(s): 8.9 us, 4.6 sy, 0.0 ni, 86.1 id, 0.1 wa, 0.0 hi, 0.3 si, 0.0 st K…...

换个手机IP地址是不是不一样?

在当今这个信息爆炸的时代&#xff0c;手机已经成为我们生活中不可或缺的一部分。而IP地址&#xff0c;作为手机连接网络的桥梁&#xff0c;也时常引起我们的关注。你是否曾经好奇&#xff0c;换个手机&#xff0c;IP地址会不会也跟着变呢&#xff1f;本文将深入探讨这个问题&a…...

【从计算机的发展角度理解编程语言】C、CPP、Java、Python,是偶然还是应时代的产物?

参考目录 前言什么是"computer"?计算机的大致发展历程计算机系统结构阶段(1946~1981)计算机网络和视窗阶段(1982~2007)复杂信息系统阶段(2008~today)人工智能阶段 越新的语言是越好的吗、越值得学习吗&#xff1f; 前言 最近读了 《Python语言程序设计基础》 这本书…...

《Google软件测试之道》笔记

介绍 GTAC&#xff1a;Google Test Automation Conference&#xff0c;Google测试自动化大会。 本书出版之前还有一本《微软测试之道》&#xff0c;值得阅读。 质量不是被测试出来的&#xff0c;但未经测试也不可能开发出有质量的软件。质量是开发过程的问题&#xff0c;而不…...

实战讲稿:Spring Boot整合MyBatis

文章目录 实战讲稿&#xff1a;Spring Boot整合MyBatis课程目标课程内容1. 创建员工映射器接口1.1 创建子包1.2 创建接口 2. 测试员工映射器接口2.1 自动装配员工映射器2.2 测试按标识符查询员工方法2.3 测试查询全部员工方法2.4 测试插入员工方法2.5 测试更新员工方法2.6 测试…...