本篇主要介紹的是SpringCloud中的斷路器(Hystrix)和斷路器指標看板(Dashboard)的相關使用知識。html
Netflix建立了一個名爲Hystrix的庫,它實現了斷路器模式。主要的目的是爲了解決服務雪崩效應的一個組件,是保護服務高可用的最後一道防線。git
開發環境github
注:不必定非要用上述的版本,能夠根據狀況進行相應的調整。須要注意的是SpringBoot2.x之後,jdk的版本必須是1.8以上!web
確認了開發環境以後,咱們再來添加相關的pom依賴。spring
<dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-hystrix</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>
注: 實際上這裏是不須要Hystrix依賴的,Fegin已經添加了Hystrix依賴。瀏覽器
因爲Hystrix機制是在微服務項目上進行的,而且Fegin中包含了該機制。因此這裏咱們能夠把以前的springcloud-feign
的項目進行簡單的改造就好了。springboot
首先是服務端這塊,爲了進行區分,建立一個springcloud-hystrix-eureka
的項目,用於作註冊中心。 代碼和配置和以前的基本同樣。 application.properties
配置信息:app
配置信息:負載均衡
spring.application.name=springcloud-hystrix-eureka-server server.port=8002 eureka.client.register-with-eureka=false eureka.client.fetch-registry=false eureka.client.serviceUrl.defaultZone=http://localhost:8002/eureka/
配置說明:ide
服務端這邊只須要在SpringBoot啓動類添加@EnableEurekaServer
註解就能夠了,該註解表示此服務是一個服務註冊中心服務。
代碼示例:
@EnableEurekaServer @SpringBootApplication public class HystrixEurekaApplication { public static void main(String[] args) { SpringApplication.run(HystrixEurekaApplication.class, args); System.out.println("hystrix註冊中心服務啓動..."); } }
這裏咱們把以前的springcloud-fegin-consumer
項目稍微改造下,項目名改成springcloud-hystrix-consumer
。而後在application.properties
配置文件新增以下配置, feign.hystrix.enabled
配置表示是否啓用熔斷機制。
feign.hystrix.enabled=true
增長了配置以後,咱們在來把以前的fegin進行定義轉發服務的@FeignClient
註解進行添加一個回調方法fallback
。代碼改造後的實現以下:
@FeignClient(name= "springcloud-hystrix-consumer2",fallback = HelloRemoteHystrix.class) public interface HelloRemote { @RequestMapping(value = "/hello") public String hello(@RequestParam(value = "name") String name); }
最後新增一個回調類,用於處理斷路的狀況。這裏咱們就簡單的處理下,返回錯誤信息便可!
代碼示例:
@Component public class HelloRemoteHystrix implements HelloRemote{ @Override public String hello(@RequestParam(value = "name") String name) { return name+", 請求另外一個服務失敗!"; } }
其他的代碼就不展現了,和以前的springcloud-fegin-consumer
項目中的一致,詳細的能夠在這篇博文SpringCloud學習系列之二 ----- 服務消費者(Feign)和負載均衡(Ribbon)進行查看。
而後在把以前的springcloud-feign-consumer2
進行簡單的改造下,項目名稱改成springcloud-hystrix-consumer2
。而後更改下配置的端口。
完成如上的工程開發以後,咱們依次啓動服務端和客戶端的springcloud-hystrix-eureka
、springcloud-hystrix-consumer
和springcloud-hystrix-consumer2
這三個程序,而後在瀏覽器界面輸入: http://localhost:8002/
,便可查看註冊中心的信息。
首先在瀏覽器輸入:
控制檯打印:
接受到請求參數:pancm,進行轉發到其餘服務
瀏覽器返回:
pancm,Hello World
而後再輸入:
瀏覽器返回:
pancm,Hello World
說明程序運行正常,fegin的調用也ok。這時咱們在進行斷路測試。 中止springcloud-hystrix-consumer2
這個服務,而後在到瀏覽器輸入:http://localhost:9004/hello/pancm
進行查看信息。
控制檯打印:
接受到請求參數:pancm,進行轉發到其餘服務
瀏覽器返回:
pancm, 請求另外一個服務失敗!
出現以上結果說明斷路器的功能已經實現了。
示例圖:
Hystrix-dashboard是一款針對Hystrix進行實時監控的工具,經過Hystrix Dashboard咱們能夠在直觀地看到各Hystrix Command的請求響應時間, 請求成功率等數據。
開發環境
注:不必定非要用上述的版本,能夠根據狀況進行相應的調整。須要注意的是SpringBoot2.x之後,jdk的版本必須是1.8以上!
確認了開發環境以後,咱們再來添加相關的pom依賴。
<dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-hystrix</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>
注: spring-boot-starter-actuator
這個必須須要要,該jar能夠獲得SpringBoot項目的各類信息,關於該jar包的使用,能夠在springboot-actuator這個項目中進行查看。
這裏咱們把上面的springcloud-hystrix-consumer
項目進行改造下,項目名稱改成springcloud-hystrix-dashboard-consumer
。而後在到啓動類新增以下配置。
完整的啓動類配置以下:
@SpringBootApplication @EnableDiscoveryClient @EnableHystrixDashboard @EnableCircuitBreaker @EnableFeignClients public class HystrixDashboardApplication { public static void main(String[] args) { SpringApplication.run(HystrixDashboardApplication.class, args); System.out.println("hystrix dashboard 服務啓動..."); } }
而後在到application.properties
配置文件中新增以下配置:
management.endpoints.web.exposure.include=hystrix.stream management.endpoints.web.base-path=/
該配置的意思是指定hystrixDashboard的訪問路徑,SpringBoot2.x以上必須指定,否則是沒法進行訪問的,訪問會出現 Unable to connect to Command Metric Stream
錯誤。
若是不想使用配置的話,也可使用代碼進行實現。 實現的代碼以下:
@Component public class HystrixServlet extends Servlet{ @Bean public ServletRegistrationBean getServlet() { HystrixMetricsStreamServlet streamServlet = new HystrixMetricsStreamServlet(); ServletRegistrationBean registrationBean = new ServletRegistrationBean(streamServlet); registrationBean.setLoadOnStartup(1); registrationBean.addUrlMappings("/hystrix.stream"); registrationBean.setName("HystrixMetricsStreamServlet"); return registrationBean; } }
完成如上的工程改造以後,咱們啓動該程序。 而後在瀏覽器輸入:
會出現如下的界面:
能夠經過該界面監控使用了hystrix dashboard的項目。這裏咱們依照提示在中間的輸入框輸入以下的地址:
會出現如下的界面:
該界面就是Hystrix Dashboard監控的界面了,經過這個界面咱們能夠很詳細的看到程序的信息。關於這些信息中說明能夠用網上找到的一張來加以說明。
注: 若是界面一直提示loading,那麼是由於沒有進行請求訪問,只需在到瀏覽器上輸入:http://localhost:9010/hello/pancm
,而後刷新該界面就能夠進行查看了。
基於SpringBoot2.x、SpringCloud的Finchley版本開發的地址:https://github.com/xuwujing/springcloud-study
基於SpringBoot1.x、SpringCloud 的Dalston版本開發的地址: https://github.com/xuwujing/springcloud-study-old
若是感受項目不錯,但願能給個star,謝謝!
夏天的夜晚,天上繁星點點,喳喳吵鬧的蟬鳴聲,遠處河流的流淌聲,此時若躺在山丘的草坪上,想必是無比的愜意吧!
<iframe frameborder="no" border="0" marginwidth="0" marginheight="0" width=330 height=86 src="//music.163.com/outchain/player?type=2&id=785902&auto=0&height=66"></iframe>
原創不易,若是感受不錯,但願給個推薦!您的支持是我寫做的最大動力! 版權聲明: 做者:虛無境 博客園出處:http://www.cnblogs.com/xuwujing CSDN出處:http://blog.csdn.net/qazwsxpcm 我的博客出處:http://www.panchengming.com