業務開發轉基礎開發,這三種「高可用」架構你會麽?

来源:https://www.cnblogs.com/xiexj/archive/2019/02/28/10451292.html
-Advertisement-
Play Games

一、業務開發與基礎開發的區別 - 劃分方式 一種將後臺開發細分的方式:前臺開發(業務)、中台開發(中間件、應用基礎服務、PAAS服務、IAAS服務)、後臺開發(運維開發)。一般前臺開發對應於業務開發,中台開發對應基礎開發,後臺開發對應運維。 - 規模 基礎開發的目標是解決業務的公共痛點,所以一般數據 ...


一、業務開發與基礎開發的區別

- 劃分方式

    一種將後臺開發細分的方式:前臺開發(業務)、中台開發(中間件、應用基礎服務、PAAS服務、IAAS服務)、後臺開發(運維開發)。一般前臺開發對應於業務開發,中台開發對應基礎開發,後臺開發對應運維。

- 規模

    基礎開發的目標是解決業務的公共痛點,所以一般數據量、併發量大於業務。就美團來說,一般的基礎服務日調用量在十億到千億。因此,高併發、高可用是常規話題。

 

二、三種高可用架構

- 多租戶集群架構

定義:

    多租戶技術(Multi-tenancy Technology),或稱多重租賃技術,是一種軟體架構技術。它是在探討與實現如何在多用戶公用相同的系統或組件時,仍可確保各用戶間的數據隔離性。

目標:

    按照業務情況分為不同租戶,單個租戶出現問題,不會影響其他租戶。

關鍵功能模塊:

  • 租戶管理

  • 許可權管理

  • 資源管理

應用舉例:

   《美團分散式服務通信框架及服務治理系統OCTO》里使用appkey作為租戶、許可權和資源劃分的依據來實現多租戶集群管理。各個公司自己的Kafka集群也是根據接入業務實現了多租戶集群管理。

 

- 應用熔斷架構

目標:

    針對混合使用集群,單個應用的問題可能拖垮整個集群,單個服務異常情況下,提供熔斷機制,不會由於單個應用影響整個集群的問題。

常用熔斷條件:

  • 線程數過高

    熔斷原因:由於容器化技術的廣泛流行,CPU超售普遍存在。一個業務的異常線程會影響其他業務。

  • 大量慢查詢

    熔斷原因:在集中式ES集群、Redis集群等場景,由於存在連接數資源共用,一個業務的慢查詢會阻塞其他業務。

  • 調用量異常

    熔斷原因:在同步調用時,每個調用都不釋放線程,等待結果返回。一個業務的調用量異常可能會拖垮整個集群。

 

- 立體監控架構

黑天鵝現象:

    非常難以預測的罕見現象,通常會引起連鎖負面反應甚至顛覆。

目標:

    為了從海量監控、報警風暴數據中找到產生影響的「黑天鵝」,立體監控應任而生。

特點:

  • 多維數據模型

  • 在多維度上靈活查詢

  • 多種可視化圖表及儀錶盤支持

 

三、總結

    親身經歷是教育的最好形式。

 

相關閱讀:

程式常用的設計技巧

到底多大才算高併發?

美團分散式服務通信框架及服務治理系統OCTO

學會用數據說話-分散式鎖究竟可以多少併發?

大話高可用


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

-Advertisement-
Play Games
更多相關文章
  • 今天碰到的一個比較煩人的問題是,在body上添加事件處理函數,發現在iphone上怎麼也沒辦法觸發事件,找了半天,發現iPhone處理冒泡事件的規則: 1.點擊某個元素; 2.如果這個元素上沒有處理該事件,則繼續向上冒泡,直到body下的子節點為止。如果此時還是沒有元素處理這個事件,則丟棄該事件,不 ...
  • 如果你是一個人在自學前端開發,或者是對前端開發有比較濃厚的興趣正想踏入前端領域,只要你在前端自學路上遇到了自己無法解決的技術難題,那麼儘管將你的疑惑交給我的小伙伴兒們吧,我們都是一群在前端自學路上摸爬滾打的有志青年,希望你可以來和我們共同交流。同時也希望你能獻出自己的一份力,幫助我的小伙伴兒們解決他 ...
  • 原型與原型鏈 javascript 創建對象 類與構造函數是大多數編程語言所擁有的,而借鑒了 C 與 JAVA 的 javascript 也是有類和構造函數的,不過 javascript 的實現不太一樣。 上面的例子中, 就是構造函數, 就是它的實例,但是它對共用性不太好,所以有了原型模式。 原型模 ...
  • 這兩天接觸到一個很有意思的 CSS 屬性 -- box-decoration-break。下麵就一起去一探究竟。 因為 MDN 上關於這個屬性,沒有中文文檔,所以一直在想一個合理貼切的中文翻譯。直譯一下: box -- 盒,可以理解為元素盒模型 decoration -- 裝飾,理解為元素樣式 br ...
  • [TOC] 裝飾器進階 通過上一篇已經知道, 如果還有概念還不理解的請返回裝飾器入門 "裝飾器入門" 裝飾器 實際也是一種函數, 他是 python語言的重要組成部分, 在實際開發中應用也相當廣泛. 正如我們所知, 前面所看到的被裝飾的函數都是最簡單函數格式, 這裡所說的簡單, 是指 ,`或者函數沒 ...
  • http://note.youdao.com/noteshare?id=42fc159d62b041e91c9e60822694db9f&sub=6D019045DECF4CAE8ABF5631C2798DCB ...
  • 1、架構 RocketMQ的master broker與master broker沒有任何消息通訊,nameserver之間也同樣沒有消息通信 MQ歷史 由數據結構隊列發展而來 MQ使用場景 非同步處理 解耦 削峰填谷 數據同步 2、隊列 rocketMQ一個主題(topic)包含多個隊列 3、使用 ...
  • 一直都想擁有一個屬於自己的技術博客,今天終於開通了,很激動。第一篇隨筆就分享一下自己今天剛學習和實踐的裝飾者設計模式。 一、設計模式到底是什麼東西,它有對應的物質嗎? 如果我們看不到物質,那麼一切的意識都是站不住腳的。那麼什麼是設計模式呢?它能映射到對應的物質嗎? 以前我剛開始接觸設計模式是在學習j ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...