摘要:注意注解能注冊(cè)到服務(wù)上,是因?yàn)樵撟⒔獍丝蛻舳说淖⒔猓撌且粋€(gè)復(fù)合注解。地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。
SpringCloud(第 018 篇)Zuul 服務(wù) API 網(wǎng)關(guān)微服務(wù)之代理與反向代理
-
一、大致介紹1、API 服務(wù)網(wǎng)關(guān)顧名思義就是統(tǒng)一入口,類似 nginx、F5 等功能一樣,統(tǒng)一代理控制請(qǐng)求入口,弱化各個(gè)微服務(wù)被客戶端記憶功能; 2、本章節(jié)主要講解了使用 zuul 的代理功能與反向代理功能,當(dāng)然 zuul 還有很多屬性設(shè)置,我就沒一一列舉所有的測(cè)試方法了; 3、http://localhost:8150/routes 地址可以查看該zuul微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的serviceId;二、實(shí)現(xiàn)步驟 2.1 添加 maven 引用包
2.2 添加應(yīng)用配置文件(springms-gateway-zuulsrcmainresourcesapplication.yml)4.0.0 springms-gateway-zuul 1.0-SNAPSHOT jar com.springms.cloud springms-spring-cloud 1.0-SNAPSHOT org.springframework.cloud spring-cloud-starter-zuul org.springframework.cloud spring-cloud-starter-eureka
spring: application: name: springms-gateway-zuul server: port: 8150 eureka: datacenter: SpringCloud # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 System Status 的 Data center 顯示信息 environment: Test # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 System Status 的 Environment 顯示信息 client: service-url: defaultZone: http://admin:admin@localhost:8761/eureka # healthcheck: # 健康檢查 # enabled: true instance: prefer-ip-address: true instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}} ##################################################################################################### # 測(cè)試二,自定義路徑配置,給 springms-provider-user 微服務(wù)添加前綴地址,反向代理用戶微服務(wù) #zuul: # routes: # springms-provider-user: /user/** ## 測(cè)試三,自定義路徑配置,給 springms-provider-user 微服務(wù)添加前綴地址,反向代理用戶微服務(wù),其它代理路徑一律失效 #zuul: # ignoredServices: "*" # routes: # springms-provider-user: /user/** # 測(cè)試四,自定義路徑配置,給 springms-provider-user 微服務(wù)添加前綴地址,代理、反向代理用戶微服務(wù),忽略禁用 springms-consumer-movie 代理、反向代理路徑 #zuul: # ignoredServices: springms-consumer-movie # routes: # springms-provider-user: /user/** ##################################################################################################### ##################################################################################################### # 打印日志 logging: level: root: INFO com.springms: DEBUG ##################################################################################################### ##################################################################################################### ribbon: ConnectTimeout: 3000 ReadTimeout: 60000 ##################################################################################################### ##################################################################################################### # 解決第一次請(qǐng)求報(bào)超時(shí)異常的方案,因?yàn)?hystrix 的默認(rèn)超時(shí)時(shí)間是 1 秒,因此請(qǐng)求超過該時(shí)間后,就會(huì)出現(xiàn)頁(yè)面超時(shí)顯示 : # # 這里就介紹大概三種方式來(lái)解決超時(shí)的問題,解決方案如下: # # 第一種方式:將 hystrix 的超時(shí)時(shí)間設(shè)置成 5000 毫秒 hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 5000 # # 或者: # 第二種方式:將 hystrix 的超時(shí)時(shí)間直接禁用掉,這樣就沒有超時(shí)的一說(shuō)了,因?yàn)橛肋h(yuǎn)也不會(huì)超時(shí)了 # hystrix.command.default.execution.timeout.enabled: false # # 或者: # 第三種方式:索性禁用feign的hystrix支持 # feign.hystrix.enabled: false ## 索性禁用feign的hystrix支持 # 超時(shí)的issue:https://github.com/spring-cloud/spring-cloud-netflix/issues/768 # 超時(shí)的解決方案: http://stackoverflow.com/questions/27375557/hystrix-command-fails-with-timed-out-and-no-fallback-available # hystrix配置: https://github.com/Netflix/Hystrix/wiki/Configuration#execution.isolation.thread.timeoutInMilliseconds #####################################################################################################2.3 添加zuul服務(wù)網(wǎng)關(guān)微服務(wù)啟動(dòng)類(springms-gateway-zuulsrcmainjavacomspringmscloudMsGatewayZuulApplication.java)
package com.springms.cloud; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.zuul.EnableZuulProxy; /** * Zuul 服務(wù) API 網(wǎng)關(guān)微服務(wù)之代理與反向代理。 * * 注意 EnableZuulProxy 注解能注冊(cè)到 eureka 服務(wù)上,是因?yàn)樵撟⒔獍?eureka 客戶端的注解,該 EnableZuulProxy 是一個(gè)復(fù)合注解。 * * @EnableZuulProxy --> { @EnableCircuitBreaker、@EnableDiscoveryClient } 包含了 eureka 客戶端注解,同時(shí)也包含了 Hystrix 斷路器模塊注解。 * * http://localhost:8150/routes 地址可以查看該zuul微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的serviceId。 * * @author hmilyylimh * * @version 0.0.1 * * @date 2017/9/24 * */ @SpringBootApplication @EnableZuulProxy public class MsGatewayZuulApplication { public static void main(String[] args) { SpringApplication.run(MsGatewayZuulApplication.class, args); System.out.println("【【【【【【 GatewayZuul微服務(wù) 】】】】】】已啟動(dòng)."); } }三、測(cè)試
/**************************************************************************************** 一、Zuul 服務(wù) API 網(wǎng)關(guān)微服務(wù)之代理與反向代理(正常情況測(cè)試): 1、編寫 application.yml 文件,添加應(yīng)用程序的注解 EnableZuulProxy 配置; 2、啟動(dòng) springms-discovery-eureka 模塊服務(wù),啟動(dòng)1個(gè)端口; 3、啟動(dòng) springms-provider-user 模塊服務(wù),啟動(dòng)1個(gè)端口(application.yml 文件中的 appname 屬性不去掉的話,測(cè)試一是無(wú)法測(cè)試通過的); 4、啟動(dòng) springms-consumer-movie 模塊服務(wù),啟動(dòng)1個(gè)端口; 5、啟動(dòng) springms-gateway-zuul 模塊服務(wù); 6、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7900/simple/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 7、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7901/movie/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 總結(jié)一:第6、7步正常,說(shuō)明 springms-provider-user、springms-consumer-movie 兩個(gè)服務(wù)目前正常; 8、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/springms-provider-user/simple/3,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 9、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/springms-consumer-movie/movie/4,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 總結(jié)二:第8、9步也能正常打印用戶信息,說(shuō)明 API 網(wǎng)關(guān)已經(jīng)生效了,可以通過API服務(wù)器地址鏈接各個(gè)微服務(wù)的 http://localhost:8150/serviceId/path 這樣的路徑來(lái)訪問了; ****************************************************************************************/ /**************************************************************************************** 二、Zuul 服務(wù) API 網(wǎng)關(guān)微服務(wù)之代理與反向代理(自定義路徑配置,給 springms-provider-user 微服務(wù)添加前綴地址,反向代理用戶微服務(wù)): 1、編寫 application.yml 文件,添加應(yīng)用程序的注解 EnableZuulProxy 配置; # 測(cè)試二,自定義路徑配置,給 springms-provider-user 微服務(wù)添加前綴地址,反向代理用戶微服務(wù) zuul: routes: springms-provider-user: /user/** 2、啟動(dòng) springms-discovery-eureka 模塊服務(wù),啟動(dòng)1個(gè)端口; 3、啟動(dòng) springms-provider-user 模塊服務(wù),啟動(dòng)1個(gè)端口(application.yml 文件中的 appname 屬性不去掉的話,測(cè)試一是無(wú)法測(cè)試通過的); 4、啟動(dòng) springms-consumer-movie 模塊服務(wù),啟動(dòng)1個(gè)端口; 5、啟動(dòng) springms-gateway-zuul 模塊服務(wù); 6、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7900/simple/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 7、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7901/movie/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 總結(jié)一:第6、7步正常,說(shuō)明 springms-provider-user、springms-consumer-movie 兩個(gè)服務(wù)目前正常; 8、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/springms-provider-user/simple/3,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 9、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/springms-consumer-movie/movie/4,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 總結(jié)二:第8、9步也能正常打印用戶信息,說(shuō)明 API 網(wǎng)關(guān)已經(jīng)生效了,可以通過API服務(wù)器地址鏈接各個(gè)微服務(wù)的 http://localhost:8150/serviceId/path 這樣的路徑來(lái)訪問了; 10、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/user/simple/3,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái),可見【用戶微服務(wù)】的地址被改變生效了,同時(shí)被 API 網(wǎng)關(guān)反向代理了,也就是說(shuō) http 的請(qǐng)求 /user 將被發(fā)送到【用戶微服務(wù)】; 11、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/user/movie/4,正常情況下訪問不通,理應(yīng)訪問不通的; 總結(jié)三:zuul.routes 屬性僅僅只是為了給 springms-provider-user 微服務(wù)添加了 user 前綴,所以電影微服務(wù)加 user 前綴當(dāng)然訪問不通的; ****************************************************************************************/ /**************************************************************************************** 三、Zuul 服務(wù) API 網(wǎng)關(guān)微服務(wù)之代理與反向代理(自定義路徑配置,給 springms-provider-user 微服務(wù)添加前綴地址,反向代理用戶微服務(wù),其它代理路徑一律失效): 1、編寫 application.yml 文件,添加應(yīng)用程序的注解 EnableZuulProxy 配置; # 測(cè)試三,自定義路徑配置,給User微服務(wù)添加前綴地址,反向代理User微服務(wù),不反向代理電影微服務(wù) zuul: ignoredServices: "*" routes: springms-provider-user: /user/** 2、啟動(dòng) springms-discovery-eureka 模塊服務(wù),啟動(dòng)1個(gè)端口; 3、啟動(dòng) springms-provider-user 模塊服務(wù),啟動(dòng)1個(gè)端口(application.yml 文件中的 appname 屬性不去掉的話,測(cè)試一是無(wú)法測(cè)試通過的); 4、啟動(dòng) springms-consumer-movie 模塊服務(wù),啟動(dòng)1個(gè)端口; 5、啟動(dòng) springms-gateway-zuul 模塊服務(wù); 6、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7900/simple/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 7、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7901/movie/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 總結(jié)一:第6、7步正常,說(shuō)明 springms-provider-user、springms-consumer-movie 兩個(gè)服務(wù)目前正常; 8、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/springms-provider-user/simple/3,正常情況下不能被代理了,訪問頁(yè)面不存在,出現(xiàn)404錯(cuò)誤碼; 9、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/springms-consumer-movie/movie/4,正常情況下不能被代理了,訪問頁(yè)面不存在,出現(xiàn)404錯(cuò)誤碼; 總結(jié)二:第8、9步訪問出現(xiàn)404錯(cuò)誤碼,說(shuō)明通過 http://localhost:8150/serviceId/path 代理路徑訪問 API 網(wǎng)關(guān)已經(jīng)失效了; 10、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/user/simple/3,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái),可見【用戶微服務(wù)】的地址被改變生效了,同時(shí)被 API 網(wǎng)關(guān)反向代理了,也就是說(shuō) http 的請(qǐng)求 /user 將被發(fā)送到【用戶微服務(wù)】; 11、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/user/movie/4,正常情況下訪問不通,理應(yīng)訪問不通的; 總結(jié)三:zuul.routes ignoredServices 忽略禁用了所有代理路徑,但僅僅只是為了給 springms-provider-user 微服務(wù)添加了 user 前綴供反向代理路徑訪問,所以電影微服務(wù)加 user 前綴當(dāng)然訪問不通的; ****************************************************************************************/ /**************************************************************************************** 四、Zuul 服務(wù) API 網(wǎng)關(guān)微服務(wù)之代理與反向代理(自定義路徑配置,給 springms-provider-user 微服務(wù)添加前綴地址,代理、反向代理用戶微服務(wù),忽略禁用 springms-consumer-movie 代理、反向代理路徑): 1、編寫 application.yml 文件,添加應(yīng)用程序的注解 EnableZuulProxy 配置; # 測(cè)試四,自定義路徑配置,給 springms-provider-user 微服務(wù)添加前綴地址,代理、反向代理用戶微服務(wù),忽略禁用 springms-consumer-movie 代理、反向代理路徑 zuul: ignoredServices: springms-consumer-movie routes: springms-provider-user: /user/** 2、啟動(dòng) springms-discovery-eureka 模塊服務(wù),啟動(dòng)1個(gè)端口; 3、啟動(dòng) springms-provider-user 模塊服務(wù),啟動(dòng)1個(gè)端口(application.yml 文件中的 appname 屬性不去掉的話,測(cè)試一是無(wú)法測(cè)試通過的); 4、啟動(dòng) springms-consumer-movie 模塊服務(wù),啟動(dòng)1個(gè)端口; 5、啟動(dòng) springms-gateway-zuul 模塊服務(wù); 6、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7900/simple/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 7、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7901/movie/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái); 總結(jié)一:第6、7步正常,說(shuō)明 springms-provider-user、springms-consumer-movie 兩個(gè)服務(wù)目前正常; 8、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/springms-provider-user/simple/3,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái),可見【用戶微服務(wù)】的地址被改變生效了,同時(shí)被 API 網(wǎng)關(guān)反向代理了,也就是說(shuō) http 的請(qǐng)求 /user 將被發(fā)送到【用戶微服務(wù)】; 9、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/springms-consumer-movie/movie/4,正常情況下不能被代理了,訪問頁(yè)面不存在,出現(xiàn)404錯(cuò)誤碼; 總結(jié)二:zuul.routes ignoredServices 忽略禁用了 springms-consumer-movie 【電影微服務(wù)】的代理路徑,所以電影微服務(wù)的代理路徑當(dāng)然訪問不通的; 10、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/user/simple/3,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái),可見【用戶微服務(wù)】的地址被改變生效了,同時(shí)被 API 網(wǎng)關(guān)反向代理了,也就是說(shuō) http 的請(qǐng)求 /user 將被發(fā)送到【用戶微服務(wù)】; 11、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8150/user/movie/4,正常情況下訪問不通,理應(yīng)訪問不通的; 總結(jié)三:zuul.routes ignoredServices 忽略禁用了 springms-consumer-movie 【電影微服務(wù)】的代理路徑,所以電影微服務(wù)的代理路徑當(dāng)然訪問不通的; 注意:測(cè)試三、測(cè)試四的區(qū)別在于,ignoredServices 屬性的設(shè)置,影響的是 springms-consumer-movie 微服務(wù)的代理路徑是否可以訪問; ****************************************************************************************/四、下載地址
https://gitee.com/ylimhhmily/SpringCloudTutorial.git
SpringCloudTutorial交流QQ群: 235322432
SpringCloudTutorial交流微信群: 微信溝通群二維碼圖片鏈接
歡迎關(guān)注,您的肯定是對(duì)我最大的支持!!!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/70555.html
SpringCloud(第 019 篇)Zuul 網(wǎng)關(guān)微服務(wù)的一些屬性應(yīng)用測(cè)試 - 一、大致介紹 1、本章節(jié)根據(jù)官網(wǎng)資料,嘗試了一些其它屬性的設(shè)置,比如 path、serviceId、prefix、strip-prefix 等應(yīng)用; 2、這些組合試用的場(chǎng)景大多數(shù)在一些地址方面需要重新映射或者針對(duì)特殊地址做特殊處理等,至于其它一些深層次的應(yīng)用大家做過知道的話也可以告盡情回帖讓大家都來(lái)學(xué)習(xí)學(xué)習(xí)。 二、...
摘要:注意注解能注冊(cè)到服務(wù)上,是因?yàn)樵撟⒔獍丝蛻舳说淖⒔?,該是一個(gè)復(fù)合注解。地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。 SpringCloud(第 020 篇)Zuul 網(wǎng)關(guān)模塊添加 listOfServers 屬性,達(dá)到客戶端負(fù)載均衡的能力 - 一、大致介紹 1、本章節(jié)添加另外一個(gè)屬性 listOfServers 來(lái)給 zuul 賦上異樣的功能色彩,提供負(fù)載均衡的能力; 2、而其實(shí)說(shuō)...
摘要:但是如果將負(fù)載均衡器置于所有服務(wù)前便不是一個(gè)好主意,會(huì)造成瓶頸。服務(wù)超時(shí)使用的和庫(kù)來(lái)進(jìn)行請(qǐng)求。支持以下四種過濾器前置過濾器在將請(qǐng)求發(fā)送到目的地之前被調(diào)用。通常用于記錄從目標(biāo)服務(wù)返回的響應(yīng)處理錯(cuò)誤或?qū)徍嗣舾行畔ⅰ? showImg(https://segmentfault.com/img/remote/1460000019531578); springcloud 總集:https://ww...
摘要:是一個(gè)相對(duì)比較新的微服務(wù)框架,年才推出的版本雖然時(shí)間最短但是相比等框架提供的全套的分布式系統(tǒng)解決方案。提供線程池不同的服務(wù)走不同的線程池,實(shí)現(xiàn)了不同服務(wù)調(diào)用的隔離,避免了服務(wù)器雪崩的問題。通過互相注冊(cè)的方式來(lái)進(jìn)行消息同步和保證高可用。 Spring Cloud 是一個(gè)相對(duì)比較新的微服務(wù)框架,...
摘要:地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。微服務(wù)已啟動(dòng)使用提供和之間的綁定它使用正則表達(dá)式組來(lái)從提取變量然后注入到路由表達(dá)式中。 SpringCloud(第 022 篇)Zuul 網(wǎng)關(guān)微服務(wù)的 regexmapper 屬性測(cè)試, 類似測(cè)試 zuul 的自定義路徑規(guī)則一樣 - 一、大致介紹 1、本章節(jié)將 Zuul 的 regexmapper 屬性單獨(dú)拿出來(lái),主要是這種配置規(guī)則,可以在一...
閱讀 1134·2021-11-08 13:13
閱讀 1716·2019-08-30 15:55
閱讀 2770·2019-08-29 11:26
閱讀 2436·2019-08-26 13:56
閱讀 2558·2019-08-26 12:15
閱讀 2137·2019-08-26 11:41
閱讀 1402·2019-08-26 11:00
閱讀 1537·2019-08-23 18:30