Nacos作为注册中心及配置中心教程
1、Nacos下载
直接去官网下载即可,下载地址在下方,我下载的是最新的2.0.1版本
https://github.com/alibaba/nacos/releases
找不到下载按钮往下拉即可
2、Nacos启动
下载完之后打开bin目录,我们这边自己玩的话,拿单例模式启动就可以了(集群模式要链接数据库),默认配置为集群,所以我们需要修改一下启动文件
2.1、Nacos文件修改
右键编辑startup.cmd文件
将标黄位置改为我一模一样的即可
2.2 、启动Nacos
双击startup.cmd文件即可,Nacos存放位置不要有中文路径,不然会报错
启动完访问http://localhost:8848/nacos/#/login
账号密码为nacos/nacos
3、Nacos作为注册中心
3.1 外层服务构建
新建一个springboot项目,删掉src文件夹,我们拿这个新建的项目用于项目模块中的依赖控制,先给大家看一下大概的目录结构
provider-one 为测试连接Nacos的服务,外层pom版本控制,下面是外层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.1.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.alibaba</groupId>
<artifactId>all</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>all</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>0.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>0.2.2.RELEASE</version>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR11</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!--整合spring cloud alibaba-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.2.1.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
大家可能要问了,springboot版本和springcloud-alibaba的版本对应关系哪里看呢,访问如下网址即可
https://start.spring.io/actuator/info
访问该网址后会给你一串json,我们可以百度一下在线json转换器,转换成我们看的清楚的格式
3.2 创建测试连接服务
在项目名上右键,新建Module,剩下的和创建新的springboot项目无差别,创建完毕之后修改pom文件,把其父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>com.alibaba</groupId>
<artifactId>all</artifactId>
<version>0.0.1-SNAPSHOT</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.ali</groupId>
<artifactId>provider</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>provider</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
3.3、连接Nacos
引入依赖(我在上面pom已引入,版本是我一个一个试出来的,按照我这个版本走肯定没错)
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>0.2.2.RELEASE</version>
</dependency>
接下来新建一个配置文件bootstrap.properties,他的优先级是要比application.properties要高的,里面添加
spring.application.name=provider-one(服务名)
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848(Nacos的地址)
启动类上加上@EnableDiscoveryClient,启动即可
我们登录到Nacos主界面
服务已成功注册上
4、Nacos作为配置中心
上一步的bootstrap.properties中加入
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
spring.cloud.nacos.config.file-extension=properties
spring.cloud.nacos.config.prefix=provider-one
这个用于我们下一步要讲的data id(用来识别作为哪个服务的配置中心),先讲一下data id,他的规则是${prefix}-${spring.profile.active}.${file-extension}
这个是什么意思呢
比如一般${spring.profile.active}
都是空
我配置文件中配置了file-extension与prefix,那我的data id 就是
provider-one.properties
如果${spring.profile.active}
为dev,那data id就是
provider-one-dev.properties,讲解完了之后,我们进入Nacos配置
4.1、 项目引入依赖
跟我相同版本即可,已踩坑,可运行
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>0.2.2.RELEASE</version>
</dependency>
4.2、Nacos配置
进入到如图所示菜单(配置管理-》配置列表),点击加号
保存之后重启项目,注册中心及配置中心就完成了