談談服務治理

来源:http://www.cnblogs.com/xiexj/archive/2017/09/13/7508393.html
-Advertisement-
Play Games

本期我們組的技術分享,打算跟大家講講服務治理。我在上篇文章中介紹了我們美團.點評北京總部用的OCTO框架,其實在上海點評部門用的是另一套Pigeon。這兩套框架都很重。這是和我們的業務有關的,其實服務治理這個東西都創業公司到成熟的大公司都在用,只是做到的程度不同。 先說說服務治理的邊界。本質上任何能 ...


  本期我們組的技術分享,打算跟大家講講服務治理。我在上篇文章中介紹了我們美團.點評北京總部用的OCTO框架,其實在上海點評部門用的是另一套Pigeon。這兩套框架都很重。這是和我們的業務有關的,其實服務治理這個東西都創業公司到成熟的大公司都在用,只是做到的程度不同。

  先說說服務治理的邊界。本質上任何能提升服務可用性,性能,讓服務更穩定等等,只要是能讓服務運行的更好,都屬於服務治理的範疇。服務治理比較常見的話題:服務發現,服務變更管理,服務監控,服務擴容縮容,服務自我保護,服務降級,服務授權防攻擊,服務上線驗證和灰度發佈,服務問題定位和跟蹤,服務負載,服務實例的調度等等。

  說服務治理就要先聊聊服務。從業務角度而言,服務是一個可重覆的任務。我是個做業務的,業務可以被粗粒度的劃分為一系列粗粒度的服務和流程。這本質上符合SOA架構的風格,而現在比較流行的微服務出現實際上應當歸功於SOA原則的成功。而微服務將服務劃分的更細,更多,會導致出問題的概率變大。這時候,服務治理的手段沒有進步的話,實際上服務的壓力是變大了。所以大家在選擇架構的時候,需要按照自己的業務發展現狀和趨勢合理的辯證的做決斷。就好像我在上篇文章里舉的例子:如果要建一間房子,可能隨便建個土房子或者茅草房子就能用幾十年,但是隨著規模的擴大,建成四合院就要講究格局,建成一個小區,建成一座城市,就需要運用各種工程學的知識更加統籌的規劃。這就是為什麼我要來美團。我在樂視其實過得很舒服,很自由。因為我家微微一笑很傾城的男神老大不僅英俊帥氣,智商情商雙高,而且管理風格open,很合適我這種有自己想法的下屬。但是樂視各個部門更像是一個村落,大家都在各自建各自的房子,好處是有才能的人可以比較自由的發揮,缺點是格局不夠統一,各個部門做了很多重覆的工作。所以樂視出來的人有水平非常高的,也有水平非常一般的。我個人覺得如果你個人能力非常好,可以去樂視試一試,說不定可以發揮自己的潛能。但是對於我而言,我發現了自己格局的問題,如果我堅持還是要去阿裡的話,到那邊也是個擰螺絲的,平臺很好,但是能不能發揮是個問題。而來美團,我至少能夠得到的保證是:完成一個從對工作負責到對結果負責的轉變。什麼意思呢?我來這邊,我們架構師說我來之前,他需要找各個開發去告訴他們我們的工作,每個開發都聽明白了,然後回到工位完成了自己的那份工作。結果中間銜接的部分職責模糊的部分就很可能被漏掉了。我來了,我的工作是對結果負責,那麼涉及到內部職責的劃分,上下游的對接和業務瞭解。任何能讓結果變得更好的事情都屬於我的職責範圍。這和服務治理的理念不謀而合,這就是為什麼我要來研究服務治理。

  我也自己創過業,做的最小的項目本質上也用到了服務治理相關的東西,就是nginx。nginx本身不處理業務邏輯。它做了什麼事情呢?服務發現,負載均衡。我自己覺得與其將其歸類為一個具體的服務組件,劃分為服務治理組件更為合適。nginx的服務發現大家都知道是在upstream里配置的,可以做DNS動態解析。服務更變修改配置文件後用nginx -s reload讓nginx發現最新的配置,可以說是一個輕巧簡單的服務發現機制。nginx的負載均衡大家說的比較多了,我就不詳述了。但是它做負載均衡的前提是它還實現了服務的分離。它可以將前端靜態請求轉發到靜態服務上,動態api轉發到api服務上,rpc調用轉發到rpc服務上。nginx的服務治理能力還體現在所有這些分離的服務,請求的log都是走nginx服務,我們可以更方便的觀察監控請求,所以相對於分散的服務有更好的治理能力的。

  服務再大一些,就是用到另一個大家熟知的東西,就是zookeeper來做配置變更管理。有一本書叫做《從paxos到zookeeper》講了zookeeper的內部實現,怎樣保證其一致性和分區一致性。但是zookeeper的最大問題是網路抖動對其的影響。為瞭解決這個問題,美團.點評的OCTO服務治理框架採用了本地代理。

  服務自動擴容縮容對於美團.點評這樣的,交易時間高峰基本在中午11點到13點。這段時間交易量大,實際上是需要擴容來保證的。交易量低的時段機器閑置造成很大的資源浪費。這種自動擴容縮容需要區分是正常的請求擴容還是異常請求擴容。一個環節擴容會不會給其他環節造成更大的壓力,反而壓垮整個鏈路。如果是異常請求,這個時候應該採用的是拒絕請求。比如有資料庫慢查詢,顯示調用結果是線程池滿了,要排隊。如果這時候採取了擴容,反而壓垮資料庫。這時候應該是報警而不是擴容。

  在樂視的時候,阿裡的陽哥自己開發了一個基於redis的異常日誌收集器。這個其實也屬於服務治理的範疇,這是一個統一的服務監控報警機制。報警是觸發門檻很低的異常處理機制。所以我在樂視的時候郵箱,手機簡訊報警太多了,我就想換了工作再也不用收這些報警了。結果,好吧,換工作後多了N倍。異常再達到一定量級,可能會觸發過載保護。過載保護再不解決問題就要降級了。我之前博客里也提到的樂視用guava的RateLimiter做了限流,這就是過載保護的一種方式。

   


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JPA基礎及查詢規則 JPA JPA是Java Persistence API的簡稱,中文名Java持久層API,是JDK 5.0註解或XML描述對象-關係表的映射關係,並將運行期的實體對象持久化到資料庫中。 JPA框架中支持大數據集、事務、併發等容器級事務,這使得 JPA 超越了簡單持久化框架的局 ...
  • 1.減少可調用對象的參數個數,使用functools.partial凍結參數 使用functools.partial(),可以固定一個或者多個值,減少調用參數。 2.給函數參數增加元信息 函數聲明中的各個參數可以在 : 之後增加註解表達式。如果參數有預設值,註解放在參數名和 = 號之間。如果想註解返 ...
  • package com.swift; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja... ...
  • 承接【Spring事務管理】,上一篇我們已經簡單接觸了關於Spring jdbc的知識,今天我們承接上一篇進行一下補充,上一篇直接將dataSource註入到了Dao層進行了實現,本篇我們通過簡單進行一下補充,將另外兩種實現為大家進行一下演示:1、在自己定義的DAO 實現類中註入一個DataSour ...
  • Coloring Trees CodeForces - 711C 題意:有n個點,每個點有一個c值,如果為0表示它沒有被染色,否則表示它被染成了c值的顏色。顏色有1到m。把第i棵樹染成顏色j所需要的代價是p[i][j]。求最小的代價,使得將每棵樹都染色,且如果將連續的一串同色的樹視為一個集合,共有k ...
  • 對於Spring相信很多做web開發的小活動一定不陌生,Spring中我們經常談到的就是IOC和AOP,但是對於Spring的事務管理,相信大家一定也很感興趣,今天我們就探討一下Spring中的事務管理。 首先談一下事務使用的場景,我們能想到的最常見場景就是銀行轉賬,A給B轉賬,第一步扣除A中的賬戶 ...
  • AJAX開發 AJAX即“Asynchronous Javascript And XML”(非同步JavaScript和XML),是指一種創建互動式網頁應用的網頁開發技術。 AJAX = 非同步 JavaScript和XML(標準通用標記語言的子集)。 AJAX 是一種用於創建快速動態網頁的技術。 通過 ...
  • 壞味道意指代碼中出現的可以被改進的地方。當你嗅到壞味道的時候,也就意味著重構的時機到了。 重構對軟體內部結構的一種調整,目的是在不改變軟體可觀察行為的前提下,提高其可理解性,降低其修改成本。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...