文章目录
- 前言
- 【idea版】springcloud微服务(3)之整合注册发现和配置中心Nacos使用
- 1.什么是 Nacos?
- 2.Nacos安装
- 3.创建项目
- 4.引包
- 1)父pom.xml依赖
- 2)pom.xml的基础web包文件
- 5.使用Nacos
- 1)使用Nacos的服务注册/发现
- 2)使用Nacos的配置中心
- 3)使用Nacos的配置中心多文件使用
- extension-configs
- shared-configs
- 优先级
前言
【idea版】springcloud微服务系列搭建教程,包括整合nacos、mybatisplus、redis、gateway、ribbion、Rocketmq等
【idea版】springcloud微服务(3)之整合注册发现和配置中心Nacos使用
1.什么是 Nacos?
Nacos 致力于帮助您发现、配置和管理微服务一体。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。
2.Nacos安装
安装教程样例:
Nacos官网:安装教程
1)Linux下的Nacos集群部署
2)linux之docker安装单机nacos
3)Linux之docker安装部署nacos集群
安装成功之后的访问:http://IP:8848/nacos/index.html
3.创建项目
根据教程:【idea版】springcloud微服务(1)之多模块版本新建一个springcloud项目
创建一个子模块:springcloud-nacos-example
4.引包
1)父pom.xml依赖
<properties>
<spring-boot.version>2.4.3</spring-boot.version>
<spring-cloud.version>2020.0.2</spring-cloud.version>
<spring-cloud-alibaba.version>2.2.1.RELEASE</spring-cloud-alibaba.version>
<java.version>11</java.version>
<maven.compiler.source>11</maven.compiler.source>
<maven.compiler.target>11</maven.compiler.target>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<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>
2)pom.xml的基础web包文件
<?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-example</artifactId>
<groupId>org.example</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>springcloud-nacos-example</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.3.5.RELEASE</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>11</source>
<target>11</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
5.使用Nacos
1)使用Nacos的服务注册/发现
第一步: 引入服务注册的包
<!--这个是springcloud2020版之后要加的引包,不然会读取不到nacos配置中心的文件-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
第二步:配置文件bootstrap.properties(或bootstrap.yml)
server:
port: 9001
spring:
application:
name: nacos-server #服务名
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848 #nacos服务地址
namespace: f99717b6-4b29-443a-afac-c949d634e648 #命名空间,在nacos界面上操作新增空间名称
第三步:启动类加注解:@EnableDiscoveryClient
package com.example;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
/**
* @description:
* @time: 2021/5/25 9:57
*/
@SpringBootApplication
@EnableDiscoveryClient
public class NacosApplication {
public static void main(String[] args) {
SpringApplication.run(NacosApplication.class, args);
}
}
启动就在nacos上看到注册上去看到注册的服务了
2)使用Nacos的配置中心
注:我这里使用Nacos配置中心,已经完成了Nacos注册步骤代码
第一步: 引入配置中心的包
注:springcloud2020版之后要加的引包spring-cloud-starter-bootstrap,不然会读取不到nacos配置中心的文件
<!--这个是springcloud2020版之后要加的引包,不然会读取不到nacos配置中心的文件-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
第二步:配置文件bootstrap.properties(或bootstrap.yml)
server:
port: 9001
spring:
application:
name: nacos-server #服务名
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848 #nacos服务地址
namespace: f99717b6-4b29-443a-afac-c949d634e648 #命名空间,在nacos界面上操作新增空间名称
config:
file-extension: yaml #文件类型,名字是默认用服务名
namespace: f99717b6-4b29-443a-afac-c949d634e648 #命名空间
server-addr: 127.0.0.1:8848 #nacos服务地址
第三步:使用配置中心的内容:
打开nacos界面,在配置管理新建配置文件
注:要选择创建好的命名空间里新建文件
输入内容:Data ID:nacos-server,组就用默认的,配置格式:yaml,然后点击发布就行
完成配置文件
第四步:代码使用,直接使用@Value("${test}")
获取配置文件的值
注:通过 Spring Cloud 原生注解 @RefreshScope 实现配置自动更新:
package com.example.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @description:
* @time: 2021/5/25 9:58
*/
@RestController
@RefreshScope
public class TestController {
@Value("${test}")
private String testVal;
@RequestMapping("/test")
public String test(){
return testVal;
}
}
第五步:测试数据url http://127.0.0.1:9001/test
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OUrVtVbv-1621914804905)(C:\Users\libingwei\AppData\Roaming\Typora\typora-user-images\image-20210525115047599.png)]
3)使用Nacos的配置中心多文件使用
extension-configs
nacos界面操作:
- data-id名称,这个名字在nacos新建的时候,后缀要一起带上,不能和默认的config,新建的时候只用服务名
- data-id的文件后缀必须和配置格式一样
注:
- data-id不支持动态刷新,需要配置refresh=true
- [x],数值越大,优先级越高
配置样例:
spring:
application:
name: nacos-server #服务名
cloud:
nacos:
discovery:
server-addr: 192.168.56.121:8848
namespace: f99717b6-4b29-443a-afac-c949d634e648
config:
file-extension: yaml #文件类型,名字是默认用服务名
namespace: f99717b6-4b29-443a-afac-c949d634e648 #命名空间
server-addr: 192.168.56.121:8848 #nacos服务地址
#拓展extension-configs文件,
#data-id的文件后缀必须和配置格式一样
#data-id名称,这个名字在nacos新建的时候,后缀要一起带上,不能和默认的config,新建的时候只用服务名
#data-id不支持动态刷新,需要配置refresh=true
extension-configs[0]:
data-id: test0.yaml
refresh: true
extension-configs[1]:
data-id: test1.yaml
group: TEST #分组
refresh: true #是否动态刷新,默认不支持
shared-configs
界面操作和extension-configs一样
配置样例:
spring:
cloud:
nacos:
config:
shared-configs[0]:
data-id: test0.yaml
refresh: true
shared-configs[1]:
data-id: test1.yaml
group: TEST
refresh: true
优先级
默认加载> extension-configs>shared-configs