精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

面試官:你知道緩存擊穿、緩存穿透、緩存雪崩嗎?

開發(fā) 前端
現在執(zhí)行 SHOW STATUS LIKE 'Threads_connected'? 去查看MySQL連接線程數會發(fā)現數值突然升高,當連接數為1283 左右時,就會發(fā)現MySQL服務已經斷開連接或者服務器宕機,也就是緩存雪崩的效果。

前言

又到了一年一度的金三銀四了,大家在面試的時候一定被問到過Redis緩存問題吧。可能有些初學者對“緩存擊穿、緩存穿透、緩存雪崩”這幾個名詞感到陌生,或者了解過但是一時半會沒辦法理解。沒關系,希望通過本文可以讓你輕松理解這些概念并掌握其解決方案,然后在即將到來的金三銀四面試中對你有所幫助。

面試題剖析

花里胡哨的名詞

剛開始我以為“緩存擊穿、緩存穿透、緩存雪崩”說的是3個問題,在各個博客以及視頻的講解下越來越繞。最后我捋了一下,這TM不是一個問題嗎。

為了讓大家也繞一繞,我把各博客對“緩存擊穿、緩存穿透、緩存雪崩”的描述貼在這里:

緩存擊穿是指一個熱點的Key在某個瞬間過期失效了,大量的并發(fā)請求在緩存獲取不到數據后直接請求數據庫的現象。

緩存穿透是指查詢一個根本不存在的數據,緩存和數據庫都不會命中,導致每次請求都要到數據庫去查詢。

緩存雪崩指的是緩存由于宕機或者某些原因不能提供服務,導致所有的請求去訪問數據庫,造成數據庫查詢壓力驟增從而宕機。

透過現象看本質

我就非常不理解了,為什么把緩存帶來的一個問題分好幾個場景去描述,還這解決方案,那解決方案的,花里胡哨的增加了大家的理解難度。

在我看來“緩存擊穿、緩存穿透,緩存雪崩”都是在說一個問題,那就是:

緩存沒命中,請求落到數據庫了

而“緩存雪崩”才突出了問題的本質:

沒有緩存的緩沖,數據庫承受不了那么大的壓力,可能會造成宕機等問題。

仔細想想是不是這樣?“緩存擊穿、緩存穿透、緩存雪崩”最終的描述都是請求落到數據庫了,只不過場景不同罷了。但不論哪種場景,在并發(fā)高的情況下都會給數據庫帶來壓力。

所以,一個問題分這么多場景,引出這么多名詞,我認為就是在增加大家的理解難度。

面試題解決方案

有問題就會有解決方案,既然看了這篇文章就不要死記硬背了,不然過段時間又會忘記,跟著思路順其自然的理解。

透過現象看本質

對于以上的幾個場景,要解決的問題就是:

如何提高緩存命中率。

也就是盡量避免請求打到數據庫中,尤其是高并發(fā)的請求。主要涉及兩個層面:

  1. 緩存組件要可靠:首先要確保緩存組件足夠可靠。
  2. 代碼邏輯要嚴謹:在編寫代碼使用緩存時盡量要把各種場景考慮進去,把問題當作功能的一部分。

像“緩存擊穿、緩存穿透”問題的產生都屬于代碼邏輯不嚴謹。熱點Key怎么能突然消失呢?一個相同的請求怎么能并發(fā)訪問到數據庫呢?怎么能允許一個不存在的數據一直請求呢?這些問題在我看來都是不應該發(fā)生的。

接下來就針對引起“緩存擊穿、緩存穿透、緩存雪崩”的幾個問題進行剖析解決。

提高緩存命中率一:完美處理熱點Key的消失

熱點數據通常分為可控和不可控。拿電商系統(tǒng)來講,商品分類屬于可控,因為基本上這類數據是通過后臺配置的。而一些商品可能會因為某個原因突然爆火成為熱點數據,這類數據屬于不可控。

不論可控或不可控,熱點數據不可以突然就消失,所以在緩存時要有對應的策略。

  • 像商品分類這類數據就可以不設置過期時間。
  • 而像不可控的熱點數據,要靠一些策略避免其過期,比如通過“看門狗”方式監(jiān)控熱點Key,快過期時進行“續(xù)命”。

可以都不設置過期時間,讓淘汰策略去淘汰數據嗎?

非常不建議。

之前生產環(huán)境曾遇到過一個問題:用戶每次登錄之后會莫名其妙退出。經過排查發(fā)現,原來是因為Redis服務容量不足,所以最近登錄生成的token一直被淘汰。

雖然沒有報錯,但是給用戶帶來不好的體驗,對產品造成非常不好的影響。

當然,避免不了熱點Key被人為刪除或者其他惡意破壞,當發(fā)生這種情況怎么辦?

如果熱點Key不存在緩存中,勢必要去數據庫中查詢了。此時,如果并發(fā)請求過高,一定不能讓所有請求打到數據庫,可以對該key進行加鎖處理,獲取到鎖的請求去數據庫訪問并緩存,其他請求則等待該key緩存后再訪問緩存。

因為平時寫代碼會很自然考慮到這一點,所以這也是為什么我剛開始一直不理解“緩存擊穿”這樣的問題。

提高緩存命中率二:避免查詢不存在的數據

造成“查詢不存在的數據”的原因要么是代碼或數據出現問題,要么是遭到惡意的攻擊造成的空命中。總之,這種情況無法完全避免。

但是,我們知道哪些數據會被緩存。這樣的話,我們可以將這些數據放在一個“大集合”中,當請求的數據不存在這個“大集合”時,直接返回NULL即可。

那么問題來了:這個“大集合”放在哪里?肯定不能是數據庫,但是內存容量又是有限的。怎么辦?

有一個叫布隆過濾器的數據結構可以解決這個問題。其主要用于檢測一個元素是否在一個集合里,其原理是:數據通過一組哈希函數映射到位圖中,不論該元素多大都只需要占用1位,從而節(jié)省大量空間。如下圖

圖片布隆過濾器原理

這樣的話,我就可以將要緩存的數據先放在布隆過濾器中,當查詢的數據不在布隆過濾器時就可以直接返回NULL了。

感興趣的可以看下 面試官:如何在海量數據中快速檢測某個數據

提高緩存命中率三:降低緩存服務的不可用

降低緩存服務的不可用也就是提高緩存服務的可用性,也就是Redis的高可用,這個沒有什么邏輯就不展開了。

面試題案例

模擬案例

現在,通過代碼模擬一個因“緩存擊穿、緩存穿透、緩存雪崩”,請求并發(fā)到MySQL服務上,看會發(fā)生什么事。

服務器環(huán)境:1核1G

編程語言:Java

案例代碼

public class MainTest {
    private static final String DB_URL = "jdbc:mysql://127.0.0.1:3306/test";
    private static final String USER = "root";
    private static final String PASS = "Mysql123.";

    public static void main(String[] args) throws InterruptedException {

        Timer timer = new Timer();
        TimerTask task = new TimerTask() {
            @Override
            public void run() {
                QueryTask.cacheExist = false;
            }
        };
        timer.schedule(task, 60 * 1000);

        while (true) {

            ExecutorService executorService = Executors.newFixedThreadPool(1500);
            for (int i = 0; i <1500 ; i++) {
                executorService.submit(new MainTest.QueryTask());
                System.gc();
            }
        }
    }

    static class QueryTask implements Runnable {
        static boolean cacheExist = true;

        @Override
        public void run() {
            try {

                if (cacheExist) {
                    System.out.println("訪問緩存");
                } else {
                    Class.forName("com.mysql.jdbc.Driver");
                    Connection conn = DriverManager.getConnection(DB_URL, USER, PASS);
                    Statement statement = conn.createStatement();
                    Thread.sleep(3000);
                    String query = "SELECT * FROM test_cache";
                    ResultSet rs = statement.executeQuery(query);
                    while (rs.next()) {
                        int id = rs.getInt("id");
                        String value = rs.getString("value");
                        System.out.println("ID: " + id + ", Value: " + value);
                    }

                    rs.close();
                    statement.close();
                    conn.close();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

上面的代碼主要做了兩件事:

  1. 模擬1500個線程去查詢數據。cacheExist為true時訪問緩存,為false時去請求數據庫。
  2. 通過定時任務在1分鐘后將cacheExist設置為false。各位就想象成熱點Key的突然消失、查詢不存在的數據、redis的宕機。

案例執(zhí)行效果

代碼在執(zhí)行1分鐘后就會報下面的錯誤信息:

com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data source rejected establishment of connection,  message from server: "Too many connections"

這是因為MySQL最大連接數只有151,遠遠低于并發(fā)線程數1500。

mysql> show variables like '%max_connections%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 151   |
+-----------------+-------+

此時,我將MySQL最大連接數設置為1500。

mysql> SET GLOBAL max_connections = 1500;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like '%max_connections%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 1500  |
+-----------------+-------+

現在執(zhí)行 SHOW STATUS LIKE 'Threads_connected' 去查看MySQL連接線程數會發(fā)現數值突然升高,當連接數為1283 左右時,就會發(fā)現MySQL服務已經斷開連接或者服務器宕機,也就是緩存雪崩的效果。

圖片圖片

MySQL壓力過高宕機

總結

面試時不要被花里胡哨的問題迷惑住,要思考一下問題的本質。

“緩存擊穿、緩存穿透、緩存雪崩”問題的本質就是:

當緩存沒命中或失效,并發(fā)的請求打到數據庫怎么辦?

通過上面的描述,此類問題要有以下考慮:

  1. 提高緩存命中率。比如,要解決熱點Key的突然消失、要避免查詢不存在的數據等。
  2. 數據庫并發(fā)請求要設置合理。太低了浪費資源,太高了就會出現MySQL服務宕機情況。

本文轉載自微信公眾號「Hi程序員」,可以通過以下二維碼關注。轉載本文請聯系Hi程序員公眾號。

責任編輯:武曉燕 來源: Hi程序員
相關推薦

2023-12-06 13:38:00

Redis緩存穿透緩存擊穿

2021-06-05 09:01:01

Redis緩存雪崩緩存穿透

2019-10-12 14:19:05

Redis數據庫緩存

2023-03-10 13:33:00

緩存穿透緩存擊穿緩存雪崩

2019-11-05 14:24:31

緩存雪崩框架

2020-03-16 14:57:24

Redis面試雪崩

2020-09-14 06:57:30

緩存穿透雪崩

2022-03-08 00:07:51

緩存雪崩數據庫

2022-05-27 07:57:20

緩存穿透緩存雪崩緩存擊穿

2021-12-25 22:28:27

緩存穿透緩存擊穿緩存雪崩

2022-11-18 14:34:28

2025-06-30 01:55:00

2023-11-10 14:58:03

2022-07-11 07:36:36

緩存緩存雪崩緩存擊穿

2023-04-14 07:34:19

2020-10-13 07:44:40

緩存雪崩 穿透

2020-12-28 12:37:36

緩存擊穿穿透

2020-03-05 09:09:18

緩存原因方案

2020-10-23 10:46:03

緩存雪崩擊穿

2024-04-07 00:00:02

Redis雪崩緩存
點贊
收藏

51CTO技術棧公眾號

色青青草原桃花久久综合| 欧美性xxxxx| 91原创国产| 久久午夜鲁丝片午夜精品| 久久动漫网址| 欧美日韩你懂的| 免费网站在线观看视频| 黄色视屏网站在线免费观看| 国产麻豆精品在线| 青草成人免费视频| 午夜精品福利在线视频| 日本欧美高清| 欧美一区二区三区视频免费播放| 日韩精品xxxx| 国产秀色在线www免费观看| av在线不卡免费看| 亚洲自拍欧美另类| 久久久精品视频网站| 亚洲色图二区| 亚洲天堂av在线免费| 无码国产精品一区二区高潮| 国产精品高清乱码在线观看| 一区二区高清视频在线观看| 日韩欧美手机在线| 少妇喷水在线观看| 国产乱理伦片在线观看夜一区| 日本免费久久高清视频| 欧美黄片一区二区三区| 日韩综合网站| 国产一区二区免费| 免费看黄色aaaaaa 片| 精品国产鲁一鲁****| 欧美日韩精品一二三区| 熟女人妇 成熟妇女系列视频| 伊人222成人综合网| 国产精品高潮久久久久无| 欧美日韩一区二区三区在线视频 | 美国一级片在线观看| 天海翼亚洲一区二区三区| 日韩美女在线视频| 日韩a一级欧美一级| 天然素人一区二区视频| 欧美性20hd另类| 欧美 丝袜 自拍 制服 另类| 黄页网站大全在线免费观看| 亚洲精品成a人| 在线观看成人免费| 爆操欧美美女| 亚洲蜜桃精久久久久久久| 老司机av福利| 成人av免费| 一区二区免费看| 欧美在线观看黄| 后进极品白嫩翘臀在线播放| 一区二区三区免费| 人人妻人人澡人人爽欧美一区双 | 亚洲欧美日本在线| 亚洲欧美日韩不卡| 国产不卡在线| 亚洲欧美日韩电影| 97超碰国产精品| 97在线超碰| 欧美性猛交xxxx偷拍洗澡| 久久婷婷国产精品| 三级成人在线| 欧美精三区欧美精三区| 亚洲天堂伊人网| 亚洲1区在线观看| 亚洲第一区中文字幕| 熟妇人妻久久中文字幕| 免费看av成人| 在线成人中文字幕| a在线视频播放观看免费观看| 亚洲精品小说| 国产69精品99久久久久久宅男| 日本少妇性生活| 久久精品二区三区| 成人激情电影一区二区| 亚洲精品综合网| 久久亚洲精品国产精品紫薇| 亚洲一区美女| 人人超在线公开视频| 日韩欧美在线视频免费观看| 亚洲36d大奶网| 日韩高清二区| 亚洲美女福利视频网站| 麻豆明星ai换脸视频| 激情婷婷欧美| 国产欧美日韩免费| 成人免费公开视频| 国产亚洲欧美日韩俺去了| 国产一二三四五| a欧美人片人妖| 91麻豆精品国产自产在线| 欧美熟妇精品一区二区蜜桃视频| 国产乱码精品一区二区三区四区| 日韩三级成人av网| 日本一区二区三区免费视频| 日韩成人av影视| 国产精品久久久久av福利动漫| 九色在线播放| 亚洲一二三四久久| 国产色视频在线播放| 99久久人爽人人添人人澡| 亚洲欧美另类人妖| 精品处破女学生| 免播放器亚洲一区| 好吊色欧美一区二区三区四区 | 亚洲视频在线一区| 97在线免费公开视频| 精品亚洲二区| 国产一区二区三区日韩欧美| 国产在线视频在线观看| 麻豆久久一区二区| 欧美日韩高清免费| 一区二区三区伦理| 69堂国产成人免费视频| 国产精久久一区二区三区| 国产一区日韩欧美| 成人精品久久一区二区三区| 美国成人毛片| 精品久久久久久| jjzz黄色片| 一本一道久久a久久精品蜜桃| 国产99视频精品免视看7| 俄罗斯嫩小性bbwbbw| 亚洲色图另类专区| 久久久精品高清| 欧美精品一区二区三区中文字幕| 97香蕉久久夜色精品国产| 亚洲AV无码一区二区三区性| 综合色天天鬼久久鬼色| 欧美午夜aaaaaa免费视频| 天堂日韩电影| 欧美一区二区三区精品电影| 成人午夜免费福利| 亚洲精品乱码久久久久久日本蜜臀| av丝袜天堂网| 欧美日韩国产区一| 亚洲一卡二卡三卡| 天天综合网站| 亚洲人成五月天| 国产情侣自拍av| 99久久国产综合精品女不卡| 国产传媒久久久| 玖玖玖电影综合影院| 久久精品色欧美aⅴ一区二区| 自拍偷拍色综合| 国产精品丝袜在线| 色噜噜狠狠永久免费| 成人精品中文字幕| 国产日韩欧美成人| 欧美激情午夜| 欧美一级高清片| 青春草免费视频| 成人免费黄色大片| av动漫在线看| 亚洲大片精品免费| 国产精品入口免费视| 中文字幕在线视频区| 欧美精品三级日韩久久| 麻豆changesxxx国产| 国产不卡视频在线观看| 日韩国产一级片| 亚洲精品亚洲人成在线观看| 国产mv久久久| 调教视频免费在线观看| 欧美一区二区人人喊爽| 久久久91视频| aaa亚洲精品一二三区| 日韩视频在线免费看| 九一国产精品| 91色中文字幕| 成人一级福利| 一区二区三区高清国产| 国产伦理一区二区| 亚洲二区视频在线| 精品国产成人亚洲午夜福利| 久久成人免费日本黄色| 精品久久久久久无码中文野结衣| 日韩高清一级| 成人淫片在线看| 日本性爱视频在线观看| 亚洲欧美日韩中文在线| 国产麻豆精品一区| 好吊成人免视频| fc2ppv在线播放| 2欧美一区二区三区在线观看视频| jizz欧美激情18| 国语精品一区| 亚洲成人精品电影在线观看| 一区二区三区在线免费看| 57pao国产精品一区| 黄色网页在线播放| 亚洲欧美另类人妖| 高h放荡受浪受bl| 在线视频中文字幕一区二区| 欧美成人综合色| 亚洲国产精品黑人久久久| www.com日本| 老司机精品视频一区二区三区| 日本男女交配视频| 久久精品国产68国产精品亚洲| 国产精品一区二区欧美黑人喷潮水| 欧美日韩成人影院| 97欧美精品一区二区三区| 欧美性天天影视| 亚洲毛茸茸少妇高潮呻吟| 亚洲av色香蕉一区二区三区| 欧美网站大全在线观看| 久久久久久久黄色片| 亚洲精品欧美激情| 免费一级黄色录像| 91一区一区三区| 熟妇高潮一区二区| 韩国av一区二区三区四区| 热久久精品免费视频| 一本色道久久综合亚洲精品高清| 91xxx视频| 欧美国产一级| 日韩国产精品一区二区三区| 欧美日韩大片免费观看| 成人自拍偷拍| 深夜福利一区二区三区| 91亚洲国产成人精品性色| 国产精品4hu.www| 日本中文字幕成人| 一区二区电影免费观看| 韩国三级电影久久久久久| 丰满诱人av在线播放| 久久躁狠狠躁夜夜爽| 成人高清网站| 中文字幕日韩精品在线观看| 国产天堂素人系列在线视频| 亚洲欧美国产另类| 天堂а在线中文在线无限看推荐| 精品国精品国产| 风流老熟女一区二区三区| 欧美成人一区二区三区在线观看| 国产av精国产传媒| 欧美一区二区视频在线观看| 中文字幕在线视频第一页| 欧美三级电影网| 亚洲一区二区视频在线播放| 欧美日韩中文字幕精品| 中文字幕理论片| 欧美日韩国产综合久久| 国产又大又粗又硬| 日韩一区二区三区在线视频| 99riav国产| 日韩欧美电影一二三| 男人天堂av网| 日韩电影免费在线观看中文字幕| 亚洲欧美色视频| 国产亚洲精品美女久久久久| 国产精品视频二区三区| 中文字幕日韩免费视频| gogo在线高清视频| 久久久久久伊人| 亚洲女同志freevdieo| 国产成人在线一区| 只有精品亚洲| 成人欧美一区二区| 色婷婷综合久久久久久| 日本不卡二区| 99精品一区| 久久久99精品视频| 国产乱码精品| 高清av免费看| 国产成人无遮挡在线视频| 四季av综合网站| 国产偷国产偷精品高清尤物| 美国一级片在线观看| 亚洲一卡二卡三卡四卡| 午夜精品一区二| 91精品一区二区三区在线观看| 亚洲成人av综合| 亚洲欧美中文日韩在线| 免费在线观看黄色网| 久久久久成人网| 欧美va在线| 99re热精品| 精品成人影院| 国产欧美久久久久| 日韩高清欧美激情| 手机版av在线| 9色porny自拍视频一区二区| 美国美女黄色片| 夜夜嗨av一区二区三区四季av | 99久热re在线精品996热视频| 老汉色老汉首页av亚洲| 亚洲精美视频| 亚洲激情在线| 午夜精品中文字幕| 26uuu色噜噜精品一区二区| 91n在线视频| 欧美体内谢she精2性欧美| av网站免费大全| 亚洲欧洲日产国码av系列天堂| 91福利国产在线观看菠萝蜜| 日韩av免费一区| 国产一级成人av| 亚洲欧洲免费无码| 亚洲欧洲日本一区二区三区| 久久精品亚洲天堂| 国产日本欧洲亚洲| 日韩欧美一区二区一幕| 日韩一区二区中文字幕| www视频在线观看免费| 91国自产精品中文字幕亚洲| 免费欧美网站| 中文网丁香综合网| 日韩精品国产欧美| 中国黄色a级片| 午夜精品久久久久久久99水蜜桃| 国产乱码精品一区二区三区精东| 亚洲人成77777在线观看网| 国产又色又爽又黄刺激在线视频| 91精品久久久久久久久久久| 国语产色综合| 国产精品亚洲αv天堂无码| 成+人+亚洲+综合天堂| 青青草原在线免费观看视频| 欧美日韩精品一区二区三区| 超碰国产在线| 国产成人综合av| 精品国产一区一区二区三亚瑟| 欧美性大战久久久久xxx| 成人高清免费观看| 久久精品国产亚洲av高清色欲 | 色婷婷狠狠18禁久久| 综合自拍亚洲综合图不卡区| 一道本在线视频| 久久天堂电影网| 久久久久亚洲精品中文字幕| 四虎精品欧美一区二区免费| 国产一区美女在线| 成人涩涩小片视频日本| 制服丝袜亚洲色图| av在线免费网址| 91观看网站| 国产精品扒开腿做爽爽爽软件| 麻豆传媒在线看| 亚洲一区二区欧美日韩| 免费国产羞羞网站视频| 久久免费视频在线观看| 欧美日韩另类图片| 欧美日韩国产精品激情在线播放| 99久免费精品视频在线观看| 国产三级av片| 亚洲一区二区精品| 看片一区二区| 91大学生片黄在线观看| 粉嫩av一区二区三区| 日本网站免费观看| 亚洲图片制服诱惑| 国产精品久久久久77777丨| 亚洲午夜激情| 成人做爰69片免费看网站| 毛片视频网站在线观看| 一本色道久久综合狠狠躁篇的优点| 福利一区和二区| 在线观看成人免费| 成人精品一区二区三区四区| 国产精品美女久久久久av爽| 亚洲欧美中文字幕| 国产成人免费视频网站视频社区| 女人床在线观看| 91麻豆国产自产在线观看| 成年人视频免费| 久久精品成人欧美大片古装| 亚洲成人影音| 精品久久久久久中文字幕2017| 中文字幕五月欧美| 欧美 日韩 国产 在线| 日本欧美爱爱爱| 68国产成人综合久久精品| 午夜男人的天堂| 欧美日韩高清一区| 韩国成人免费视频| 亚洲精品中文字幕在线 | 亚洲精品女人久久久| 欧美伊人久久久久久久久影院 | 国产一二三区在线观看| 精品不卡在线| 精品一区二区三区香蕉蜜桃| 日本在线视频免费| 日韩中文在线中文网三级| 国产另类在线| 99re6在线观看| 欧美视频第一页| 91精选在线| 亚洲成人第一| 久久综合色综合88| 99久久99久久久精品棕色圆| 茄子视频成人在线| 欧美视频导航| 午夜剧场免费在线观看| 亚洲免费影视第一页| a看欧美黄色女同性恋|