当前文档为学习笔记,编辑中
Nacos简介
名字的由来
Naming + Configuration Service => Nacos
基本简介
一个更易于构件云原生应用的动态服务发现、配置管理和服务管理平台。 ——摘自Nacos github
即 注册中心 + 配置中心,代替 Eureka + Config + Bus
下载地址
中文官网:https://nacos.io/zh-cn/
官网:https://github.com/alibaba/Nacos
下载地址:https://github.com/alibaba/nacos/tags
当前我使用的版本是1.3.2,官网可能下载慢,我会上传上来,但是考虑到日后可能进行版本更新,故而附上官网地址和下载地址用户可自行下载
各注册中心的比较
服务注册与发现框架 | CAP模型 | 控制台管理 | 社区活跃度 |
---|---|---|---|
Eureka | AP | 支持 | 低 |
Zookeeper | CP | 不支持 | 中 |
Consul | CP | 支持 | 高 |
Nacos | AP | 支持 | 高 |
这里提到了CAP模型,详见这里
安装并运行Nacos
- 下载:Nacos-1.3.2
- 安装:无需安装,解压后直接启动
- 启动:
下载完毕后是个zip压缩包,解压后如图所示
进入bin文件夹,如图所示
cmd后缀为windos启动文件,sh为Linux启动文件,所以下载后的nacos两系统通用 - 访问:启动完毕后,访问 http://127.0.0.1:8848/nacos
- 登录:账号密码:nacos/nacos
服务注册中心
官网文档
https://spring.io/projects/spring-cloud-alibaba#learn
服务提供者
接下来我会在eclipse中新建一个项目,项目的完整代码将在下面展示,当然,后续我也把会项目源码打包上传上来;
- 新建项目
项目名称:mjchen-nacos9001 - 完成POM文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.9.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.cloud</groupId>
<artifactId>naocs9001</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>naocs9001</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud-alibaba.version>2.2.1.RELEASE</spring-cloud-alibaba.version>
<maven-jar-plugin.version>3.1.1</maven-jar-plugin.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR6</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!-- <dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency> -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- <dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency> -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>${spring-cloud-alibaba.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
- 我这里的配置文件是 properties
server.port = 9001
# 配置服务名
spring.application.name = nacos-payment-provider
# 配置nacos地址
spring.cloud.nacos.discovery.server-addr = 127.0.0.1:8848
# 监控全部打开(监控啥我忘了,日后再说)
management.endpoints.web.exposure.include = *
- 编写主启动类,主要是 @EnableDiscoveryClient
package com.cloud.naocs9001;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient
public class Naocs9001Application {
public static void main(String[] args) {
SpringApplication.run(Naocs9001Application.class, args);
}
}
- 书写业务类
package com.cloud.naocs9001.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class PaymentController {
@Value("${server.port}")
private String serverPort;
@GetMapping("/payment/nacos/{id}")
public String getPayment(@PathVariable("id") Integer id) {
return "nacos registry,serverPort: " + serverPort + "\t id = " + id;
}
}
- 测试
a. 测试nacos是否启动成功,及访问8848端口看能不能访问管理系统
b. 测试服务是否注册进了nacos,即查看nacos服务,看有没有 nacos-payment-provider 服务 - 负载均衡
根据上述的步骤,重新创建一个相同的项目9002,来试一下负载均衡。
服务注册中心对比
服务配置中心
基础配置
- 新建项目
- POM
- YML
- 主启动
- 业务类
- 在Nacos中添加配置信息
Nacos中的匹配规则
理论:
Nacos中的dataid的组成格式及与SpringBoot配置文件中的匹配规则
dataId的完整格式如下:
${prefix}-${spring.profile.active}.${file-extension}
spring.profile.active也可以为空,此时就变成了下面的格式,但是不推荐!
${prefix}.${file-extension}
实操: