搭建两个 nacos 的客户端
我们搭建 alibaba-nacos-consumer 和 alibaba-nacos-provider,就是一个消费者一个提供者
版本依赖【重点-再贴图一次】
创建两个项目,选择依赖
这两个项目的依赖都是一样的,因为 springboot 更新原因,导致创建项目时选择不了低版本,所以直接贴出 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.3.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.powernode</groupId>
<artifactId>01-alibaba-nacos-consumer</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>alibaba-nacos-consumer</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<!-- spring-cloud-alibaba 的当前稳定发行版本 2.2.6 -->
<spring-cloud-alibaba.version>2.2.6.RELEASE</spring-cloud-alibaba.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 添加 nacos 的依赖 -->
<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>
</dependency>
</dependencies>
<!-- 添加 alibaba 的依赖管理 -->
<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>
application.yml
两个配置文件基本一致,注意端口和应用名称
server:
port: 8001
spring:
application:
name: alibaba-nacos-consumer
cloud:
nacos: # 客户端注册的地址
server-addr: localhost:8848
username: nacos
password: nacos
# discovery: # 命名空间 可以做项目隔离
# namespace: car-namespace
# group: dev # 在命名空间下的组别,可以用来做细粒度的隔离
修改两个启动类
@SpringBootApplication
@EnableDiscoveryClient // 这是注解是springcloud的开启服务发现客户端 也就是 nacosServer 的客户端
public class AlibabaNacosConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(AlibabaNacosConsumerApplication.class, args);
}
}
给 alibaba-nacos-provider 添加一个 controller
@RestController
public class ProviderController {
/**
* 打招呼的接口
*
* @param name
* @return
*/
@GetMapping("hello")
public String hello(String name) {
return "hello:"+name;
}
}
启动 alibaba-nacos-provider 测试
启动后去看 nacosServer 的控制台,已经有实例注册上去了
访问测试: http://localhost:8002/hello?name=cxs
给 alibaba-nacos-consumer 添加一个 controller 做服务发现
@RestController
public class ConsumerController {
/**
* 注入服务发现组件 在 eureka 中也用过
*/
@Autowired
private DiscoveryClient discoveryClient;
/**
* 服务发现的接口
*
* @param serviceId
* @return
*/
@GetMapping("discovery")
public String discoveryService(String serviceId) {
// 根据实例名称拿到实例(提供者的应用名)集合
List<ServiceInstance> instances = discoveryClient.getInstances(serviceId);
// 从实例集合列表中获取一个实例对象
ServiceInstance serviceInstance = instances.get(0);
System.out.println(serviceInstance.getHost() + ":" + serviceInstance.getPort());
return serviceInstance.getHost() + ":" + serviceInstance.getPort();
}
}
启动 alibaba-nacos-consumer 测试
先查看 NacosServer 是否注册上线
访问测试 http://localhost:8001/discovery?serviceId=alibaba-nacos-provider
至此,服务注册和服务发现已经完成了,基本和 eureka 一样