本章主要介绍nacos的服务注册与发现
一、需要注意的就是依赖问题,在网上了解好springboot、springcloud和springcloualibaba的版本对应关系
# 父工程约束:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.2.5.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR9</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
二、需要添加依赖(版本号已经在父工程约定,可以对应上面的版本)
<!-- 微服务基础依赖 -->
<dependencies>
<!-- web的场景依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 端点监控场景依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!-- 服务注册与发现的场景依赖 -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
</dependencies>
三、开始搭建服务提供方
- 配置文件:
spring:
application:
name: provider #服务名称,必须,保证唯一
cloud:
nacos:
discovery:
server-addr: 192.168.44.1:8848 #指定nacos-server的地址
username: nacos
password: nacos
namespace: dev
group: test-dubbo
server:
port: 9999
- 启动类开启服务注册发现
@EnableDiscoveryClient //开关,开启服务的注册与发现功能
四、开始搭建服务消费方
- 配置文件
spring:
application:
name: comsumer #服务名称,必须,保证唯一
cloud:
nacos:
discovery:
server-addr: 192.168.44.1:8848 #指定nacos-server的地址
username: nacos
password: nacos
namespace: dev
group: test-dubbo
server:
port: 8888
- 启动类开启服务注册发现,注入RestTemplate需要两个注解
@EnableDiscoveryClient //开关,开启服务的注册与发现功能
- 使用RestTemplate实现服务调用,在需要调用的地方注入RestTemplate,发起调用的时候使用提供方微服务名称
- 使用OpenFeign调用
- 首先需要添加openfeign的依赖,版本是父工程springcloud约束的
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
- OpenFeign主要是调用远程服务的,一般在服务消费方使用,在启动类开启OpenFeign,扫描需要使用OpenFeign的包
- 在调用方新建远程服务接口
- 在需要使用远程服务的地方注入接口