小知识:Nginx gateway集群和动态网关的实现思路

网关是系统的唯一对外的入口,介于客户端和服务器端之间的中间层,处理非业务功能,提供路由请求、鉴权、监控、缓存、限流等功能。无论你查看任何一个微服务项目架构,你都会发现在客户端和服务器端之间有一个网关,移动端的任何请求都必须经过网关才能到达服务端。

网关怎么实现集群:使用nginx实现。

基于nginx部署gateway集群

1、将网关项目多个部署启动

例如:

网关1 127.0.0.1:81

网关1 127.0.0.1:82

%小知识:Nginx gateway集群和动态网关的实现思路-猿站网-插图

2、各个微服务如何知道是哪个网关请求的

在网关的过滤器中给请求头添加可以区别网关的信息。

动态Gateway

动态网关:任何配置都实现不用重启网关服务器都可以及时刷新。

实现思路:

1、分布式配置中心,阅读性差。

2、基于数据库表结构设计。

gateway提供对应的接口:1、直接新增路由;2、直接修改路由

使用api添加gateway 路由,直接注入该bean 调用 loadRoute1方法就可以添加路由策略了。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
@Service
public class GatewayService implements ApplicationEventPublisherAware {
private ApplicationEventPublisher publisher;
@Autowired
private RouteDefinitionWriter routeDefinitionWriter;
@Override
public void setApplicationEventPublisher(ApplicationEventPublisher applicationEventPublisher) {
this.publisher = applicationEventPublisher;
}
public void initAllRoute() {
// 从数据库查询配置的网关配置
List<GatewayRouteEntity> gateWayEntities = gatewayRouteMapper.gateWayAll();
for (GatewayRouteEntity gw :
gateWayEntities) {
loadRoute(gw);
}
}
public String loadRoute1() {
RouteDefinition definition = new RouteDefinition();
Map<String, String> predicateParams = new HashMap<>(8);
PredicateDefinition predicate = new PredicateDefinition();
FilterDefinition filterDefinition = new FilterDefinition();
Map<String, String> filterParams = new HashMap<>(8);
// 如果配置路由type为0的话 则从注册中心获取服务
URI uri = UriComponentsBuilder.fromUriString(“lb://kaico-member/”).build().toUri();
// 定义的路由唯一的id
definition.setId(“member”);
predicate.setName(“Path”);
//路由转发地址
predicateParams.put(“pattern”, “/member/**”);
predicate.setArgs(predicateParams);
// 名称是固定的, 路径去前缀
filterDefinition.setName(“StripPrefix”);
filterParams.put(“_genkey_0”, “1”);
filterDefinition.setArgs(filterParams);
definition.setPredicates(Arrays.asList(predicate));
definition.setFilters(Arrays.asList(filterDefinition));
definition.setUri(uri);
routeDefinitionWriter.save(Mono.just(definition)).subscribe();
this.publisher.publishEvent(new RefreshRoutesEvent(this));
return “success”;
}
}

使用数据库实现动态路由

根据上面的案例,将配置信息添加到数据库中(数据库表的设计只要符合只用场景就可以了,没有什么特别要求),在调用相关的api添加到gateway中即可。

参考学习文档:https://www.cnblogs.com/crazymakercircle/p/11704077.html

官放文档:https://docs.spring.io/spring-cloud-gateway/docs/3.0.5-SNAPSHOT/reference/html/#gateway-starter

到此这篇关于Nginx gateway集群和动态网关的文章就介绍到这了,更多相关Nginx gateway集群内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_19734597/article/details/127363021

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:在Debian11上安装Openresty服务(Nginx+Lua)的详细教程

2023-3-14 1:15:03

建站知识

小知识:Nginx负载均衡之upstream模块简介与使用详解

2023-3-14 1:33:28

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索