SpringCloud微服務帶來的問題
業務團隊的痛點
1. 對於業務開發團隊而言,最強的是技術嗎?一定不是,業務團隊最強的一定是對於業務的理解和熟悉程度。
2. 而業務應用的核心價值,就是為了實現業務場景,而不是寫微服務,微服務只是一種實現業務的手段。
3. 業務團隊除了關心業務之外,他們所面臨的最大的挑戰在於,如何保證系統的穩定性何可擴充套件性、如何設計一個安全的open api。如果對服務進行拆分、如何保證跨庫的資料一致性。以及對於舊系統的改造。
4. 於公司層面而言,業務團隊的壓力還來自於時間人力的投入,我們用於被各種deadline趕著走。所以作為一個業務程式設計師,如果在這個deadline之前還需要花更多的時間投入在spring cloud這些工具的學習上,那無疑是雪上加霜。公司對於業務團隊的考核,永遠只看結果!
服務治理功能不齊全
SpringCloud對於服務治理的功能是不夠強大的,如果需要實現企業級的微服務落地以及服務治理,那麼我們還需要基於SpringCloud這套體系上來解決這些問題。
跨語言帶來的問題
微服務有一個很重要的特性,就是不同的微服務可以採用自己最擅長的語言來編寫程式。這種特性在企業中落地的時候又會帶來一些問題。
比如公司內部會開發一些公共的類庫或者框架,也或者會使用第三方的類庫或者框架來實現某些功能。
但是由於公司的微服務用了各種各樣的語言,那意味著這些類庫需要針對不同的語言開發相容版本。如果是主流語言還好,如果是一些小眾語言,那對於這些基礎元件的開發者而言無疑是晴天霹靂
總結
從這些痛點中可以發現,我們所做的所有非業務類的事情,都是為了保證把請求傳送到正確的地方,並且能夠及時或得正確的結果。那對於對於業務開發人員而言,是否有必要去關心這些呢?
回到最開始我們說的一個例子,在進行計算機網路通訊的時候,開發人員有必要去關心網路通訊的細節嗎? 我們在使用http協議進行資料傳輸時,關心過底層是使用TCP還是udp?資料是怎麼傳輸的?
既然我們不需要關心這些,那對於微服務架構中的這些問題,業務開發人員為什麼一定要關心服務的通訊呢?
技術棧下沉
那麼對於微服務實施來說,能不能像網路協議的下沉一樣,增加一個微服務層來完成這個而是情呢?這就引出了service mesh
在每個服務中,會有一個service mesh例項,客戶端發起一個請求,首先會把請求傳送到本地的service mesh例項,service mesh例項中會完成完整的服務之間的呼叫流程,比如服務發現、負載均衡。最終傳送給目標服務。而這個service mesh例項,專業名稱應該為:sidecar , 簡單來說,它是原有的客戶端和服務端之間的一個代理
在多個服務的呼叫中,這種通訊方式的表現形式就像一個網格,sidecar之間的連結形成了一個網路,這個就是service mesh的由來
Service Mesh為業務開發團隊降低了門檻,提供了穩定的基礎設施,最重要的是,讓業務開發團隊從微服務實現的具體技術細節中解放出來迴歸到業務。
相關文章
- 生產環境部署springcloud微服務啟動慢的問題排查SpringGCCloud微服務
- SpringCloud微服務治理SpringGCCloud微服務
- SpringCloud微服務的那點事SpringGCCloud微服務
- SpringCloud微服務基礎SpringGCCloud微服務
- SpringCloud微服務整合DubboSpringGCCloud微服務
- SpringCloud微服務理解(一)SpringGCCloud微服務
- springcloud 微服務面試SpringGCCloud微服務面試
- 微服務異常問題微服務
- 微服務架構帶來的分散式單體微服務架構分散式
- SpringCloud升級之路2020.0.x版-2.微服務框架需要考慮的問題SpringGCCloud微服務框架
- 事務的隔離級別與所帶來的問題
- SpringCloud包含的微服務介紹--EurekaSpringGCCloud微服務
- SpringCloud(1) ——回顧微服務和微服務架構SpringGCCloud微服務架構
- 微服務之springcloud eureka(一)微服務SpringGCCloud
- springcloud 微服務 之 Eureka 配置SpringGCCloud微服務
- 微服務思考(02):微服務實施前有哪些問題?微服務
- clone 淺克隆帶來的問題
- SpringCloud——Eureka-微服務的註冊中心SpringGCCloud微服務
- SpringCloud微服務技術選型SpringGCCloud微服務
- 微服務SpringCloud之熔斷器微服務SpringGCCloud
- java springcloud 微服務設計方案JavaSpringGCCloud微服務
- 微服務學習計劃——SpringCloud微服務SpringGCCloud
- 【SpringCloud】微服務Eureka高可用配置SpringGCCloud微服務
- springcloud微服務分散式雲架構-SpringCloud簡介SpringGCCloud微服務分散式架構
- 關於分散式事務帶來的問題及解決方案分散式
- 基於SpringCloud的微服務架構設計SpringGCCloud微服務架構
- 129、springcloud-eureka-client微服務的互相呼叫SpringGCCloudclient微服務
- 微服務02 Kafka訊息佇列, Dubbo, Springcloud微服務框架, Nacos微服務Kafka佇列SpringGCCloud框架
- (一)springcloud微服務分散式雲架構-SpringCloud簡介SpringGCCloud微服務分散式架構
- Springcloud分散式微服務b2b2c電子商務一Spring Cloud常見問題(一)SpringGCCloud分散式微服務
- SpringCloud(一)微服務遠端呼叫 -- RestTemplateSpringGCCloud微服務REST
- SpringCloud微服務治理二(Robbin,Hystix,Feign)SpringGCCloud微服務
- SpringCloud 微服務閘道器 Gateway 元件SpringGCCloud微服務Gateway元件
- SpringCloud 微服務最佳開發實踐SpringGCCloud微服務
- 二. SpringCloud基本Rest微服務工程搭建SpringGCCloudREST微服務
- 如何避免微服務設計中的耦合問題微服務
- 微服務架構分散式事務管理問題微服務架構分散式
- 十大微服務面試問題微服務面試