微服務架構案例(05):SpringCloud 基礎組件應用設計
- 2019 年 11 月 6 日
- 筆記
本文源碼:GitHub·點這裡 || GitEE·點這裡
更新進度(共6節):
01:項目技術選型簡介,架構圖解說明
02:業務架構設計,系統分層管理
03:資料庫選型,業務數據設計規劃
04:中間件集成,公共服務管理
05:SpringCloud 基礎組件應用設計
一、組件應用規劃
1、註冊中心
Eureka 組件是 Netflix 開發的,用於定位服務,基於RESTFul方式實現服務註冊與發現。包括一個EurekaServer服務端(通常是指微服務中的註冊中心) 和EurekaClient客戶端(通常指微服務中的業務服務)。Eureka支援高可用的配置,當註冊中心發現有故障的服務時,Eureka就會轉入自動保護模式,故障時不影響服務的發現和註冊,當故障恢復正常時,註冊中心的服務會進行狀態同步,繼續提供服務。
2、服務調用
Feign 組件是一個聲明式的 WebService客戶端。在Eureka註冊的服務中,可以使用Feign介面的形式來進行相關服務間的請求調用,並提供超時回退,快速熔斷的相關特性。Feign是一個便利的RestFul框架,簡化調用,通過ribbon在註冊伺服器中找到服務實例,然後對請求進行服務分配,實現了負載均衡的效果,默認採用輪詢演算法。
3、服務網關
GateWay網關,可以讓所有客戶端請求先通過微服務網關,跟網關進行交互,由網關進行各個微服務的請求轉發,客戶端(前端)對多服務架構無感知。降低客戶端與微服務之間的交互耦合度;便於監控,可在網關中監控數據;在網關層統一處理認證,規劃切面編程;也就是說與業務本身功能無關的公共邏輯可以在網關層統一封裝實現,類似設計模式中的門面模式。
二、註冊中心
1、服務端配置
eureka: server: enable-self-preservation: false eviction-interval-timer-in-ms: 15000 instance: prefer-ip-address: true client: register-with-eureka: false fetch-registry: false service-url: defaultZone: http://127.0.0.1:5001/eureka/
2、客戶端配置
eureka: instance: prefer-ip-address: true client: service-url: defaultZone: http://127.0.0.1:5001/eureka/
三、Feign組件
1、Feign介面
@FeignClient("MOPSZ-SOFT-ROCKET") public interface UserSearchFeign { @GetMapping("/mq/user/search/sendBookSearch") void sendBookSearch (@RequestParam("msgContent") String msgContent) ; }
2、Feign介面實現
@RestController public class UserSearchController implements UserSearchFeign { @Override public void sendBookSearch(String msgContent) { } }
3、介面配置
該配置文件在實現Feign介面的項目中配置就好,也可針對特定方法配置。
feign: hystrix: enabled: true client: config: feignName: connectTimeout: 60000 readTimeout: 60000
4、Feign介面調用
@Resource private UserSearchFeign userSearchFeign ; userSearchFeign.sendBookSearch("");
四、服務網關
1、網關組件配置
zuul: # 前綴,可以用來做版本控制 prefix: /v1 # 禁用默認路由,執行配置的路由 ignored-services: "*" routes: # 配置 Token 服務 pro6601: serviceId: mopsz-basis-token path: /api/6601/** # 配置 UserClient 服務 pro6102: serviceId: mopsz-user-client path: /api/6102/**
- 配置FilterConfig進行用戶Token認證攔截;
- 配置FallBackConfig進行服務降級響應管理;
2、項目部署
在項目上線後,對外暴露一個網關服務埠,其他服務埠不對外暴露,所有的請求都必須通過網關攔截或者轉發,這就是微服務提供服務的一種常見方式。
五、源程式碼地址
GitHub·地址 https://github.com/cicadasmile/husky-spring-cloud GitEE·地址 https://gitee.com/cicadasmile/husky-spring-cloud