前文目录
SpringCloud Alibaba Nacos注册中心生产消费
前言
Nacos作为Alibaba 出品的注册中心,可以说是我用过的几个注册中心产品作为强大的一个了
他不仅是一个服务的注册中心,也是一个配置中心.相当于他把springcloud组件里的eureka和config组合在了一起.通过控制台上一些简单的操作就可以实现对配置的添加修改,同时还支持热更新!
官网文档:https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html
这里我还遇到了个不算问题的一个问题,现在还没找到解决答案,最后再说!
添加依赖
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>springcloud-alibaba-learn</artifactId>
<groupId>com.zhbcm</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>nacos-discovery-config</artifactId>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<spring-boot.version>2.3.0.RELEASE</spring-boot.version>
<spring-cloud-alibaba.version>2.2.1.RELEASE</spring-cloud-alibaba.version>
</properties>
<dependencies>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</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-discovery</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>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</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>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!-- spring-cloud-dependencies -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR3</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
配置文件
bootstrap.properties
#\u5185\u5D4C\u7684web\u670D\u52A1\u5668\u7AEF\u53E3
server.port=7070
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
#nacos\u7684\u7528\u6237\u540D\u548C\u
#\u8BE5\u914D\u7F6E\u9879\u76EE\u7B49\u4E8Enacos\u914D\u7F6E\u4E2D\u5FC3\u914D\u7F6E\u7684 Data Id\uFF1Aalibaba-nacos-config-client
spring.application.name=nacos-discovery-config
#nacos\u6CE8\u518C\u4E2D\u5FC3\u7684\u8FDE\u63A5\u5730\u5740
#spring.cloud.nacos.discovery.server-5BC6\u7801
spring.cloud.nacos.username=nacos
spring.cloud.nacos.password=nacos
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
#nacos\u914D\u7F6E\u6587\u4EF6\u7684\u6269\u5C55\u540E\u7F00
#spring.cloud.nacos.config.file-extension=properties
#spring.cloud.nacos.config.group=DEV_GROUP
#\u6307\u5B9A\u547D\u540D\u7A7A\u95F4\uFF0C\u590D\u5236id
#spring.cloud.nacos.config.namespace=1d44862f-51a7-4532-971e-7f4f247824d3
#\u662F\u5426\u5F00\u542F\u914D\u7F6E\u7684\u81EA\u52A8\u5237\u65B0\uFF0C\u9ED8\u8BA4\u662Ftrue\u8868\u793A\u81EA\u52A8\u5237\u65B0
spring.cloud.nacos.config.refresh-enabled=true
#spring.profiles.active=dev
#spring.cloud.nacos.discovery.namespace=public
#spring.cloud.nacos.discovery.group=DEV_GROUP
bootstrap优先级高于application
这里根据官网的教程有一些细节上的问题
配置细节
dataId命名规则
-
${prefix}-${spring.profiles.active}.${file-extension}
prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。 -
spring.profiles.active 即为当前环境对应的 profile,详情可以参考 Spring Boot文档。 注意:当 spring.profiles.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成
${prefix}.${file-extension}
-
file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 properties 和 yaml 类型。
举个栗子,比如我现在在控制台上配置properties,我的服务名是nacos-discovery-config
,那么我的dataId就是nacos-discovery-config.properties
,但是这里我试一下即使没有后缀也能访问到!
配yaml
spring.cloud.nacos.config.file-extension=yaml
自定义分组
spring.cloud.nacos.config.group=DEV_GROUP
启动类测试
控制台配置图:
代码:
package com.zhbcm.nacos;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.context.ConfigurableApplicationContext;
import java.util.concurrent.TimeUnit;
@EnableDiscoveryClient
@SpringBootApplication
public class ConfigApp
{
public static void main(String[] args) throws InterruptedException {
ConfigurableApplicationContext applicationContext = SpringApplication.run(ConfigApp.class, args);
while(true) {
//当动态配置刷新时,会更新到 Enviroment中,因此此处每隔一秒从Enviroment中获取配置
String userName = applicationContext.getEnvironment().getProperty("user.name");
String userAge = applicationContext.getEnvironment().getProperty("user.age");
System.out.println("user name : " + userName + "; age: " + userAge);
//获取当前部署的环境
String currentEnv = applicationContext.getEnvironment().getProperty("current.env");
System.err.println("in [ "+currentEnv+" ] enviroment; "+"user name :" + userName + "; age: " + userAge);
TimeUnit.SECONDS.sleep(1);
}
}
}
这个时候控制台打印就OK
最后的问题
不知道是不是版本的问题,我虽然可以拿到到配置中心的配置,但是一直显示401,百度了一圈没有找到,后续需要接着研究!
大佬的解决
昨天nacos不是一直报401吗,我一直没有解决找来了茶佬. 茶佬非常热心远程操作解决问题!他通过打印日志的地方进行断点调试发现两次请求不同就猜到了可能是版本不一致,而且官网也说到了
开启鉴权功能后,服务端之间的请求也会通过鉴权系统的影响。考虑到服务端之间的通信应该是可信的,因此在1.2~1.4.0版本期间,通过User-Agent中是否包含Nacos-Server来进行判断请求是否来自其他服务端。
但这种实现由于过于简单且固定,导致可能存在安全问题。因此从1.4.1版本开始,Nacos添加服务身份识别功能,用户可以自行配置服务端的Identity,不再使用User-Agent作为服务端请求的判断标准。
我本地的nacos服务是1.1.x,直接升级1.2.x,解决了报错问题