redis啟動流程介紹
1. 準備運行環(huán)境
* 設置oom handler,zmalloc分配內存失敗時調用
* 初始化隨機種子,用于生成隨機數(shù)
* 將server參數(shù)初始化為默認值
* 創(chuàng)建命令與處理函數(shù)的映射表
2. 解析命令行參數(shù)、loadServerConfig()解析配置文件
* 配置文件會覆蓋命令行指定的參數(shù)
* 無效的配置項或者不合理的配置值會導致redis無法正常啟動
3. initServer()初始化服務
* 安裝信號處理函數(shù)
* 創(chuàng)建共享對象,redis預分配好常用的對象用于共享,以節(jié)省內存
* 根據(jù)maxc lients配置調整max open files
* 創(chuàng)建全局db字典,每個db對應一個dict
* 監(jiān)聽網(wǎng)絡端口,安裝事件處理器
* 如果開啟了aof,打開aof文件
* 創(chuàng)建serverCron定時器
4. loadDataFromDisk()從rdb或aof文件加載數(shù)據(jù)
* load數(shù)據(jù)出錯(比如文件格式亂掉)等會導致redis不能正常啟動
* loading的過程中,redis仍能處理請求,但大部分請求都會回復-LOADING錯誤
5. aeMain()開始事件循環(huán),接收客戶端請求
監(jiān)聽文件描述符的事件處理函數(shù)初始化為acceptTcpHandler,新建立的連接的事件處理函數(shù)設置為readQueryFromClient,readQueryFromClient從網(wǎng)絡連接上讀取請求,解析出請求參數(shù)并處理。
相關文章
redis key過期監(jiān)聽的實現(xiàn)示例
在Redis中,我們可以為Key設置過期時間,當Key的過期時間到達后,Redis會自動將該Key標記為已失效,本文就來介紹一下redis key過期監(jiān)聽的實現(xiàn)示例,感興趣的可以了解一下2024-03-03
Redis SETNX命令在Spring Cloud中的分布式鎖用法詳解
在Spring Cloud項目中,使用Java和Redis結合實現(xiàn)的分布式鎖可以確保訂單的一致性和并發(fā)控制,通過合理使用鎖的粒度以及注意事項,可以減少死鎖問題并提高系統(tǒng)的并發(fā)性能,這篇文章主要介紹了Redis SETNX命令在Spring Cloud中的分布式鎖用法詳解,需要的朋友可以參考下2023-10-10
如何在SpringBoot中使用Redis實現(xiàn)分布式鎖
這篇文章主要介紹了如何在SpringBoot中使用Redis實現(xiàn)分布式鎖,在實際開發(fā)中有可能會遇到多個線程同時訪問同一個共享變量,那么上鎖就很重要了,需要的朋友可以參考下2023-03-03
Redis報錯NOAUTH?Authentication?required簡單解決辦法
這篇文章主要給大家介紹了關于Redis報錯NOAUTH?Authentication?required的簡單解決辦法,Redis無密碼報錯NOAUTH Authentication required的原因是客戶端訪問Redis時需要提供密碼,但是沒有提供或提供的密碼不正確,需要的朋友可以參考下2024-05-05

