图解Nacos,注册中心演变 + Nacos核心功能

网站建设4年前发布
43 0 0

20230307002418d3c7d7316d263160481482873afab10b9a168a641,大家好,我是哪吒。,一个更易于构建云原生应用的动态服务发现、服务配置和服务管理平台。,202303070028237357ddc64ad38560ee7959d319dabf645cd7c5476,Nacos的关键特性:,20230307140724f3183a7026a9bcd02bb4823ceae1730fb33b87119,Nacos的关键特性,如果此时,服务端接口接口名或参数或请求方式更改了,那么就得同步修改此restTemplate方法,感觉很麻烦,20230307001930330e377244b88632286779980021740bfc1888712,RestTemplate调用远程服务,20230307001931f9f339e28c73b7f2ad6622bddd4ceb25259c2c216,通过Nginx维护服务列表(upStream),如果服务较多的话,在Nginx通过upStream的方式去配置的话,Nginx配置文件会变得非常的难以维护。,2023030700193143f4d6307f71d5765e3915b941ca6e625ee501747,Nacos注册中心,这种是最简单的Nacos注册中心,有若干个服务,都注册到Nacos注册中心,调用之前,先到Nacos获取对应接口,然后进行实际的调用。,但是,思考一个问题,如果Nacos宕机了,怎么办?如果从Nacos获取到接口后,调用服务2时,服务2宕机了,怎么办?,20230307001931e3e46c290e1696f88bf694b412feb3bef7bea6811,心跳版Nacos,心跳版Nacos,服务1和服务2和Nacos之间维护一个心跳关系,每5秒跳一次,频率不能太快或者太慢,否者会嗝屁的。,如果Nacos在5秒内没有收到心跳,则表示服务挂了,Nacos会下线此服务。,对于超过15秒没有收到客户端心跳的服务实例,会将它的healthy属性置为false,客户端无法调用healthy为false的服务。,如果超过30秒没有收到心跳,Nacos会直接将此服务剔除。,也可以通过服务端主动注销的方式,停止注册。,服务1调用服务2时,服务1会通过定时任务到Nacos中获取在线的服务,保证所调用的服务一直都是健康在线的状态。,获取到之后,用缓存将其保存起来,然后通过负载均衡器调用服务2,此时,将不再使用服务端的负载均衡Nginx了。,SpringBoot中引入Nacos Discovery,实现与Nacos的无缝连接,Nacos Discovery可以将服务自动注册到Nacos服务端,并且能够动态感知此服务,并刷新服务列表。并将服务的host、port、URL等信息注册到Nacos。,Nacos 的配置项信息:,20230307001931539202448c367254eb188936078ff0a4e32285187,20230307002419876f77c59231df1eaf54744b757300384d3be0259,Nacos核心功能,Nacos Client会通过发送REST请求向Nacos Server注册自己的服务,提供自身的元数据,比如host、port、url等信息,Nacos Server在收到注册请求后,会将这些数据信息存储在一个双层的内存map中。,服务注册后,服务消费者和Nacos Server之间会维护一个心跳,定时通知server,此服务还活着,防止被剔除掉。,Nacos Server集群之间会互相同步已注册的服务,用来保证服务列表的一致性。,服务消费者在调用服务提供者的服务时,会发送一个REST请求到Nacos Server,获取健康的服务列表,然后将其缓存到本地,同时开启一个定时任务,定时访问Nacos Server,然后更新本地缓存。,Nacos Server会开启一个定时任务用来检查注册服务实例的健康情况,对于超过15秒没有收到客户端心跳的服务实例,会将它的healthy属性置为false,客户端无法调用healthy为false的服务,如果超过30秒没有收到心跳,Nacos会直接将此服务剔除。,1、Nacos目前功能最全,用的也最多;,2、Eureka,因为挺更的缘故,比较新的技术都不支持了,目前很多公司都将Eureka换成Nacos了,不推荐使用;,3、Zookeeper,用的最多的地方就是和Dubbo一起使用,不支持负载均衡策略,但可以通过其它组件实现;,4、Consul支持的也很多;,Nacos使用key/value形式存储配置信息,为分布式系统中的外部化配置提供服务支持。,一秒刷新一次。,开发测试环境和生产环境的资源(如配置、服务)隔离等,比如dev和prod。,在没有明确指定 ${spring.cloud.nacos.config.group}配置的情况下, 默认使用的是 DEFAULT_GROUP 。如果需要自定义自己的 Group,可以通过以下配置来实现:,profile > 默认配置文件 > extension-configs(下标越大优先级越高) > shared-configs(下标越大优先级越高)。,一般都是通过@Value的形式读取配置文件中的信息,但是无法感知修改后的值,需要利用@RefreshScope动态刷新。,(1) Spring Cloud Config需要结合Git使用,动态变更需要配合Bus 消息总线来通知所有的客户端变化。,(2)Spring Cloud Config没有可视化界面。,(3)Nacos使用长轮询更新配置,速度上秒杀Spring Cloud Config。,本文转载自微信公众号「哪吒编程」,可以通过以下二维码关注。转载本文请联系哪吒编程公众号。,20230307002421c70dd9511c9e4336331614b19fbe0b62be096a877,

© 版权声明

相关文章