微服务02-Nacos、Ribbon

文章目录

一、认识Nacos

二、服务注册到Nacos

1.在父工程中添加spring-cloud-alibaba的管理依赖:

2、添加nacos的客户端依赖

3、修改application.yml文件

三、Nacos服务分级存储模型

 1、修改application.yml

 2、在Nacos控制台可以看到集群变化

3、Nacos服务分级存储模型

4、如何设置实例的集群属性

 四、NacosRule负载均衡

 1、根据集群负载均衡 ​编辑

 2、NacosRule负载均衡策略

五、服务实例的权重设置

六、环境隔离-namespace

七、Nacos注册中心原理

 八、临时实例和非临时实例

九、Nacos和Eureka区别

十、统一配置管理

 十一、微服务配置拉取

 十二、配置热更新

 十三、多环境配置共享

 十四、Ribbon负载均衡


一、认识Nacos

Nacos 是阿里巴巴的产品,现在是 SpringCloud 中的一个组件。相比 Eureka 功能更加丰富,在国内受欢迎程度较高

二、服务注册到Nacos

1.在父工程中添加spring-cloud-alibaba的管理依赖:

2、添加nacos的客户端依赖

3、修改application.yml文件

三、Nacos服务分级存储模型

 1、修改application.yml

 2、在Nacos控制台可以看到集群变化

3、Nacos服务分级存储模型

  1. 一级是服务,例如 userservice
  2. 二级是集群,例如杭州或上海
  3. 三级是实例,例如杭州机房的某台部署了userservice的服务器

4、如何设置实例的集群属性

        修改application.yml文件,添加spring.cloud.nacos.discovery.cluster-name属性即可

 四、NacosRule负载均衡

 1、根据集群负载均衡 

 2、NacosRule负载均衡策略

  1. 优先选择同集群服务实例列表
  2. 本地集群找不到提供者,才去其他集群寻找,并且会警告
  3. 确定了可用的实例列表后,再采用随机负载均衡挑选实例

五、服务实例的权重设置

1、在Nacos控制台可以设置实例的权重值,说先选中实例后面的编辑按钮

 2、将权重设置为0.1,测试发现8082被访问到的频率大大降低

 

 3、实例的权重控制

  1. Nacos控制台可以设置实例的权重值,0~1之间
  2. 同集群内的多个实例,权重越高被访问的频率越高
  3. 权重设置为0则完全不会被访问

六、环境隔离-namespace

Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西,用来做最外层隔离

1、在Nacos控制台可以创建namespace,用来隔离不同环境

 2、然后填写一个新的命名空间信息

 3、保存后会在控制台看到这个命名空间的id:

 4、修改application.yml,添加namespace

 5、Nacos环境隔离:

  1. namespace用来做环境隔离
  2. 每个namespace都有唯一id
  3. 不同namespace下的服务不可见

七、Nacos注册中心原理

 八、临时实例和非临时实例

        服务注册到Nacos时,可以选择注册为临时或非临时实例,通过下面配置来设置

        

         临时实例宕机时,会从nacos的服务列表中删除,而非临时实例则不会

九、Nacos和Eureka区别

  1. Nacos与eureka的共同点
    1. 都支持服务注册和服务拉去
    2. 都支持服务提供者心跳方式做健康检测
  2. Nacos与Eureka的区别
    1. Nacos支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测方式
    2. 临时实例心跳不正常会被剔除,非临时实例则不会被剔除
    3. Nacos支持服务列表变更的消息推送模式,服务列表更新更及时
    4. Nacos集群模式采用AP方式,当集群中存在非临时实例时,采用CP模式;Eureka采用AP方式

十、统一配置管理

        配置更改热更新

        

1、在Nacos中添加配置信息      

 2、在弹出表单中填写配置信息

 十一、微服务配置拉取

        配置获取的步骤如下:

 1、引入Nacos的配置管理客户端依赖

 2、在userservice的 resource 目录添加一个 bootstrap.yml 文件,这个文件是引导文件。优先级高于 application.yml,服务名称+开发环境+文件后缀名决定了程序启动时去nacos读取哪个文件

 十二、配置热更新

Nacos中的配置文件变更后,微服务无需重启就可以感知。不过需要通过下面两种配置实现

方式一:在 @Value 注入的变量所在类上添加注解 @RefreshScope

方式二:使用 @ConfigurationProperties 注解

 十三、多环境配置共享

 微服务启动时会从nacos读取多个配置文件

  • 服务名称-开发环境.yaml,例如:userservice-dev.yaml     
  • 服务名称.yaml,例如:userservice.yaml

无论 profile 何如变化,服务名称.yaml 这个文件一定会被加载,因为多环境共享配置可以写入这个文件

 多种配置的优先级:

 十四、Ribbon负载均衡

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud Nacos是一个非常流行的微服务注册中心和配置中心,而Ribbon则是一个负载均衡组件。结合起来,可以实现服务的自动发现和负载均衡。 下面是一个简单的示例: 1. 在pom.xml文件中添加依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-ribbon</artifactId> </dependency> ``` 2. 在application.properties或application.yml中配置NacosRibbon: ```yaml # Nacos配置 spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848 # Ribbon配置 service-provider.ribbon.listOfServers=localhost:8081,localhost:8082 service-provider.ribbon.NIWSServerListClassName=com.netflix.loadbalancer.ConfigurationBasedServerList ``` 3. 创建一个Ribbon的配置类,用于自定义负载均衡策略等: ```java @Configuration public class RibbonConfig { @Bean public IRule ribbonRule() { return new RandomRule(); // 随机负载均衡策略 } @Bean public IPing ribbonPing() { return new PingUrl(false, "/health"); // 检查服务健康状态的URL } } ``` 4. 在服务消费方的代码中,注入RestTemplate对象,并使用@LoadBalanced注解: ```java @RestController public class ConsumerController { @Autowired private RestTemplate restTemplate; @GetMapping("/hello") public String hello() { String url = "http://service-provider/hello"; return restTemplate.getForObject(url, String.class); } @Bean @LoadBalanced public RestTemplate restTemplate() { return new RestTemplate(); } } ``` 在这里,我们使用了"http://service-provider/hello"作为服务提供方的URL,而不是具体的IP和端口。这是因为Ribbon会根据服务名自动选择一个可用的实例。 以上就是使用Spring Cloud NacosRibbon调用服务的基本步骤。需要注意的是,在使用Nacos作为注册中心时,服务提供方需要在启动时注册自己。可以参考Nacos的官方文档或者Spring Cloud官方文档进行配置和使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值