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

然后重新启动这个微服务。

另一个微服务也做相同操作。

我们打开服务注册中心,打开服务列表。

可以看到两个服务都在服务中心上线了。