日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

如何為Spring Cloud Gateway加上全局過濾器

瀏覽:161日期:2023-07-20 08:43:47

既然是一個網關。那么全局過濾器肯定是少不了的一個存在。像是鑒權、認證啥的不可能每個服務都做一次,一般都是在網關處就搞定了。Zuul他就有很強大的過濾器體系來給人使用。Gateway當然也不會差這么點東西。對于SpringCloud體系來說,一切的實現(xiàn)都是那么的簡單。那么廢話不多說,直接開始寫起來。 Gateway內部有一個接口 名為GlobalFilter,這個就是Gateway的全局過濾器接口,只要在應用中實現(xiàn)此接口后注冊為Spring的Bean,背后就會幫你將這個實現(xiàn)注冊到全局過濾器鏈條里邊去。我這里就簡單的寫了個模擬鑒權的過濾器實現(xiàn):

@Componentpublic class AuthFilter implements GlobalFilter, Ordered { @Override public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { String token = exchange.getRequest().getHeaders().getFirst('Authorization'); //不為空則通過 if (!StringUtils.isEmpty(token)) return chain.filter(exchange); ServerHttpResponse response = exchange.getResponse(); // 封裝錯誤信息 Map<String, Object> responseData = Maps.newHashMapWithExpectedSize(3); responseData.put('code', HttpStatus.UNAUTHORIZED.value()); responseData.put('message', 'Token is empty'); responseData.put('cause', 'Token is empty'); // 將信息轉換為 JSON ObjectMapper objectMapper = new ObjectMapper(); byte[] data = new byte[0]; try { data = objectMapper.writeValueAsBytes(responseData); } catch (JsonProcessingException e) { e.printStackTrace(); } // 返回錯誤信息json DataBuffer buffer = response.bufferFactory().wrap(data); response.setStatusCode(HttpStatus.UNAUTHORIZED); response.getHeaders().add('Content-Type', 'application/json;charset=UTF-8'); return response.writeWith(Mono.just(buffer)); } //最后執(zhí)行 @Override public int getOrder() { return Ordered.LOWEST_PRECEDENCE; }}

雖說是鑒權,但實際上我這就是個簡單的demo而已。想知道真正的Spring Security鑒權/認證怎么寫?我以前寫的這個:https://github.com/skypyb/code_demo/tree/master/spring-security-demo 應該可以幫助你。 看我寫的這個過濾器內部實現(xiàn)哈,其實就是拿出Request Header中的 Authorization字段(token) 然后判斷是否存在。不存在就返回錯誤,存在就交給鏈條中的下一個過濾器。 過濾器其實也沒啥好說的,那么說說限流。關于限流這個東西,常見的算法就是漏桶和令牌桶了,對于一個應用單機限流來說也復雜不到哪兒去。靠著google guava包里的RateLimiter工具都能搞定大多數(shù)場景了。不過既然人家Gateway好心好意給你搞了個限流的實現(xiàn)。那么還是尊重他用一下。由于Gateway是用的Redis和lua腳本實現(xiàn)了令牌桶的算法,那么先導入幾個需要的依賴:

<!--Redis begin--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis-reactive</artifactId> </dependency> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> </dependency> <!--Redis end-->

既然是Redis,那還是先配一下Redis序列化先:

@Configurationpublic class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) { RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); StringRedisSerializer stringRedisSerializer = new StringRedisSerializer(); redisTemplate.setKeySerializer(stringRedisSerializer); redisTemplate.setHashKeySerializer(stringRedisSerializer); redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<Object>(Object.class)); redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer()); redisTemplate.setConnectionFactory(connectionFactory); return redisTemplate; }}

萬事俱備,開始進行限流的具體實現(xiàn)了。 既然是限流,那么也得有個限流策略是根據(jù)用戶來限流呢?還是說根據(jù)請求路徑限流?或者是IP限流?不過這個都是由需求來決定了,我這就簡單的寫個根據(jù)IP來限流的。人家也給你封裝完畢了,只需要你自己實現(xiàn)KeyResolver這個接口就可以。由于實現(xiàn)這個一般來說也就一行代碼,所以我就不寫個單獨的類去實現(xiàn)了,而是直接寫在配置類里邊。

@Configurationpublic class GatewayRateLimiterConfig { /** * Gateway通過內置的RequestRateLimiter過濾器實現(xiàn)限流,用的是令牌桶算法,借助Redis保存中間數(shù)據(jù) * 這里自定義一個KeyResolver * 作用是對來源ip進行限流 */ @Bean(value = 'ipKeyResolver') public KeyResolver ipKeyResolver() { return exchange -> Mono.just(exchange.getRequest().getRemoteAddress().getAddress().getHostAddress()); }}

看,我其實只需要返回我需要限制的東西就可以了。我這里提取到用戶的IP將其返回,即可實現(xiàn)通過ip來進行限流的策略。不過限流相關的配置寫了,那也得用起來。這個怎么用起來? 其實直接在配置文件里配置就OK了

spring: application: # 應用名稱 name: sc-demo-alibaba-gateway cloud: nacos: discovery: server-addr: 192.168.3.105:8848 #注冊進nacos # 使用 Sentinel 作為熔斷器 sentinel: transport: port: 18102 dashboard: 192.168.3.105:8858 # 路由網關配置 gateway: # 這里是設置與服務注冊發(fā)現(xiàn)組件結合,這樣可以采用服務名的路由策略 discovery: locator: enabled: true # 配置路由規(guī)則 routes: - id: ROUTER#sc-demo-alibaba-consumer #這個是路由ID,需要保證在所有路由定義中唯一,值隨便寫就是了 # 采用 LoadBalanceClient 方式請求,以 lb:// 開頭,后面的是注冊在 Nacos 上的服務名 uri: lb://sc-demo-alibaba-consumer predicates: # Method ,這里是匹配 GET 和 POST 請求 - Method=GET,POST filters: - name: RequestRateLimiter args:redis-rate-limiter.burstCapacity: 20redis-rate-limiter.replenishRate: 5key-resolver: ’#{@ipKeyResolver}’ - id: ROUTER#sc-demo-alibaba-provider uri: lb://sc-demo-alibaba-provider predicates: - Method=GET,POST #Redis配置 redis: host: 192.168.3.105 port: 6379 #Redis連接池配置 jedis: pool: min-idle: 0 max-idle: 8 max-active: 8 max-wait: -1msserver: port: 8888feign: sentinel: enabled: truemanagement: endpoints: web: exposure: include: '*'# 配置日志級別,方別調試logging: level: org.springframework.cloud.gateway: debug

這里可以看到,除了Redis配置 ( spring.redis.** )以外。主要就是對于Getway的配置。在Gateway路由配置中,設置了一個filters參數(shù)。這個是為了指定路由的各種過濾器的。這個參數(shù)也有很多種,可以參考官方講解: https://cloud.spring.io/spring-cloud-gateway/2.0.x/single/spring-cloud-gateway.html#gateway-route-filters

我這就是指定了一個RequestRateLimiter,請求限流。

redis-rate-limiter.burstCapacity: 20

這個參數(shù)表示突發(fā)容量,即每秒可以最大通過多少次請求

redis-rate-limiter.replenishRate: 5

這個是令牌桶的補充速度,每秒往桶里邊放幾個令牌

key-resolver: ‘#{@ipKeyResolver}’

這個就是用上KeyResolver的具體實現(xiàn)了,這里用spel表達式指定我寫的那個ip限制類

準備好之后將應用啟動就完事了,想測的話可以用jmeter測測看,或者將請求限制寫的更小一點,在網頁上狂按f5也行。

以上就是如何為Spring Cloud Gateway加上全局過濾器的詳細內容,更多關于Spring Cloud Gateway添加全局過濾器的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品字幕| 超碰99在线| 亚洲国产成人精品女人| 国产精品毛片久久| 高潮久久久久久久久久久久久久| 美国欧美日韩国产在线播放| 美女精品在线| 中文字幕一区二区精品区| 中文无码久久精品| 日韩中文字幕| 国产精品免费不| 麻豆国产精品视频| 国产精品成人一区二区不卡| 亚洲夜间福利| 亚洲一区二区免费看| 免费人成精品欧美精品 | 国产成人精品999在线观看| 国产精品一区三区在线观看| 日本不卡高清| 国产精品香蕉| 国产不卡精品| 青青青免费在线视频| 久久精品动漫| 好吊视频一区二区三区四区| 麻豆亚洲精品| 国产乱人伦精品一区| 久久精品国产亚洲aⅴ| 色黄视频在线观看| 日韩视频在线一区二区三区| 91大神在线观看线路一区| 国产精品一区二区精品视频观看 | 宅男噜噜噜66国产日韩在线观看| 激情91久久| 日韩1区2区3区| 美日韩一区二区三区| 久久久噜噜噜| 综合激情婷婷| 久久伊人亚洲| 美女亚洲一区| 日韩手机在线| 亚洲一级网站| 欧美日韩亚洲一区二区三区在线| 欧美国产极品| 999国产精品| 婷婷精品在线| av日韩中文| 在线亚洲免费| 亚洲精品看片| 97人人精品| 综合亚洲色图| 欧美男人天堂| 少妇精品久久久一区二区| 国产成人精品一区二区三区视频| 欧美网站在线| 国产一区二区三区四区大秀| 国产视频一区免费看| 国产福利一区二区三区在线播放| 999久久久国产精品| 日韩国产在线一| 香蕉人人精品| 国产精品一区二区精品视频观看| 色爱综合av| 欧美日本二区| 亚洲神马久久| 91一区二区| 日本欧美在线| 国产高清一区| 国产伊人久久| 日本不卡高清| 亚洲国产不卡| 久久精品三级| 视频一区在线播放| 亚洲国产福利| 欧美亚洲tv| 亚洲免费中文| 日本欧美不卡| 国产精品久久久久av蜜臀| 99视频一区| 日韩欧美三级| 国产精品网站在线看| 久久香蕉精品| 99精品小视频| 久久电影tv| 国产激情精品一区二区三区| 中文字幕av亚洲精品一部二部| 日韩精品看片| 欧美激情精品| 亚洲另类黄色| 免费观看久久av| 国内精品伊人| 久久不卡国产精品一区二区| 久久都是精品| 久久九九精品| 国产成人免费精品| 国产精品xxxav免费视频| 国产乱论精品| 色一区二区三区四区| 黑森林国产精品av| 蜜桃av一区二区| 国产精品97| 成人久久久久| 欧美日韩视频免费观看| 免费日韩一区二区三区| 国产日韩在线观看视频| 日本一区二区中文字幕| 亚洲一区成人| 久久国产毛片| 国产videos久久| 麻豆成人在线观看| 国产精品国产三级在线观看| 婷婷视频一区二区三区| 日本欧美在线看| 蜜臀av国产精品久久久久| 亚洲精华国产欧美| 一本色道久久精品| 国产亚洲毛片| 香蕉视频成人在线观看| 午夜国产精品视频| 欧美日韩第一| 国产综合精品一区| 中文另类视频| 日本不良网站在线观看| 国产va免费精品观看精品视频| 久久精品国产成人一区二区三区| 国产精品s色| 美女尤物国产一区| 久久久久久夜| 日韩高清欧美| 尤物tv在线精品| 欧美日韩视频| 丝瓜av网站精品一区二区| 丝袜亚洲精品中文字幕一区| 三级在线观看一区二区| 亚洲精品在线a| 国产日韩欧美一区二区三区在线观看 | 中文在线免费视频| av最新在线| 欧美成人日韩| 亚洲综合国产| 日韩高清欧美激情| 国产精品久久久久av蜜臀| 久久精品女人| 日韩久久精品| 成人av二区| 亚洲69av| 免费在线亚洲欧美| 国产麻豆久久| 日韩午夜一区| 香蕉久久久久久| 国产欧美日韩影院| 国产黄大片在线观看| 激情综合网五月| 日韩欧美2区| 精品久久一区| 极品日韩av| 亚洲精品乱码久久久久久蜜桃麻豆 | 国产午夜精品一区二区三区欧美 | 免费高潮视频95在线观看网站| 99精品电影| 中文视频一区| 久久精品一区二区国产| 亚洲午夜视频| 青草久久视频| 日韩高清电影免费| 日产精品一区二区| 91成人精品视频| 日韩精品欧美大片| caoporn视频在线| 91久久午夜| 久久99性xxx老妇胖精品| 999久久久国产精品| 日本成人手机在线| 国产精品yjizz视频网| 怡红院精品视频在线观看极品| 日本成人在线网站| 91精品韩国| 亚洲精品在线a| 97se综合| 日韩福利在线观看| 99久久视频| 国产情侣一区| 日韩免费福利视频| 日本中文字幕一区二区视频 | 国内在线观看一区二区三区| 欧美日韩高清| 麻豆国产91在线播放| 亚洲一卡久久| 欧美国产免费| 免费的成人av| 日韩国产在线| 欧美综合社区国产| 婷婷亚洲五月| 美女精品视频在线| 视频一区视频二区中文字幕| 捆绑调教日本一区二区三区| 日韩高清欧美激情| 午夜av一区| 福利在线免费视频| 日本aⅴ亚洲精品中文乱码| 欧美一级精品|