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

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

Spring Cloud Alibaba 本地調試介紹及方案設計

瀏覽:19日期:2023-07-03 13:38:53
目錄1 本地調試介紹2 框架環境3 方案設計4 實現要點5. 總結附:工具方法1 本地調試介紹

本地調試: 這里是指在開發環境中,部署了一整套的某個項目或者產品的服務,開發人員開發時,本地會起一個或多個服務,這些服務和開發環境中部署的服務是相同的,這種情況下,一個服務就會有多個實例,大多數微服務中的默認負載均衡策略都是輪詢,這些實例會輪流被調用。

為了方便 本地調試,需要提供一種策略,可以指定在負載均衡時,選擇哪個實例進行調用。在使用 Nacos 作為注冊中心時,可以通過 上線和下線 的方式來選擇使用哪個實例,但是這種方式只能強制調用某個實例,如果開發環境還有其他人在調試,自己程序 設置斷點 時會阻塞所有調用,非常不利于多人調試的協調。

為了解決 本地調試 的問題,本文實現了一種簡單實用的策略,可以通過 Nacos 動態配置服務路由,還可以基于用戶,部門,組織等級別配置服務路由,實現 本地調試 的同時,實際上也實現 灰度發布

2 框架環境

本文基于 Spring Cloud Alibaba 框架,和 Spring Cloud 相比增加了一部分針對 Dubbo 的方案,因此本文適合以下框架參考:

Spring Cloud Alibaba Spring Cloud

Spring Cloud GatewaySpring Cloud Ribbon

Dubbo

下圖是 Spring Cloud Alibaba 框架中,一次方法調用的可能情況,Ailbaba 這部分多的是圖中 ServiceA -> ServiceB 部分使用 Dubbo 協議。Spring Cloud 框架中,用的是 ServiceA -> ServiceC 這種 Feign(HTTP) 方式。

Spring Cloud Alibaba 本地調試介紹及方案設計

圖中的所有過濾器和攔截器,雖然名稱不同,但是作用相同。這部分的主要作用就是 獲取或傳遞路由規則,例如,可以實現基于 HTTP Header 設置路由規則的配置,可以基于 HTTP 和 token 實現基于用戶的路由規則配置,這部分的實現和需求有關,沒有統一的實現。

3 方案設計

這里以這兩種場景簡單舉個例子。

3.1 基于 HTTP Header 的本地調試方案

在這個方案中,按照上面的流程圖敘述一遍。

用戶調用服務前,在 Header 中設置調用規則,比如增加 service-route 請求頭,請求頭的內容為 servicea:10.10.10.130;serviceb:10.10.10.100;servicec:10.10.10.0/24,在請求頭中指明需要控制路由的服務信息(不需要控制的直接省略走默認)。 通過 Spring Cloud Gateway 的 GlobalFilter 實現提取請求頭信息,將配置信息記錄下來(如 ThreadLocal) 負載均衡時,根據這里的配置選擇優先路由的服務,調用 ServiceA 時,仍然是 HTTP 請求,請求頭會傳遞過去。 攔截器獲取請求頭中的路由規則,這一步和 1 類似,但是屬于 Spring MVC 的攔截器,獲取路由規則后記錄下來(如 ThreadLocal) ServiceA 調用 ServiceB 是 Dubbo 協議的路徑,和 7,8 Feign 方式沒有先后順序,是兩個分支。 在 4 這一步通過 Dubbo 的 Consumer Filter 過濾器和 RpcContext 將路由信息記錄到 attachment 中,這樣可以把路由配置傳遞到 ServiceB,如果 ServiceB 還需要調用其他服務,路由仍然會起到作用。 在 Dubbo 的 Router 實現中,根據路由信息選擇優先調用的服務,然后進行調用。 Dubbo 的 Provider Filter 從 RpcContext 獲取路由配置,記錄下來(如 ThreadLocal),如果后續調用其他服務,邏輯和 4,5,6一樣。在 6 這一步的 Provider Filter 結束調用的時候,注意清空路由信息(如 ThreadLocal.clear()),避免對其他調用產生污染。 這一步和4,5,6沒有順序關系,是純 Spring Cloud 方式的調用,在 ServiceA 調用時,通過自定義 Ribbon 中的 IRule 實現基于自己路由規則的調用。 在最終調用 ServiceC 之前,通過 Feign 的 RequestInterceptor 攔截器添加 service-route 頭,將服務路由傳遞下去。 和第3步相同,通過 Spring MVC 攔截器獲取服務路由記錄下來。后續在調用其他服務時,Dubbo服務走4,5,6,Feign方式走7,8,9。

3.2 基于操作用戶的本地調試方案

基于操作用戶的方案中,和上面類似,但是不需要在每次請求的時候設置 HTTP Header,但是需要一種方式存取服務路由的配置。

這里以使用 Nacos 配置管理實現服務路由配置的存取。

根據自己使用的用戶在 Nacos 配置服務路由,配置名規則如 服務名.user-routes,使用 Spring Cloud Alibaba 的默認組 dubbo,用戶服務路由的配置規則可以自己定義,這里舉個簡單例子:

enabled: true # 啟用,停用ip: 10.10.0.0/24 # 默認優先IP或網段,所有IP都支持具體IP和網段userIps: # Map<Long, String>,優先級最高,針對用戶配置 IP 優先 # userId: IP 1: 10.10.0.100 2: 10.10.0.101# 這部分定義根據自己需要設計 deptIps: # 針對部門配置 # deptId: IP 1: 10.10.0.0/24orgIps: # 針對組織配置 # orgId: IP 1: 10.10.10.0/24

Spring Cloud Gateway 的 GlobalFilter 根據請求 token 獲取 用戶信息,記錄用戶信息(如 ThreadLocal)。

負載均衡時,使用 Nacos ConfigService,根據 服務名.user-routes 查詢配置信息,同時監聽該配置信息,根據這里的配置選擇優先路由的服務。 攔截器根據請求 token 獲取 用戶信息,記錄用戶信息(如 ThreadLocal)。 ServiceA 調用 ServiceB 是 Dubbo 協議的路徑,和 7,8 Feign 方式沒有先后順序,是兩個分支。 在 4 這一步通過 Dubbo 的 Consumer Filter 過濾器和 RpcContext 將用戶信息記錄到 attachment 中,這樣可以把用戶信息傳遞到 ServiceB,如果 ServiceB 還需要調用其他服務,用戶信息仍然會起到作用。 在 Dubbo 的 Router 實現中,根據路由信息選擇優先調用的服務,然后進行調用。 Dubbo 的 Provider Filter 從 RpcContext 獲取用戶信息,記錄下來(如 ThreadLocal),如果后續調用其他服務,邏輯和 4,5,6一樣。在 6 這一步的 Provider Filter 結束調用的時候,注意清空用戶信息(如 ThreadLocal.clear()),避免對其他調用產生污染。 這一步和4,5,6沒有順序關系,是純 Spring Cloud 方式的調用,在 ServiceA 調用時,通過自定義 Ribbon 中的 IRule 實現基于自己路由規則的調用。 在最終調用 ServiceC 之前,通過 Feign 的 RequestInterceptor 攔截器設置token或用戶信息,將操作用戶傳遞下去。 和第3步相同,通過 Spring MVC 攔截器獲取用戶信息記錄下來。后續在調用其他服務時,Dubbo服務走4,5,6,Feign方式走7,8,9。

本文選擇第 2 種方案,針對 1~9 步,分別講解需要實現的接口和接口應用(生效)的配置。

4 實現要點

上面提到的 ThreadLocal,實現時使用一個 static 變量存儲,提供相應的存取清空的靜態方法,方便跨接口的 用戶信息 傳遞。

4.1 Spring Cloud Gateway 全局過濾器

假設有一個 UserGlobalFilter,該過濾器根據 token 獲取并緩存用戶信息,在請求完成后需要清空緩存的用戶信息。

Spring Cloud Gateway 中的過濾器,直接在 @Configuration 的配置類中用 @Bean 提供即可。

4.2 Ribbon 負載均衡

實現 ribbon-loadbalancer 中的 com.netflix.loadbalancer.IRule 接口,將來調用具體服務時通過 choose 接口返回符合條件的實例。

實現這個接口之后,需要特殊的方式注冊該接口,在啟動類增加注解 @RibbonClients(defaultConfiguration = UserRuleConfiguration.class),注解中指定了一個配置類,這個類一定不要添加 @Configuration 注解!!!

在這個類中,通過 @Bean 注解返回一個 IRule 接口的實現。

在 Ribbon 中,會創建一個新的 ApplicationContext 來初始化這些配置,在這個新的 ApplicationContext 中,配置的 IRule 實現會被使用。

4.3 Spring MVC 攔截器

實現 HandlerInterceptor 攔截器,從請求獲取用戶信息并記錄下來。

攔截器想要生效,需要提供一個配置類,繼承 WebMvcConfigurer 接口,實現 addInterceptors 方法,在這個方法實現中添加攔截器的實現類。

4.4 Dubbo Consumer Filter 過濾器

實現Dubbo 的Filter接口,通過 RpcContext 傳遞前面記錄的用戶信息。

可以在實現類添加 @Activate 注解,指定 group 為 CommonConstants.CONSUMER。

按照 dubbo SPI 要求,添加 META-INF/dubbo/org.apache.dubbo.rpc.Filter 文件,寫上實現類。

4.5 Dubbo Router 路由

這一步實際上可以放在 Dubbo 負載均衡實現,也可以用 Router 實現。

使用 Router 時,需要同時使用 RouterFactory 和 Router 接口,然后配置 RouterFactory 的 SPI 配置文件。

在 Router 的 route 方法中根據規則返回合適的 Invoker。

4.6 Dubbo Provider Filter 過濾器

實現Dubbo 的Filter接口,通過 RpcContext 獲取傳遞過來的用戶信息。

可以在實現類添加 @Activate 注解,指定 group 為 CommonConstants.PROVIDER。

按照 dubbo SPI 要求,添加 META-INF/dubbo/org.apache.dubbo.rpc.Filter 文件,寫上實現類。

這個實現類可以和 4.4 的放一個 Filter 實現中,需要自己區分當前是 consumer 還是 provider 實現不同的邏輯。

4.7 Ribbon 負載均衡,同 4.2

這一步的實現和 4.2 一樣,4.2 是用在 Spring Cloud Gateway 中,這里是配置到具體的服務中。配置方式一樣。

4.8 Feign RequestInterceptor 攔截器

首先實現 RequestInterceptor 接口,在實現中往 requst 的 Header 中放置要傳遞的數據。

接口想要生效,需要和 Ribbon 類似的配置。

在 @EnableFeignClients 的注解中,通過 defaultConfiguration 設置一個 Feign 的配置類。在這個配置中通過 @Bean 提供 RequestInterceptor 接口的實現。

4.9 Spring MVC 攔截器,同 4.3

4.3 中是網關調用服務,4.9是服務通過 Feign (或resttemplate)調用服務,對被調用的服務來說都是 HTTP 請求,因此都會執行 Spring MVC 的攔截器,所以這里的實現是一樣的。

5. 總結

本文提供了本地調試的方案和主要的實現要點,可以根據文中的關鍵指引和自己的實際需求實現自己的方案。關于本地調試如果有更好的方案,歡迎留言討論。

附:工具方法

判斷IP是否相等或輸入子網IP的方法:

public static boolean ipInRange(String ip, String cidr) {if(cidr.indexOf(’/’) < 0) {return ip.equals(cidr);}int ipAddr = ipToInt(ip);int type = Integer.parseInt(cidr.replaceAll('.*/', ''));String cidrIp = cidr.replaceAll('/.*', '');if(type == 32){return ip.equals(cidrIp);}int cidrIpAddr = ipToInt(cidrIp);int mask = 0xFFFFFFFF << (32 - type);return (ipAddr & mask) == (cidrIpAddr & mask);}public static int ipToInt(String ip) {String[] ips = ip.split('.');return (Integer.parseInt(ips[0] << 24) |Integer.parseInt(ips[1] << 16) |Integer.parseInt(ips[2] << 8) |Integer.parseInt(ips[3]));}

到此這篇關于Spring Cloud Alibaba 本地調試方案的文章就介紹到這了,更多相關Spring Cloud Alibaba 本地調試內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧洲av不卡| 日本久久成人网| 日韩午夜黄色| 亚洲一区二区小说| 日韩精品免费一区二区夜夜嗨| 欧美色综合网| 日韩av专区| 中文亚洲欧美| 国产伦理一区| 正在播放日韩精品| 夜夜嗨一区二区三区| 中文字幕日韩高清在线| 国产三级一区| 日韩精品麻豆| 亚洲精品一区二区妖精| 日韩欧美2区| 成人在线免费观看91| 午夜日韩福利| 日韩av电影一区| 中文字幕在线看片| 麻豆成人在线| 久久久久九九精品影院| 日韩大片在线观看| 免费成人性网站| 成人日韩av| 久久高清免费观看| 国内精品伊人| 中文字幕日韩亚洲| 日韩欧美精品| 丝袜美腿高跟呻吟高潮一区| 国产精品天天看天天狠| 亚洲福利国产| 国产欧美日韩在线一区二区| 综合日韩av| 青草综合视频| 好看的av在线不卡观看| 久久这里只有| 自拍自偷一区二区三区| а√天堂8资源在线| 日韩精品视频中文字幕| 久久精品在线| 欧美激情精品| 亚洲日本三级| 欧美日韩激情| 久久久久伊人| 日本一区二区中文字幕| 亚洲网站视频| 粉嫩av一区二区三区四区五区| 只有精品亚洲| 欧美/亚洲一区| 国产一区二区三区不卡av | 日韩精选在线| 欧美片第1页| 欧美国产视频| 日本视频在线一区| 亚洲综合精品四区| 欧美性感美女一区二区| 精品免费av一区二区三区| 亚洲欧美日韩视频二区| 国产精品字幕| 久久久久久色 | 午夜电影亚洲| 婷婷综合六月| 国产成人久久精品一区二区三区| 日韩一区二区三区精品| 国产精品嫩草99av在线| 99免费精品| 国产精品精品| 精品国产美女a久久9999| 中文字幕av一区二区三区四区| 日韩网站中文字幕| 精品国产亚洲一区二区三区大结局| 日本不卡视频一二三区| 免费日韩av片| 五月精品视频| 亚洲天堂成人| 日韩欧美一区免费| 国产中文在线播放| 成人国产精品一区二区免费麻豆| 久久av综合| 精品视频自拍| 精品国产不卡一区二区| 麻豆高清免费国产一区| 国产精品激情| 奇米色欧美一区二区三区| 亚洲精品三级| 亚洲影院天堂中文av色| 久久xxxx精品视频| 免费成人av在线播放| 麻豆精品91| 免费看黄色91| 日本不卡不码高清免费观看 | 国产精品久久久久久久免费观看| 久久亚洲黄色| 国产白浆在线免费观看| а√在线中文在线新版| 国产suv精品一区二区四区视频| 国产精品免费大片| 久久午夜影院| 中文字幕在线高清| 婷婷成人在线| 亚洲综合欧美| 日韩精品欧美成人高清一区二区| 日本色综合中文字幕| 国产精品www.| 婷婷综合六月| 亚洲精品123区| 日韩精彩视频在线观看| 国产毛片一区二区三区| 国产成人77亚洲精品www| 日韩电影二区| 欧美另类专区| 亚洲毛片在线免费| 国产情侣久久| 欧美日韩在线观看首页| 在线国产一区二区| 亚洲+小说+欧美+激情+另类| 国产精品视频一区二区三区四蜜臂 | 蜜桃视频免费观看一区| 日韩国产欧美视频| 国产不卡精品| 日韩网站在线| 国产精区一区二区| 樱桃视频成人在线观看| 夜夜嗨一区二区三区| 青青草精品视频| 吉吉日韩欧美| 男女性色大片免费观看一区二区| 97久久亚洲| 日韩久久一区二区三区| 在线精品一区| 国产不卡人人| 六月婷婷一区| 精品视频高潮| 黄色日韩精品| 欧美黄色一区| 99国产成+人+综合+亚洲欧美| 日韩avvvv在线播放| 日本一二区不卡| 免费在线观看精品| 成人精品久久| 日韩中文字幕在线一区| 色一区二区三区四区| 免费久久99精品国产自在现线| 国产福利亚洲| 日韩中文字幕麻豆| 中文字幕在线看片| 日本午夜精品一区二区三区电影| 中文字幕高清在线播放| 日本亚洲视频| 在线日韩电影| 精品国产亚洲一区二区三区| 热久久免费视频| 国产资源在线观看入口av| 综合视频一区| 欧美国产91| 97在线精品| 国产精品亚洲片在线播放| 国产婷婷精品| 精精国产xxxx视频在线播放| 国产图片一区| 亚洲色图国产| 一本一本久久| 久久免费国产| 久久久久久一区二区| 久久国产精品色av免费看| 国产亚洲毛片在线| 欧美日韩视频网站| 国产精品久久久久久久久久妞妞 | 97国产成人高清在线观看| 蜜桃视频一区二区三区 | 日韩免费在线| 国产亚洲精aa在线看| 蜜桃视频第一区免费观看| 日韩另类视频| 亚洲免费福利| 成人一区不卡| 国产成人精品一区二区免费看京| 久久精品99久久久| 日本不卡视频在线观看| 石原莉奈在线亚洲三区| 亚洲激情黄色| 91久久视频| 99日韩精品| 亚洲欧美久久久| 亚洲中午字幕| 免费日韩精品中文字幕视频在线| 亚洲午夜黄色| 欧美不卡视频| 日本美女一区| 午夜欧美巨大性欧美巨大| 国产精品99在线观看| 国产精品手机在线播放| 日本v片在线高清不卡在线观看| 久久国产精品亚洲77777| 一区二区亚洲精品| 黄色成人在线网址| 亚洲欧洲另类| 天堂成人国产精品一区| 午夜在线一区|