一、搭建Gateway网关服务
- 父工程下新建moudle。
- 引入nacos服务发现和gateway依赖。
- 创建目录结构,并创建启动类。
- 创建application.yml文件,并配置包括服务端口、名称信息、nacos地址、路由配置。
具体如下:
1、父工程下新建moudle,即创建gateway服务工程
2、引入nacos服务发现和gateway依赖
<!--网关-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<!--nacos服务发现依赖-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
注:引入依赖后,记得刷新maven!
3、创建目录结构,并创建启动类
package cn.cloud.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* Gateway网关服务启动类
*
* @author PRK
* @date: 2022-11-10 21:55:59
*/
@SpringBootApplication
public class GatewayApplication {
public static void main(String[] args) {
SpringApplication.run(GatewayApplication.class, args);
}
}
4、创建application.yml文件,并配置包括服务端口、名称信息、nacos地址、路由配置:
路由配置包括:
- 路由id:路由的唯一标示
- 路由目标(uri):路由的目标地址,http代表固定地址,lb代表根据服务名负载均衡
- 路由断言(predicates):判断路由的规则,
- 路由过滤器(filters):对请求或响应做处理
server:
port: 10008 # 网关端口
spring:
application:
name: gateway # 服务名称
cloud:
nacos:
server-addr: localhost:8848 # nacos地址
gateway:
routes: #网关路由配置
- id: user-service # 路由id,自定义,只要唯一即可
uri: lb://userservice # 路由的目标地址 lb就是负载均衡,后面跟服务名称;uri: http://127.0.0.1:8081 # 路由的目标地址 http就是固定地址
filters: # 过滤器
- AddRequestHeader=Truth, I freaking awesome! # 添加请求头
predicates: # 路由断言,也就是判断请求是否符合路由规则的条件
- Path=/user/** # 这个是按照路径匹配,只要以/user/开头就符合要求
5、重启网关,并测试
访问http://localhost:10008/user/1(注意该处端口并非userservice服务的端口,而是gateway网关服务端口),符合/user/**
规则,请求转发到uri:http://userservice/user/1,得到了结果: