电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

spring-cloud-gateway動態路由的實現方法

瀏覽:10日期:2023-07-26 17:50:23
概述

線上項目發布一般有以下幾種方案:

機發布 藍綠部署 滾動部署 灰度發布

停機發布 這種發布一般在夜里或者進行大版本升級的時候發布,因為需要停機,所以現在大家都在研究 Devops 方案。

藍綠部署 需要準備兩個相同的環境。一個環境新版本,一個環境舊版本,通過負載均衡進行切換與回滾,目的是為了減少服務停止時間。

滾動部署 就是在升級過程中,并不一下子啟動所有新版本,是先啟動一臺新版本,再停止一臺老版本,然后再啟動一臺新版本,再停止一臺老版本,直到升級完成?;?k8s 的升級方案默認就是滾動部署。

灰度發布 也叫金絲雀發布,灰度發布中,常常按照用戶設置路由權重,例如 90%的用戶維持使用老版本,10%的用戶嘗鮮新版本。不同版本應用共存,經常與 A/B 測試一起使用,用于測試選擇多種方案。

上邊介紹的幾種發布方案,主要是引出我們接下來介紹的 spring-cloud-gateway 動態路由,我們可以基于動態路由、負載均衡和策略加載去實現 灰度發布。當然現在有很多開源的框架可以實現 灰度發布,這里只是研究學習。

動態路由

spring-cloud-gateway 默認將路由加載在內存中。具體可以參見 InMemoryRouteDefinitionRepository 類的實現。

這里我們基于 Redis 實現動態路由。基礎項目見 spring-cloud-gateway 簡介

1. 將 actuator 的端點暴露出來。

management: endpoints: web: exposure: include: '*'

2. redis 配置

@Configurationpublic class RedisConfig { @Bean(name = {'redisTemplate', 'stringRedisTemplate'}) public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory factory) { StringRedisTemplate redisTemplate = new StringRedisTemplate(); redisTemplate.setConnectionFactory(factory); return redisTemplate; }}

3. 將原內存路由持久化到 redis

@Componentpublic class RedisRouteDefinitionRepository implements RouteDefinitionRepository { /** * hash存儲的key */ public static final String GATEWAY_ROUTES = 'gateway_dynamic_route'; @Resource private StringRedisTemplate redisTemplate; /** * 獲取路由信息 * @return */ @Override public Flux<RouteDefinition> getRouteDefinitions() { List<RouteDefinition> routeDefinitions = new ArrayList<>(); redisTemplate.opsForHash().values(GATEWAY_ROUTES).stream().forEach(routeDefinition -> routeDefinitions.add(JSON.parseObject(routeDefinition.toString(), RouteDefinition.class))); return Flux.fromIterable(routeDefinitions); } @Override public Mono<Void> save(Mono<RouteDefinition> route) { return route.flatMap(routeDefinition -> { redisTemplate.opsForHash().put(GATEWAY_ROUTES, routeDefinition.getId(), JSONObject.toJSONString(routeDefinition)); return Mono.empty(); }); } @Override public Mono<Void> delete(Mono<String> routeId) { return routeId.flatMap(id -> { if (redisTemplate.opsForHash().hasKey(GATEWAY_ROUTES, id)) {redisTemplate.opsForHash().delete(GATEWAY_ROUTES, id);return Mono.empty(); } return Mono.defer(() -> Mono.error(new NotFoundException('route definition is not found, routeId:' + routeId))); }); }}

4. 重寫動態路由服務

@Servicepublic class GatewayDynamicRouteService implements ApplicationEventPublisherAware { @Resource private RedisRouteDefinitionRepository redisRouteDefinitionRepository; private ApplicationEventPublisher applicationEventPublisher; /** * 增加路由 * @param routeDefinition * @return */ public int add(RouteDefinition routeDefinition) { redisRouteDefinitionRepository.save(Mono.just(routeDefinition)).subscribe(); applicationEventPublisher.publishEvent(new RefreshRoutesEvent(this)); return 1; } /** * 更新 * @param routeDefinition * @return */ public int update(RouteDefinition routeDefinition) { redisRouteDefinitionRepository.delete(Mono.just(routeDefinition.getId())); redisRouteDefinitionRepository.save(Mono.just(routeDefinition)).subscribe(); applicationEventPublisher.publishEvent(new RefreshRoutesEvent(this)); return 1; } /** * 刪除 * @param id * @return */ public Mono<ResponseEntity<Object>> delete(String id) { return redisRouteDefinitionRepository.delete(Mono.just(id)).then(Mono.defer(() -> Mono.just(ResponseEntity.ok().build()))).onErrorResume(t -> t instanceof NotFoundException, t -> Mono.just(ResponseEntity.notFound().build())); } @Override public void setApplicationEventPublisher(ApplicationEventPublisher applicationEventPublisher) { this.applicationEventPublisher = applicationEventPublisher; }}

5. 對外暴露接口

@RestController@RequestMapping('/gateway')public class GatewayDynamicRouteController { @Resource private GatewayDynamicRouteService gatewayDynamicRouteService; @PostMapping('/add') public String create(@RequestBody RouteDefinition entity) { int result = gatewayDynamicRouteService.add(entity); return String.valueOf(result); } @PostMapping('/update') public String update(@RequestBody RouteDefinition entity) { int result = gatewayDynamicRouteService.update(entity); return String.valueOf(result); } @DeleteMapping('/delete/{id}') public Mono<ResponseEntity<Object>> delete(@PathVariable String id) { return gatewayDynamicRouteService.delete(id); }}

測試

測試前刪除我們配置的靜態路由,因為靜態路由和 redis 動態路由同時存在時取并集。

訪問 http://localhost:2000/actuator/gateway/routes , 可以看到只有默認路由。

[ { 'route_id': 'CompositeDiscoveryClient_consul', 'route_definition': { 'id': 'CompositeDiscoveryClient_consul', 'predicates': [{ 'name': 'Path', 'args': { 'pattern': '/consul/**' }} ], 'filters': [{ 'name': 'RewritePath', 'args': { 'regexp': '/consul/(?<remaining>.*)', 'replacement': '/${remaining}' }} ], 'uri': 'lb://consul', 'order': 0 }, 'order': 0 }, { 'route_id': 'CompositeDiscoveryClient_idc-gateway', 'route_definition': { 'id': 'CompositeDiscoveryClient_idc-gateway', 'predicates': [{ 'name': 'Path', 'args': { 'pattern': '/idc-gateway/**' }} ], 'filters': [{ 'name': 'RewritePath', 'args': { 'regexp': '/idc-gateway/(?<remaining>.*)', 'replacement': '/${remaining}' }} ], 'uri': 'lb://idc-gateway', 'order': 0 }, 'order': 0 }, { 'route_id': 'CompositeDiscoveryClient_idc-provider1', 'route_definition': { 'id': 'CompositeDiscoveryClient_idc-provider1', 'predicates': [{ 'name': 'Path', 'args': { 'pattern': '/idc-provider1/**' }} ], 'filters': [{ 'name': 'RewritePath', 'args': { 'regexp': '/idc-provider1/(?<remaining>.*)', 'replacement': '/${remaining}' }} ], 'uri': 'lb://idc-provider1', 'order': 0 }, 'order': 0 }, { 'route_id': 'CompositeDiscoveryClient_idc-provider2', 'route_definition': { 'id': 'CompositeDiscoveryClient_idc-provider2', 'predicates': [{ 'name': 'Path', 'args': { 'pattern': '/idc-provider2/**' }} ], 'filters': [{ 'name': 'RewritePath', 'args': { 'regexp': '/idc-provider2/(?<remaining>.*)', 'replacement': '/${remaining}' }} ], 'uri': 'lb://idc-provider2', 'order': 0 }, 'order': 0 }]

這個時候訪問 http://192.168.124.5:2000/idc-provider1/provider1/1 根據結果可以推測能正確路由到 provider1, 測試結果一致。

創建 provider1 路由,將路徑設置為 /p1/**,測試是否生效。

POST 請求 http://localhost:2000/gateway/add

{ 'id':'provider1', 'predicates':[ { 'name':'Path', 'args':{ '_genkey_0':'/p1/**' } }, { 'name':'RemoteAddr', 'args':{ '_genkey_0':'192.168.124.5/16' } } ], 'filters':[ { 'name':'StripPrefix', 'args':{ '_genkey_0':'1' } } ], 'uri':'lb://idc-provider1', 'order':0}

查看 redis 存儲,或者請求 http://localhost:2000/actuator/gateway/routes , 都可以看到配置成功。

訪問

curl http://localhost:2000/p1/provider1/1

結果輸出 2001,與期望一致。

由此可見動態路由已經生效。

到此這篇關于spring-cloud-gateway動態路由的實現方法的文章就介紹到這了,更多相關spring-cloud-gateway動態路由內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 讲师宝经纪-专业培训机构师资供应商_培训机构找讲师、培训师、讲师经纪就上讲师宝经纪 | 北京燃气公司 用户服务中心 | ALC墙板_ALC轻质隔墙板_隔音防火墙板_轻质隔墙材料-湖北博悦佳 | 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | 分子精馏/精馏设备生产厂家-分子蒸馏工艺实验-新诺舜尧(天津)化工设备有限公司 | 儿童乐园|游乐场|淘气堡招商加盟|室内儿童游乐园配套设备|生产厂家|开心哈乐儿童乐园 | 氮化镓芯片-碳化硅二极管 - 华燊泰半导体 | 测试治具|过炉治具|过锡炉治具|工装夹具|测试夹具|允睿自动化设备 | 防火阀、排烟防火阀、电动防火阀产品生产销售商-德州凯亿空调设备有限公司 | 卓能JOINTLEAN端子连接器厂家-专业提供PCB接线端子|轨道式端子|重载连接器|欧式连接器等电气连接产品和服务 | 团建-拓展-拓展培训-拓展训练-户外拓展训练基地[无锡劲途] | 嘉兴泰东园林景观工程有限公司_花箱护栏 | 药品仓库用除湿机-变电站用防爆空调-油漆房用防爆空调-杭州特奥环保科技有限公司 | 日本东丽膜_反渗透膜_RO膜价格_超滤膜_纳滤膜-北京东丽阳光官网 日本细胞免疫疗法_肿瘤免疫治疗_NK细胞疗法 - 免疫密码 | 合肥废气治理设备_安徽除尘设备_工业废气处理设备厂家-盈凯环保 合肥防火门窗/隔断_合肥防火卷帘门厂家_安徽耐火窗_良万消防设备有限公司 | 存包柜厂家_电子存包柜_超市存包柜_超市电子存包柜_自动存包柜-洛阳中星 | 强效碱性清洗剂-实验室中性清洗剂-食品级高纯氮气发生器-上海润榕科学器材有限公司 | 模切之家-专注服务模切行业的B2B平台! | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 | 海外整合营销-独立站营销-社交媒体运营_广州甲壳虫跨境网络服务 焊管生产线_焊管机组_轧辊模具_焊管设备_焊管设备厂家_石家庄翔昱机械 | 北京模型公司-军事模型-工业模型制作-北京百艺模型沙盘公司 | 大米加工设备|大米加工机械|碾米成套设备|大米加工成套设备-河南成立粮油机械有限公司 | 无味渗透剂,泡沫抑尘剂,烷基糖苷-威海威能化工有限公司 | 游泳池设计|设备|配件|药品|吸污机-东莞市太平洋康体设施有限公司 | Magnescale探规,Magnescale磁栅尺,Magnescale传感器,Magnescale测厚仪,Mitutoyo光栅尺,笔式位移传感器-苏州连达精密量仪有限公司 | 高清视频编码器,4K音视频编解码器,直播编码器,流媒体服务器,深圳海威视讯技术有限公司 | 轻型地埋电缆故障测试仪,频响法绕组变形测试仪,静荷式卧式拉力试验机-扬州苏电 | 流量检测仪-气密性检测装置-密封性试验仪-东莞市奥图自动化科技有限公司 | 钢托盘,铁托盘,钢制托盘,镀锌托盘,饲料托盘,钢托盘制造商-南京飞天金属13260753852 | 粉碎机_塑料粉碎机_塑料破碎机厂家-星标机械 | 深圳美安可自动化设备有限公司,喷码机,定制喷码机,二维码喷码机,深圳喷码机,纸箱喷码机,东莞喷码机 UV喷码机,日期喷码机,鸡蛋喷码机,管芯喷码机,管内壁喷码机,喷码机厂家 | 家庭教育吧-在线家庭教育平台,专注青少年家庭教育 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 口臭的治疗方法,口臭怎么办,怎么除口臭,口臭的原因-口臭治疗网 | 纯化水设备-EDI-制药-实验室-二级反渗透-高纯水|超纯水设备 | 氟氨基酮、氯硝柳胺、2-氟苯甲酸、异香兰素-新晨化工 | 空压机网_《压缩机》杂志 | 干粉砂浆设备_干混砂浆生产线_腻子粉加工设备_石膏抹灰砂浆生产成套设备厂家_干粉混合设备_砂子烘干机--郑州铭将机械设备有限公司 | 篮球地板厂家_舞台木地板品牌_体育运动地板厂家_凯洁地板 | 直读光谱仪,光谱分析仪,手持式光谱仪,碳硫分析仪,创想仪器官网 | 烽火安全网_加密软件、神盾软件官网 |