黑马商城项目—服务注册、服务发现

服务注册

我们把item-service注册到Nacos,步骤如下

1.引入依赖

在item-service的pom.xml中添加依赖:


2.配置Nacos

在item-service的application.yml中添加nacos地址配置:


3.配置服务实例

为了测试一个服务多个实例的情况,我们再配置一个item-service的部署实例

点击ItemApplication启动类右键选择Copy Configuration

点击Add VM options 之后会弹出下面一条框,里面填写-Dserver.post=端口号

之后就可以看到两个ItemApplication启动类了


4.启动两个启动类进行测试

访问nacos控制台,可以发现服务注册成功

点击详情,可以查看到item-service服务的两个实例信息:


服务发现

服务发现的作用在于不管是服务宕机、启动,随时都能被我们感应到,随时都能拿到最新的服务列表

服务发现使用步骤和服务注册前两步一样,都是导入依赖和配置Nacos,区别在于后面需要使用到负载均衡

我们把cart-service注册到Nacos并实现服务发现步骤如下

1.引入依赖

我们在cart-service中的pom.xml中添加下面的依赖:


2.配置Nacos


3.发现并调用服务

接下来,服务调用者cart-service就可以去订阅item-serivce服务了。不过item-service有多个实例,而真正发起调用时只需要知道一个实例的地址。

因此,服务调用者必须利用负载均衡的算法,从多个实例中挑选一个去访问。常见的负载均衡算法有:

  • 随机

  • 轮询

  • IP的hash

  • 最近最少访问

这里我们可以选择最简单的随机负载均衡。另外,服务发现需要用到一个工具:DiscoveryClient;SpringCloud已经帮我们自动装配,我们可以直接注入使用:


点开cart-service中CartServiceImpl实现类,找到handCartItems,对原来的远程调用进行一个修改,之前调用时我们需要写死服务提供者的IP和端口:

但现在不需要了,我们通过DiscoveryClient发现服务实例列表 ,然后通过负载均衡算法,选择一个实例去调用:


4.启动测试


通过http://localhost:8082/doc.html路径打开购物车服务文档进行测试 ,把三个启动类日志清空好观察输出sql语句

然后到控制台去查看CartApplication和两个ItemApplication是否有sql语句输出,有则代表负载均衡成功,有一个启动类没sql语句输出则代表有问题

可以看到三个控制台都有sql语句输出,声明该服务发现成功!

相关推荐
拾忆,想起4 天前
Dubbo服务调用幂等性深度解析:彻底解决重复请求的终极方案
微服务·性能优化·服务发现·dubbo
Java天梯之路8 天前
Java SPI:服务发现的轻量级标准
java·面试·服务发现
周杰伦_Jay8 天前
【Nacos指南】服务发现+配置管理从入门到实战
网络·架构·开源·云计算·服务发现
kong790692812 天前
Spring Cloud Consul
spring cloud·服务发现·consul·服务治理
阿拉斯攀登13 天前
SpringCloudAlibaba之Nacos
微服务·服务发现·springcloud
拾忆,想起15 天前
Dubbo动态服务发现配置指南:从基础到云原生实践
服务器·网络·微服务·云原生·架构·服务发现·dubbo
摇滚侠17 天前
2025最新 SpringCloud 教程,Nacos-注册中心-服务发现功能,笔记07
笔记·spring cloud·服务发现
楠枬1 个月前
服务注册与发现——Eureka
spring cloud·eureka·服务发现
利刃大大1 个月前
【c++中间件】etcd存储系统 && 服务注册 && 服务发现 && 二次封装
c++·中间件·服务发现·etcd·服务中心
q***R3081 个月前
后端服务发现工具,Consul与Eureka Consul vs Eureka:后端服务发现工具全面对比
eureka·服务发现·consul