redis啓動過程

一. 入口
int main(int argc, char **argv)redis

二. main()處理
1. server配製初始化
 //各類配製初始化
 void initServerConfig(void)
    //redis命令初始化, server.commands就是在這裏初始化的
    populateCommandTable(void)

網絡

2. 加載配製
 //加載配製文件
 void loadServerConfig(char *filename, char *options)
    //加載配製上面方法生成的配製字符串
    loadServerConfigFromString(char *config)

dom

3. server初始化
 void initServer(void)
    //通知消息靜態數據初始化
    createSharedObjects()  
    //最大可打開文件設置
    adjustOpenFilesLimit()  
    //事件監聽器
    server.el = aeCreateEventLoop(server.maxclients+CONFIG_FDSET_INCR);
    //db內存初始化
       server.db = zmalloc(sizeof(redisDb)*server.dbnum);
    //tcp監聽端口初始化            
    listenToPort(server.port,server.ipfd,&server.ipfd_count)
    server.sofd = anetUnixServer(server.neterr,server. server.unixsocketperm, server.tcp_backlog)
    db初始化:socket

  /* Create the Redis databases, and initialize other internal state. */
    for (j = 0; j < server.dbnum; j++) {
        server.db[j].dict = dictCreate(&dbDictType,NULL);
        server.db[j].expires = dictCreate(&keyptrDictType,NULL);
        server.db[j].blocking_keys = dictCreate(&keylistDictType,NULL);
        server.db[j].ready_keys = dictCreate(&setDictType,NULL);
        server.db[j].watched_keys = dictCreate(&keylistDictType,NULL);
        server.db[j].eviction_pool = evictionPoolAlloc();
        server.db[j].id = j;
        server.db[j].avg_ttl = 0;
    }

    
    計劃任務和監聽事件初始化:   tcp

  /* Create the serverCron() time event, that's our main way to process
     * background operations. */
    if(aeCreateTimeEvent(server.el, 1, serverCron, NULL, NULL) == AE_ERR) {
        serverPanic("Can't create the serverCron time event.");
        exit(1);
    }

    /* Create an event handler for accepting new connections in TCP and Unix
     * domain sockets. */
    for (j = 0; j < server.ipfd_count; j++) {
        if (aeCreateFileEvent(server.el, server.ipfd[j], AE_READABLE,
            acceptTcpHandler,NULL) == AE_ERR)
            {
                serverPanic(
                    "Unrecoverable error creating server.ipfd file event.");
            }
    }
    if (server.sofd > 0 && aeCreateFileEvent(server.el,server.sofd,AE_READABLE,
        acceptUnixHandler,NULL) == AE_ERR) serverPanic("Unrecoverable error creating server.sofd file event.");

 

4. 加載數據
 loadDataFromDisk()oop


5. server開啓
 aeSetBeforeSleepProc(server.el,beforeSleep);
 //網絡事件監聽器啓動
    aeMain(server.el);
    aeDeleteEventLoop(server.el);spa

相關文章
相關標籤/搜索