0. nacos简介
Nacos 是阿里巴巴推出来的一个新开源项目,这是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。
Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施
Nacos 支持如下核心特性:
1)服务发现: 支持 DNS 与 RPC 服务发现,也提供原生 SDK 、OpenAPI 等多种服务注册方式和 DNS、HTTP 与 API 等多种服务发现方式。
2)服务健康监测: Nacos 提供对服务的实时的健康检查,阻止向不健康的主机或服务实例发送请求。
3)动态配置服务: Nacos 提供配置统一管理功能,能够帮助我们将配置以中心化、外部化和动态化的方式管理所有环境的应用配置和服务配置。
4)动态 DNS 服务: Nacos 支持动态 DNS 服务权重路由,能够让我们很容易地实现中间层负载均衡、更灵活的路由策略、流量控制以及数据中心内网的简单 DNS 解析服务。
5)服务及其元数据管理: Nacos 支持从微服务平台建设的视角管理数据中心的所有服务及元数据,包括管理服务的描述、生命周期、服务的静态依赖分析、服务的健康状态、服务的流量管理、路由及安全策略、服务的 SLA 以及最首要的 metrics 统计数据。
1.2 常见的注册中心
Eureka(原生,2.0遇到瓶颈,停止维护)
Zookeeper(支持,专业的独立产品。例如:dubbo)
Consul(原生,GO语言开发)
Nacos
相对于 Spring Cloud Eureka 来说,Nacos 更强大。
Nacos = Spring Cloud Eureka + Spring Cloud Config
Nacos 可以与 Spring, Spring Boot, Spring Cloud 集成,并能代替 Spring Cloud Eureka, Spring Cloud Config。
通过 Nacos Server 和 spring-cloud-starter-alibaba-nacos-config 实现配置的动态变更。
通过 Nacos Server 和 spring-cloud-starter-alibaba-nacos-discovery 实现服务的注册与发现。
注:nacos与eureka的区别(简单介绍)
1)nacos和eureka的范围不同,Nacos的阈值是针对某个具体Service的,而不是针对所有服务的;但Eureka的自我保护阈值是针对所有服务的。nacos支持CP和AP两种;eureka只支持AP。nacos使用netty,是长连接; eureka是短连接,定时发送。
2)Eureka保护方式:当在短时间内,统计续约失败的比例,如果达到一定阈值,则会触发自我保护的机制,在该机制下,Eureka Server不会剔除任何的微服务,等到正常后,再退出自我保护机制。自我保护开关(eureka.server. enab1e-self-preservation:false)
Nacos保护方式:当域名健康实例(Instance)占总服务实例(Instance)的比例小于阈值时,无论实例(Instance)是否健康,都会将这个实例(Instance)返回给客户端。这样做虽然损失了一部分流量,但是保证了集群的剩余健康实例(Instance)能正常工作。
1.下载配置nacos
下载地址: https://github.com/alibaba/nacos
如果打不开或者慢的情况下可以使用镜像网站。
页面找到下面这个地方,点击进入,找到合适的版本
本文选用nacos的版本是2.2.0(因为前文spring cloud alibaba 2021.0.5.0)
下载解压后如下:
注意:实际安装路径不能有中文,不然就会报错:
Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'clientOperationServiceProxy' defined in URL
我们创建一个数据库,命名为nacos
然后打开 conf文件夹,找到mysql-schema.sql
在nacos数据库中执行这个sql,执行完后,生成了下面这些表。
然后我们修改nacos的配置
我们打开conf文件夹中的application.properties。
35、38、41~43行取消注释,并修改数据库名、用户名和密码。
再修改配置文件,由集群模式改为单机模式。
我们用vscode或者记事本打开startup.cmd,将 set MODE=”cluster”
set MODE=”standalone”
然后双击运行startup.cmd
然后我们访问:
http://localhost:8848/nacos/#/login
用户名和密码默认都是nacos
到此,注册中心服务端搭建完毕。
2.生产者和消费者引入nacos
生产者和消费可以参考下面过程,首先修改微服务的pom文件,引入nacos依赖
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency>
然后修改application.yml
server: port: 8010 #服务的端口 #spring相关配置 spring: application: name: service-producer #服务的名称 cloud: nacos: discovery: server-addr: localhost:8848
最后在启动类中加入@EnableDiscoveryClient
然后重新启动这个微服务。
另一个微服务也做相同操作。
我们打开服务注册中心,打开服务列表。
可以看到两个服务都在服务中心上线了。