• Nginx gateway集群和动态网关


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

     

    基于nginx部署gateway集群

    1、将网关项目多个部署启动
    例如:
    网关1 127.0.0.1:81
    网关1 127.0.0.1:82

    在这里插入图片描述
    3、各个微服务如何知道是哪个网关请求的
    在网关的过滤器中给请求头添加可以区别网关的信息。

    动态Gateway

    动态网关:任何配置都实现不用重启网关服务器都可以及时刷新。
    实现思路:
    1、分布式配置中心,阅读性差。
    2、基于数据库表结构设计。

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

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

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

    使用数据库实现动态路由

    根据上面的案例,将配置信息添加到数据库中(数据库表的设计只要符合只用场景就可以了,没有什么特别要求),在调用相关的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

  • 相关阅读:
    golang适合做什么
    indexof
    世界杯海信再出圈,三星:“谈不上愉悦”
    拷贝构造函数、拷贝赋值操作符、移动构造函数,移动赋值操作符
    【Java面试小短文】Spring 如何解决循环依赖?
    如何从小白成长为AI工程师笔记
    2023-09-07 LeetCode每日一题(修车的最少时间)
    JSP forward动作
    [React]useEffect中return函数执行时机
    祥云杯crypto-wp
  • 原文地址:https://blog.csdn.net/qq_19734597/article/details/127363021