SpringCloud Alibaba【三】Gateway
Gateway配置与使用
- 前言
- 新建gateway子项目
- pom.xml
- 配置文件
- 启动类
- 访问接口方式
- 测试
- 拓展
前言
在工作中遇到一种情况,一个父项目中有两个子项目。实际使用时,需要外网可以访问,宝信软件只能将一个端口号发布在外网上,所以需要运用网关技术,通过一个端口号访问两个项目。
之前已经试用nacos搭建了注册中心
新建gateway子项目
pom.xml
导入依赖时注意SpringCloudAlibaba与gateway依赖的版本是否对应,否则启动时会报错。
<?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>testmaven32springcloud</artifactId>
<groupId>com.hzx</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>gateway-project</artifactId>
<dependencies>
<!-- 此依赖已经在父项目pom中导入
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>2.2.7.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
<version>2.2.6.RELEASE</version>
</dependency>
</dependencies>
</project>
配置文件
将gateway服务注册到nacos中
server:
port: 8901
spring:
cloud:
nacos:
discovery:
server-addr: http://192.168.0.248:8848
namespace: e6f0f8ad-e4c1-408b-afae-4a2495911ca7
gateway:
discovery:
locator:
enabled: true
application:
name: nacos-gateway
启动类
在启动类中需要加上注解:@EnableDiscoveryClient
@SpringBootApplication
@EnableDiscoveryClient
public class StartGatewayApplication {
public static void main(String[] args) throws Exception {
SpringApplication.run(StartGatewayApplication.class, args);
}
}
以上就是gateway相关的代码,启动成功后就可以使用了。
我在学习的时候没想到这么简单。
访问接口方式
http://ip:网关端口/nacos中注册的服务名称/controller层路径
具体内容见测试部分
测试
上一篇讲nacos的文章中,我创建了两个子项目,分别是:nacos-provider-project、nacos-consumer-project,连同gateway项目启动后,在nacos可以看到注册的服务。
在nacos-provider-project项目添加接口
@RequestMapping(value = "/send/provider/{msg}",method = RequestMethod.GET)
public String sendMessageProvider(@PathVariable String msg){
return "调用生产者端接口,向生产者发送消息:"+msg;
}
在nacos-consumer-project项目添加接口
@RequestMapping(value = "/send/consumer/{msg}",method = RequestMethod.GET)
public String sendMessageConsumer(@PathVariable String msg){
return "调用消费者端接口,向消费者发送消息:"+msg;
}
通过接口文档测试上面的两个接口
首先是直接通过项目本身的端口号访问接口。其中8081和8091分别是两个项目的端口号。
然后通过网关端口分别访问两个接口。其中8901为gateway项目端口号,nacos-provider与nacos-consumer分别为两个项目在nacos注册中心的服务名称。
拓展
本文中使用的是gateway默认配置网关的方法,开发者还可以自定义配置路由,也可以不通过注册在nacos中的服务名就能访问接口,但这两种方法目前本人还不需要,所以文章中没有写出。