欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis服務器的啟動過程分析

 更新時間:2015年04月08日 09:39:41   投稿:junjie  
這篇文章主要介紹了Redis服務器的啟動過程分析,本文講解了初始化Redis服務器全局配置、加載配置文件、初始化服務器、加載數據、開始網絡監(jiān)聽等內容,需要的朋友可以參考下

本文將通過分析代碼來介紹Redis的啟動過程,通過查看Redis 的啟動腳本,得知Redis的啟動時從Redis.c的main方法開始的。Redis啟動可以分為以下幾個步驟:

1.初始化Redis服務器全局配置
2.重置服務器Save參數(具體下文詳解)和加載配置文件
3.初始化服務器
4.加載數據庫
5.開始網絡監(jiān)聽

一,初始化Redis服務器全局配置。這一步驟主要是主要是根據Redis.h中設置的Static值來初始化Redis服務器配置,這里設置是Redis服務器的默認配置。如:

·TCP Port,Redis Client的缺省Timeout;
·Redis缺省的數據庫數目;
·Redis Append 持久化方式的參數設置;
·Redis的所支持的各種數據結構的缺省值的設置;
·Redis內存Swap相關設置;
·Redis Master & Slave相關的配置;
·Redis Command Table初始化。

 二,加載配置文件:

這一步是通過讀取的配置文件來對Redis服務器進行設置,將會覆蓋上一步的某些缺省設置。打開下載下來的Redis源代碼,我們可以看到其根目錄下有一個默認的配置文件redis.conf。需要注意的是,如果在啟動Redis的時候沒有指定配置文件,則Redis服務器在啟動的時候是不會加載這個默認的配置文件進行配置的。而且這個默認的配置文件和第一步中得全局默認缺省配置不盡相同,比如針對Redis的Append模式的數據保存策略的配置,redis.conf里面的設置是:

save 900 1 -------15分鐘內一次更新
save 300 10 ------5分鐘內10次更新
save 60 10000 ---1分鐘內10000次更新。

而上一步里面的默認缺省配置確實:

save 60*60 1 -------一個小時內1次更新
save 300 100 ------5分鐘內100次更新
save 60 10000 ---1分鐘內10000次更新。

因此我們在啟動Redis的時候如果默認配置不能滿足要求,則需要指明配置文件進行配置。

三,初始化服務器:

初始化服務器是在initServer()方法中完成的,次方法利用上兩步設置的參數進一步初始化服務器:

·創(chuàng)建用來維護clients和slaves的list
·創(chuàng)建共享對象。redisObject這個struct里有個變量叫做refcount,這個變量就是用來實現共享的。Redis的對象目前Redis只支持共享StringObject。Redis的共享對象有兩大類比:第一類:Redis server的各種操作需要經常用到的各類對象,如:Redis Command的分隔符 "\r\n",用于Redis command的reply的"+OK\r\n"或者"-ERR\r\n"等對象,因為在Redis的各種操作這類對象要被頻繁使用,所以就在啟動Redis的時候創(chuàng)建好,然后共用這些對象,減少時間成本和空間成本;第二,類的共享對象就是對應于數字的StringObject,如:Set "olylakers1" 1234; Set "olylakes2" 1234;在Redis內部,"olylakers1"和"olylakers2"這兩個key都指向由數字1234轉化的StringObject。這樣在海量數據和特定存儲內容下,可以節(jié)省大量的內存空間??捎猛ㄟ^REDIS_SHARED_INTEGERS這個參數來指定Redis啟動的時候創(chuàng)建多少個第二類共享對象,默認的參數是10000,即創(chuàng)建的StrongObject個取值范圍是0-9999之間。

·創(chuàng)建Pub/Sub通道
·初始化網絡監(jiān)聽EventLoop的相關內容,如eventLoop,timeEvent,fileEvent等
·如果開啟了VM,則初始化虛擬內存相關的IO/Thread

四,加載數據:

根據配置的不同,Redis加載數據的源也不一樣,如果在配置文件里設置了appendonly  yes(默認是no),那么就從appendfile加載數據,反之則從RedisDb加載數據

·從appendfile加載數據:我們先來看一下appendfile的內容是什么。下面的一條記錄摘取自appendfile:SET $9 olylakers $3 oly。很顯,appendfile保存的就是redis server接收到的各種命令,那么從appendfile加載數據就是redis server從appenfile里面讀取這些命令的記錄,然后重新把這些命令執(zhí)行一遍即可。需要注意的是,如果開啟了VM,那么在從appendfile加載數據的時候可能要涉及swap操作。
·從redisdb加載數據:如果沒有開啟appendonly,那么則需要從db file加載數據到內存,其過程是:
1.通過處理select命令,選擇DB
2.然后從db file讀取key和value
3.檢查key是否過期,如果過期則跳過這個key,如果不過期,則把數據Add到對應的db的dict中
4.如果開啟了VM,則從db file中l(wèi)oad數據,也可能涉及到swap操作

五,開始網絡監(jiān)聽:

Redis的網絡監(jiān)聽沒有采用libevent等,而是自己實現了一套簡單的機遇event驅動的API,具體見ae.c。

相關文章

  • 一文搞懂Redis中String數據類型

    一文搞懂Redis中String數據類型

    string 是 redis 最基本的類型,你可以理解成與 Memcached 一模一樣的類型,一個 key 對應一個 value。今天通過本文給大家介紹下Redis中String數據類型,感興趣的朋友一起看看吧
    2022-04-04
  • Redis配置文件詳解

    Redis配置文件詳解

    這篇文章主要介紹了Redis配置文件詳解,本文詳細完整的用中文解釋了Redis配置文件中各種參數的作用和功能,需要的朋友可以參考下
    2015-04-04
  • Redis基本數據類型哈希Hash常用操作命令

    Redis基本數據類型哈希Hash常用操作命令

    這篇文章主要為大家介紹了Redis基本數據類型哈希Hash常用操作,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • Redis序列化存儲及日期格式的問題處理

    Redis序列化存儲及日期格式的問題處理

    這篇文章主要介紹了Redis序列化存儲及其日期格式的問題處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 基于Redis實現抽獎功能及問題小結

    基于Redis實現抽獎功能及問題小結

    這篇文章主要介紹了基于Redis實現抽獎功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • Redis+Caffeine實現分布式二級緩存組件實戰(zhàn)教程

    Redis+Caffeine實現分布式二級緩存組件實戰(zhàn)教程

    這篇文章主要介紹了Redis+Caffeine實現分布式二級緩存組件實戰(zhàn)教程,介紹了分布式二級緩存的優(yōu)勢,使用組件的方法,通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • Redis通用命令介紹以及key的層級結構講解

    Redis通用命令介紹以及key的層級結構講解

    這篇文章主要介紹了Redis通用命令以及key的層級結構,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-12-12
  • Redis過期鍵與內存淘汰策略深入分析講解

    Redis過期鍵與內存淘汰策略深入分析講解

    因為redis數據是基于內存的,然而內存是非常寶貴的資源,然后我們就會對一些不常用或者只用一次的數據進行存活時間設置,這樣才能提高內存的使用效率,下面這篇文章主要給大家介紹了關于Redis中過期鍵與內存淘汰策略,需要的朋友可以參考下
    2022-11-11
  • NestJS+Redis實現手寫一個限流器

    NestJS+Redis實現手寫一個限流器

    限流是大型系統(tǒng)必備的保護措施,本文將結合redis , lua 腳本 以及 Nestjs Guard 來實現 限流的效果,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-11-11
  • redis復制集群搭建的實現

    redis復制集群搭建的實現

    redis 復制集群是開發(fā)中一種比較常用的集群模式,本文主要介紹了redis復制集群搭建的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08

最新評論