Nacos注册中心
目前开源的注册中心框架有很多,国内比较常见的有:
- Eureka:Netflix公司出品,目前被集成在SpringCloud当中,一般用于Java应用
- Nacos:Alibaba公司出品,目前被集成在SpringCloudAlibaba中,一般用于Java应用
- Consul:HashiCorp公司出品,目前集成在SpringCloud中,不限制微服务语言
以上几种注册中心都遵循SpringCloud中的API规范,因此在业务开发使用上没有太大差异。由于Nacos是国内产品,中文文档比较丰富,而且同时具备配置管理功能(后面会学习),因此在国内使用较多,课堂中我们会Nacos为例来学习。
官方网站如下:
暂时无法在飞书文档外展示此内容
我们基于Docker来部署Nacos的注册中心,首先我们要准备MySQL数据库表,用来存储Nacos的数据。由于是Docker部署,所以大家需要将资料中的SQL文件导入到你Docker中的MySQL容器中:
最终表结构如下:
然后,找到课前资料下的nacos文件夹:
其中的
nacos/custom.env
文件中,有一个MYSQL_SERVICE_HOST也就是mysql地址,需要修改为你自己的虚拟机IP地址:然后,将课前资料中的
nacos
目录上传至虚拟机的/root
目录。上传资料中的nacos.tar到root目录下,执行命令加载镜像:docker load -i nacos.tar
进入root目录,然后执行下面的docker命令:
docker run -d \
--name nacos \
--env-file ./nacos/custom.env \
-p 8848:8848 \
-p 9848:9848 \
-p 9849:9849 \
--restart=always \
nacos/nacos-server:v2.1.0-slim
云服务器注意:需要开放 8848 9848 9849 端口!!!
启动完成后,访问下面地址:http://192.168.150.101:8848/nacos/,注意将
192.168.150.101
替换为你自己的虚拟机IP地址。首次访问会跳转到登录页,账号密码都是nacos
服务注册
接下来,我们把
item-service
注册到Nacos,步骤如下:- 引入依赖
- 配置Nacos地址
- 重启
添加依赖
在
item-service
的pom.xml
中添加依赖:<!--nacos 服务注册发现-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
配置Nacos
在
item-service
的application.yml
中添加nacos地址配置:spring:application:name: item-service # 服务名称cloud:nacos:server-addr: 192.168.150.101:8848 # nacos地址
启动服务实例
注意:Nacos需要调用8848和9848两个端口,如果是云服务需要去安全组开放两个端口
为了测试一个服务多个实例的情况,我们再配置一个
item-service
的部署实例:然后配置启动项,注意重命名并且配置新的端口,避免冲突:
重启
item-service
的两个实例:访问nacos控制台,可以发现服务注册成功:
点击详情,可以查看到
item-service
服务的两个实例信息:服务发现
服务的消费者要去nacos订阅服务,这个过程就是服务发现,步骤如下:
- 引入依赖
- 配置Nacos地址
- 发现并调用服务
引入依赖
服务发现除了要引入nacos依赖以外,由于还需要负载均衡,因此要引入SpringCloud提供的LoadBalancer依赖。
我们在
cart-service
中的pom.xml
中添加下面的依赖:<!--nacos 服务注册发现-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
可以发现,这里Nacos的依赖于服务注册时一致,这个依赖中同时包含了服务注册和发现的功能。因为任何一个微服务都可以调用别人,也可以被别人调用,即可以是调用者,也可以是提供者。
因此,等一会儿
cart-service
启动,同样会注册到Nacos配置Nacos地址
在
cart-service
的application.yml
中添加nacos地址配置:spring:cloud:nacos:server-addr: 192.168.150.101:8848
发现并调用服务
接下来,服务调用者
cart-service
就可以去订阅item-service
服务了。不过item-service有多个实例,而真正发起调用时只需要知道一个实例的地址。因此,服务调用者必须利用负载均衡的算法,从多个实例中挑选一个去访问。常见的负载均衡算法有:
- 随机
- 轮询
- IP的hash
- 最近最少访问
- ...
这里我们可以选择最简单的随机负载均衡。
另外,服务发现需要用到一个工具,DiscoveryClient,SpringCloud已经帮我们自动装配,我们可以直接注入使用: