简介
作用:
- 注册中心
- 配置中心
注册中心:微服务拆分后,使用网络请求在各个服务之间进行调用,就会出现各个服务之间的调用错综复杂、难以维护。注册中心的作用就是管理所有微服务、解决微服务之间调用关系错综复杂、难以维护的问题
Nacos是一个更易于构建云原生应用的动态服务发现、服务配置和服务管理平台
注册中心原理
服务注册
Nacos Client会通过发送Rest请求的方式想Nacos Server注册自己的服务,提供自身的元数据,如IP地址、端口等信息,Server收到注册请求后,会把信息存储在一个双层的内存Map中
服务心跳
在注册后,Nacos Client会维护一个定时心跳来持续通知Server,确保自己一直处于可用状态,防止被删除,默认5秒发送一次
服务同步
Nacos Server集群之间会相互同步服务实例,用来保证数据的一致性
服务发现
服务消费者(Nacos Client)在调用服务提供者的服务时,会发送一个Rest请求给Server,获取已注册的服务清单,并且缓存到本地,同时会开启一个定时任务拉取服务端最新的注册信息到本地
服务健康值
Nacos Server会开启一个定时任务用来检查注册表的实例的健康情况,对于超过15秒没有收到Client心跳的实例会将其healthy设置为false(Client进行服务发现时不会获取到),如果实例超过30秒没有心跳,直接剔除实例(被剔除实例回复心跳则会重新注册)
各注册中心对比
服务端安装
根据SpringCloud Alibaba官方各版本对应下载Nacos版本
运行nacos/bin下的脚本即可启动,注意,默认时集群模式启动,单机模式需要修改
# 调整此处
set MODE="cluster"
# 根据代码看可以选择standalone(单机)、cluster(集群)
if %MODE% == "standalone" (
echo "nacos is starting with standalone"
set "NACOS_OPTS=-Dnacos.standalone=true"
set "NACOS_JVM_OPTS=-Xms512m -Xmx512m -Xmn256m"
)
rem if nacos startup mode is cluster
if %MODE% == "cluster" (
echo "nacos is starting with cluster"
if %EMBEDDED_STORAGE% == "embedded" (
set "NACOS_OPTS=-DembeddedStorage=true"
)
set "NACOS_JVM_OPTS=-server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=%BASE_DIR%\logs\java_heapdump.hprof -XX:-UseLargePages"
)
其余端口等信息在nacos/conf/application.properties中修改
启动成功后根据提示访问http://localhost:8848/nacos/index.html即可看到服务端后台
默认用户名和密码都是nacos
客户端安装
添加依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
项目启动报错
***************************
APPLICATION FAILED TO START
***************************
Description:
Parameter 0 of method ribbonServerList in com.alibaba.cloud.nacos.ribbon.NacosRibbonClientConfiguration required a bean of type 'com.netflix.client.config.IClientConfig' that could not be found.
Action:
Consider defining a bean of type 'com.netflix.client.config.IClientConfig' in your configuration.
Disconnected from the target VM, address: '127.0.0.1:62141', transport: 'socket'
这是个BUG,项目启动类放在了com包下造成的,需要防止到com.xxx下,也就是多加一个包就可以了
项目启动出现WARN
启动项目控制台出现WARN的No URLs will be polled as dynamic configuration sources.
原因是没有找到配置文件
解决办法,在项目resources下加一个config.properties空文件
服务相互调用
@Bean
@LoadBalanced // 开启请求解析和负载均衡
public RestTemplate restTemplate() {
return new RestTemplate();
}
请求其他服务
@Resource
private RestTemplate restTemplate;
@RequestMapping("/test")
public String test() {
System.out.println("订单");
String res = restTemplate.getForObject("http://stock-service/stock/test", String.class);
return "order" + res;
}
其中stock-service为服务名
nacos集群
集群搭建也是用的是下载的nacos包,然后需要修改一下内容,注意集群下注册中心的内容需要写到MySQL数据库中
配置文件conf/application.properties
# 端口
server.port=8848
# 开启数据库
spring.datasource.platform=mysql
# 数据库连接数量
db.num=1
# 数据库连接信息
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user.0=nacos
db.password.0=nacos
开启数据库后记得创建数据库及其表,表的创建脚本在conf/nacos-mysql.sql
然后复制一份conf/cluster.conf.example为cluster.conf,编辑集群的服务地址
#it is ip
#example
192.168.16.101:8847
192.168.16.102
192.168.16.103
编辑bin/startup,确保集群模式启动
export MODE="cluster"
其中的启动内存可以根据需求进行调整
JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"
其余服务器同理,一个服务器能启动后,其余可以直接拷贝过去
注意:搭建好集群后,服务端如果只向一个注册,如果宕机就无法注册,所以需要使用Nginx进行nacos的集群负载,nacos想Nginx的地址注册