亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

分布式系統(tǒng)中的降級(jí)熔斷設(shè)計(jì)問(wèn)題面試

 更新時(shí)間:2022年03月09日 15:55:01   作者:Q.E.D  
這篇文章主要為大家介紹了分布式系統(tǒng)中的降級(jí)熔斷設(shè)計(jì)問(wèn)題面試解答,有需要的朋友可以借鑒參考下,希望能有所幫助,祝大家多多進(jìn)步,早日升職加薪

引言

穩(wěn)定性設(shè)計(jì)第一篇:在分布式系統(tǒng)下,線上的某一個(gè)功能按鈕背后會(huì)有很多個(gè)服務(wù)共同完成,這些服務(wù)之間有依賴關(guān)系,且有一定的順序調(diào)用。那么這些服務(wù)如果其中有一個(gè)環(huán)節(jié)出現(xiàn)問(wèn)題,會(huì)帶來(lái)一些連鎖反應(yīng)。

比如,突如其來(lái)的流量,部分服務(wù)突然宕機(jī),你能想到的故障都算故障,是不是整個(gè)服務(wù)都不可用了嗎?作為開(kāi)發(fā)者肯定不希望這樣的事情發(fā)生,那么有哪些解決問(wèn)題?思路就是盡量給每個(gè)服務(wù)找一個(gè)“備胎” ,這個(gè)“備胎”不是集群概念里一個(gè)備用機(jī)器 ,而是一種備用方案。

1、面試官:

你對(duì)你負(fù)責(zé)的系統(tǒng)做了哪些提高可用性的設(shè)計(jì)?

問(wèn)題分析:穩(wěn)定性設(shè)計(jì)三把斧:降級(jí)、熔斷和限流。即使你沒(méi)用過(guò),也可以完全根據(jù)我描述的場(chǎng)景再結(jié)合自己的項(xiàng)目編造一個(gè)。

答:這個(gè)問(wèn)題很好理解,舉個(gè)例子:比如外賣訂單服務(wù),假設(shè)美團(tuán)外賣訂單系統(tǒng),系統(tǒng)日常QPS 在 1000 左右(這里我拍腦袋假設(shè),實(shí)際遠(yuǎn)高于1000),可能受天氣影響或者是否工作日,QPS 會(huì)上下浮動(dòng),為1000 - 2000之間。

假設(shè)線上系統(tǒng)設(shè)計(jì)時(shí)最多能承受2000 QPS,正常會(huì)發(fā)生的突發(fā)情況單量增多都能承受,突然有那么一天,你的競(jìng)爭(zhēng)對(duì)手餓了么宕機(jī)了,用戶無(wú)法使用都蜂擁而至來(lái)美團(tuán)下單,這個(gè)時(shí)候QPS 變成了 3000,系統(tǒng)扛不住 3000 的QPS怎么辦?用戶都卡在提交訂單的頁(yè)面,誰(shuí)也下不了單。那么如何有效解決這個(gè)問(wèn)題?這個(gè)時(shí)候就要想到“備胎”方案,嘗試以下優(yōu)化思路。

  1. 流量控制:也就是限流,限流包括單機(jī)限流和集群限流,訂單系統(tǒng)某一環(huán)節(jié)加一個(gè)開(kāi)關(guān),好比地鐵進(jìn)站口,人多要排隊(duì),保證流量持續(xù)進(jìn)入,而不是撐破服務(wù)器大家都無(wú)法使用,比如將系統(tǒng)QPS控制在最高2000,后面的 1000 用戶告訴他“系統(tǒng)繁忙,請(qǐng)稍后再試”,這樣一來(lái)無(wú)非就是多點(diǎn)幾下或者等幾分鐘,你還能吃上飯。
  2. 降級(jí)備案:比如商品列表查詢,默認(rèn)查詢的是 Redis 集群,各種故障趕在一起,Redis 所有集群都掛了不能用了,這個(gè)時(shí)候怎么辦,設(shè)計(jì)一個(gè)備胎 Elasticsearch,查詢速度可能沒(méi) Redis 快,但好歹備胎還能用。
  3. 熔斷: 這個(gè)可以理解成家庭電路中的保險(xiǎn)絲,電流有異常后自動(dòng)開(kāi)啟熔斷保護(hù),系統(tǒng)流量也同樣原理。

舉例: 我對(duì)公司內(nèi)部訂單查詢系統(tǒng)做的優(yōu)化,訂單查詢是運(yùn)營(yíng)人員每天都要使用的功能,一定要保證服務(wù)可用,還要迅速響應(yīng),為了解決這個(gè)問(wèn)題,我使用了ES作為查詢主庫(kù),如ES故障,系統(tǒng)會(huì)自動(dòng)降級(jí)到MySQL查詢,完美解決了性能和可用性的問(wèn)題。

圖片描述

(有了上面這個(gè)例子,面試官對(duì)我在系統(tǒng)可用性方面的設(shè)計(jì)能力放心多了。)

Tip: 說(shuō)了這么多不如直接看看圖形界面,限流到底是怎么用的,舉個(gè)例子,我負(fù)責(zé)的一個(gè)接口,限流參數(shù)設(shè)置是這樣的。

圖片描述

這是限流功能做成頁(yè)面可視化系統(tǒng)以后,看看紅色框備注和提示如何設(shè)置限流,是不是so easy,使用開(kāi)源的 Hystrix 也能解決此類問(wèn)題。

總結(jié)

這一節(jié)的內(nèi)容不多,最重要的是要知道系統(tǒng)穩(wěn)定性設(shè)計(jì)還有三把斧:降級(jí)、熔斷和限流,內(nèi)容并不難,重要的是你要有這個(gè)意識(shí),你能做到讓系統(tǒng)全年不故障持續(xù)提供服務(wù),領(lǐng)導(dǎo)把這事兒交給你放心,offer不是你的是誰(shuí)的?

以上就是分布式系統(tǒng)中的降級(jí)熔斷設(shè)計(jì)問(wèn)題面試的詳細(xì)內(nèi)容,更多關(guān)于分布式系統(tǒng)中的降級(jí)熔斷設(shè)計(jì)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • SpringBoot利用自定義注解實(shí)現(xiàn)隱私數(shù)據(jù)脫敏(加密顯示)的解決方案

    SpringBoot利用自定義注解實(shí)現(xiàn)隱私數(shù)據(jù)脫敏(加密顯示)的解決方案

    這兩天在整改等保測(cè)出的問(wèn)題,里面有一個(gè)“用戶信息泄露”的風(fēng)險(xiǎn)項(xiàng)(就是后臺(tái)系統(tǒng)里用戶的一些隱私數(shù)據(jù)直接明文顯示了),其實(shí)指的就是要做數(shù)據(jù)脫敏,本文給大家介紹了SpringBoot利用自定義注解實(shí)現(xiàn)隱私數(shù)據(jù)脫敏(加密顯示)的解決方案,需要的朋友可以參考下
    2023-11-11
  • 深入淺出Java中重試機(jī)制的多種方式

    深入淺出Java中重試機(jī)制的多種方式

    重試機(jī)制在分布式系統(tǒng)中,或者調(diào)用外部接口中,都是十分重要的。重試機(jī)制可以保護(hù)系統(tǒng)減少因網(wǎng)絡(luò)波動(dòng)、依賴服務(wù)短暫性不可用帶來(lái)的影響,讓系統(tǒng)能更穩(wěn)定的運(yùn)行的一種保護(hù)機(jī)制。本文就來(lái)和大家聊聊Java中重試機(jī)制的多種方式
    2023-03-03
  • 淺析java中next與nextLine用法對(duì)比

    淺析java中next與nextLine用法對(duì)比

    這篇文章主要介紹了java中next與nextLine用法區(qū)別以及實(shí)例分析了他們的區(qū)別,需要的朋友可以參考下
    2017-04-04
  • java 回調(diào)機(jī)制的實(shí)例詳解

    java 回調(diào)機(jī)制的實(shí)例詳解

    這篇文章主要介紹了java 回調(diào)機(jī)制的實(shí)例詳解的相關(guān)資料,希望通過(guò)本文的示例能幫助到大家理解使用回調(diào)機(jī)制,需要的朋友可以參考下
    2017-09-09
  • 帶你了解Java中Static關(guān)鍵字的用法

    帶你了解Java中Static關(guān)鍵字的用法

    這篇文章主要介紹了JAVA Static關(guān)鍵字的用法,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下,希望能給你帶來(lái)幫助
    2021-08-08
  • Java 如何安全的發(fā)布對(duì)象

    Java 如何安全的發(fā)布對(duì)象

    這篇文章主要介紹了Java 如何安全的發(fā)布對(duì)象,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2021-01-01
  • Java中Dijkstra算法求解最短路徑的實(shí)現(xiàn)

    Java中Dijkstra算法求解最短路徑的實(shí)現(xiàn)

    Dijkstra算法是一種解決最短路徑問(wèn)題的常用算法,本文主要介紹了Java中Dijkstra算法求解最短路徑的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • springboot mybatis里localdatetime序列化問(wèn)題的解決

    springboot mybatis里localdatetime序列化問(wèn)題的解決

    這篇文章主要介紹了springboot mybatis里localdatetime序列化問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • 一文帶你搞懂Java中的泛型和通配符

    一文帶你搞懂Java中的泛型和通配符

    泛型機(jī)制在項(xiàng)目中一直都在使用,甚至很多源碼中都用到了泛型機(jī)制。但是里面很多的機(jī)制和特性一直沒(méi)有明白,尤其通配符這塊,經(jīng)常忘記。本文對(duì)此做了一些總結(jié),具有一定借鑒價(jià)值,希望有所幫助
    2022-09-09
  • Java Idea高效率配置技巧實(shí)例解析

    Java Idea高效率配置技巧實(shí)例解析

    這篇文章主要介紹了Java Idea高效率配置技巧實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04

最新評(píng)論