Nacos服务注册发现功能
背景
项目中快速集成配置中心·Nacos服务注册发现功能
ips技术点
-
@EnableDiscoveryClient注解
- 启用Nacos服务注册发现功能
-
区分不同环境,实现服务注册发现功能
- 登录Nacos控制台,新增dev / test / prod三套不同环境,分别对应:开发环境 / 测试环境 / 生产环境
代码目录结构:
1. 父pom.xml依赖组件
<?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">
<modelVersion>4.0.0</modelVersion>
<groupId>com.jiawen</groupId>
<artifactId>nacos-alibaba-study</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<modules>
<module>nacos-server</module>
</modules>
<properties>
<spring-boot.version>2.0.4.RELEASE</spring-boot.version>
<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</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>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>0.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>com.alibaba.nacos</groupId>
<artifactId>nacos-client</artifactId>
<version>1.1.0</version>
</dependency>
</dependencies>
</dependencyManagement>
</project>
2.nacos-server模块pom.xml
<?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>nacos-alibaba-study</artifactId>
<groupId>com.jiawen</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>nacos-server</artifactId>
<properties>
<spring-cloud-openfeign.version>2.0.0.RELEASE</spring-cloud-openfeign.version>
<spring-cloud-netflix.version>2.0.0.RELEASE</spring-cloud-netflix.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
<version>${spring-cloud-netflix.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
<version>${spring-cloud-openfeign.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<exclusions>
<exclusion>
<groupId>com.alibaba.nacos</groupId>
<artifactId>nacos-client</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.alibaba.nacos</groupId>
<artifactId>nacos-client</artifactId>
</dependency>
</dependencies>
</project>
3.bootstrap.yml
spring:
application:
name: microservice-alibaba-nacos-discovery
profiles:
active: dev
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
namespace: 9f7f1f88-6ae6-419f-bfc6-8fff15590dee
# server
server:
port: 9090
3.NacosApplication.java类
package com.jiawen;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient
public class NacosApplication {
//startup.cmd -m standalone 启动nacos
public static void main(String[] args) {
SpringApplication.run(NacosApplication.class,args);
}
}
然后启动nacos-server服务,将服务注册到nacos中。
我们登录nacos中看下:
发现已经注册进去了。
其他功能的话,小伙伴自己去点一下试试吧。
环境管理
在真正的开发中,我们会有很多环境,下面的话我就只演示下咱们常用到的几大环境在nacos上的切换。
dev:自测环境也叫本地环境。
uat:联调测试环境。
pro:生产环境
我们将项目工程中的配置文件改下。
bootstrap.yml
# 不同的环境使用不同的配置,通过指定启动参数使用不同的profile,比如:
# 开发环境:java -jar xxx.jar --spring.profiles.active=dev
# 生产环境:java -jar xxx.jar --spring.profiles.active=prod
spring:
application:
name: microservice-alibaba-nacos-discovery
profiles:
active: dev
# server
server:
port: 9090
#下面这一行务必不能少,区分不同环境配置,而且必须是三个字符"-"
---
spring:
profiles: dev
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
namespace: 9f7f1f88-6ae6-419f-bfc6-8fff15590dee
---
spring:
profiles: uat
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
namespace: 19ad912d-c35e-4899-90c4-ba86b8fd08a0
---
spring:
profiles: pro
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
namespace: 67ae3d28-8e84-48ef-9d66-9b476f5b500e
其中namespace是你在nacos中创建命名空间的时候随机生成的。如下:
在命名空间的功能中,创建命名空间。
然后比如我们想启动dev环境工程,那么在配置文件中就将:
spring:
application:
name: microservice-alibaba-nacos-discovery
profiles:
active: dev
active改为dev就可以。我们启动项目后就可以看到在nacos中发现dev环境下已经有了服务:
相同的如果切换到uat一样会在uat下发现:
那么到这里nacos的注册与发现功能就结束了。