大话SpringCloud---服务注册中心是个啥?

软件开发的趋势慢慢偏向分布式开发,随着模块越来越多,它们之间依赖调用关系开始错中复杂。我们就需要一个东西去解决这一问题,今天就来记录一下。


问题来了

正如前言所言,现在一个系统内部被打散,不同的功能放入不同的模块里。而一个模块难免会去远程调用别的模块。如果只是几个模块的调用还可以自己捋清,但是往往一个系统开发到后期,会有几十个模块出现,这个时候再自己一个一个去管理调用,那是很耗费精力的事情。

在传统的rpc远程调用框架中,每个服务与服务之间依赖关系比较复杂,管理起来也比较复杂,所以需要使用服务治理,管理服务与服务之间的依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册。

SpringCloud封装了Netflix公司开发的Eureka模块来实现服务治理的。

什么是服务注册与发现?

这里先举一个例子,我们平时看病去私人诊所看病往往不需要排队,直接走进去找医生看病即可。但是医院规模大了之后,每一个患者都不排队,直接走进去找医生,那不乱套了吗?先不说这样效率低下,医生也很累呀。所有人都往诊室门口站,安保压力也山大。

如果这时有一堵"墙"把他们隔开,怎么讲呢?

有一个门诊,患者来了之后先去那里挂号,然后排队,门诊系统上会显示当前的患者人数信息、医生今天所接诊的人数、医生的就诊情况,比如哪些医生刚刚就诊完,现在是空闲状态等等。可以一目了然的看到医院的情况。

这么一看有内味了,很符合我们程序员经常讲的高内聚低耦合,将患者与医生隔开,中间通过门诊调度再将他们相连。服务注册与发现就是扮演门诊的一个角色。

服务注册与发现中,有一个注册中心。当服务器启动的时候,会把当前自己服务器的信息,比如服务地址通信地址等以别名的方式注册到注册中心上。另一方(消费者|服务提供者),以该别名的方式去注册中心上获取到实际的服务通讯地址,然后在实现本地RPC调用。RPC远程调用框架核心设计思想:在于注册中心,因为使用注册中心管理每个服务与服务之间的一个依赖关系(服务治理概念)。在任何一个RPC远程框架中,都会有一个注册中心(存放服务地址相关信息)。

在这里插入图片描述

在这里插入图片描述

这个过程就像是,小明医生今天来上班,上班前先把自己的信息填入到门诊系统中(服务注册)。等于告诉全世界,我开始接诊了!之后有患者来看病,他总要先去挂号吧?挂号时系统发现“嘿,这里小明医生有空闲,那先安排他接诊吧”(服务发现)。于是患者拿到了小明医生的号,上面写着小明所在的诊室信息。患者照着上面的信息来到所在诊室,开始就诊(rpc调用)。

服务注册中心的技术栈

有了这么一个东西,可以很好的解决在分布式系统中出现的模块与模块间的管理问题。而到现在服务注册与发现还只是个"天上飞"的概念,还需要有"落地"的实现。

有人说这简单,不就是一个注册中心嘛,我手写一个出来!其实知道原理后并不困难,但是还要考虑各种问题,比如在分布式系统中注册中心突然故障了怎么办?那不是整个系统都跟着瘫痪了嘛。还有你服务提供者总要有一个集群吧,那你注册中心要怎么解决负载均衡的问题呢?

诸如此类的问题,但是已经有人帮我们解决了。市面上有许多常用的服务注册中心技术。就比如Eureka、Zookeeper、Consul还有Nacos

其中EurekaSpringCloud的老项目中用的比较多,为啥是老项目呢?因为它后面停止更新了。比较新的项目用别的技术偏多。关于Zookeeper的之前在另外几篇博客中介绍到了。有兴趣的可以去看一下。也算是一个比较老的技术了。但好像还是挺多公司在使用的

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

最近也是刚刚开始学习微服务有关的知识,望各位共勉,感谢观看🙏

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
stable-diffusion-webui是一个稳定的扩散网络用户界面,该项目的开发可以分为三个主要步骤。 首先,我们需要搭建一个基本的Web界面框架。我们可以选择使用现成的Web开发框架,如React或Vue.js。这些框架提供了一套良好的组件化和状态管理机制,方便我们构建一个复杂而稳定的用户界面。我们需要使用HTML和CSS来设计和布局页面,并使用框架提供的组件和API来实现各种功能和交互。 接下来,我们需要连接界面与稳定的扩散网络后端。我们可以使用HTTP请求来与后端进行通信,获取和发送数据。为了保持稳定性,我们可以使用异步请求,以避免界面在等待响应时冻结。我们可以使用现有的HTTP库,如Axios或Fetch,来简化请求的处理。同时,我们还需要进行错误处理和数据验证,以确保数据的准确性和完整性。 最后,我们需要为界面添加一些功能和特性。这可能包括用户认证和授权,数据可视化和图表展示,以及与其他用户的实时交互和通信。我们可以使用现有的库和工具,如Chart.js和Socket.io,来实现这些功能。同时,我们还需要进行一些性能和安全性方面的优化,以确保界面的快速响应和数据的安全性。 总之,开发一个简单的stable-diffusion-webui需要搭建基本的Web界面框架,连接后端,并为界面添加功能和特性。通过以上步骤,我们可以实现一个稳定而功能丰富的扩散网络用户界面。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值