如何搭建Gateway服务
- Gateway的简单介绍
- Spring Cloud Gateway是Spring Cloud的一个项目,该项目是基于Spring,Spring Boot和Project Reactor等响应式编程和事件流技术开发的网关,它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式。
- Gateway网关可以是所有微服务的统一入口,具有请求路由、权限控制、限流的功能特性
- 权限控制:网关作为微服务入口,需要校验用户是否有请求资格,如果没有则进行拦截
- 路由和负载均衡:一切请求都必须先经过gateway,但网关不处理业务,而是根据某种规则,把请求转发到某个微服务,这个过程叫做路由。当然路由的目标服务有多个时,还需要做负载均衡
- 限流:当请求流量过高时,在网关中按照下游的微服务能够接受的速度来放行请求,避免服务压力过大
- 在Spring Cloud中网关的实现有gateway、zuul,但Zuul是基于Servlet的实现,属于阻塞式编程,而Spring Cloud Gateway则是基于Spring5中提供的WebFlux,属于响应式编程的实现,具备更好的性能
- 那么现在我们就开始简单的搭建gateway服务
- 首先创建gateway的maven项目,并在maven的pom文件中添加依赖
-
<!-- Nacos依赖 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><!--网关--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency>
- 编写gateway的spring boot的启动类
-
package com.app.user;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** spring boot启动类** @author Administrator*/
@SpringBootApplication
public class GatewayApplication {public static void main(String[] args) {SpringApplication.run(GatewayApplication.class, args);}
}
- 创建application.yml文件,并编写基础的配置信息以及路由规则
-
server:port: 12080
spring:application:#应用的名称name: gateway-servicecloud:nacos:# Nacos Server 启动监听的ip地址和端口server-addr: 192.168.xxx.xxx:8848discovery:# nacos开启鉴权之后的用户名username: nacos# nacos开启鉴权之后的用户登录密码password: nacosgateway:# 网关的路由配置routes:# 路由id,自定义,只要唯一即可- id: nacos-feign-user-service# 路由的目标地址,lb就是负载均衡,后面跟服务名称uri: lb://nacos-feign-user-service# 路由断言,也就是判断请求是否符合路由规则的条件predicates:# 这个是按照路径匹配,只要以/users/开头就符合要求- Path=/users/**
- 启动gateway-service服务,访问http://127.0.0.1:12080/users/2时,符合/users/**规则,然后请求转发到uri:http://nacos-feign-user-service/users/2
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/226576.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!