文档详情

Redis运行流程源码解析.pdf

发布:2017-09-25约5.37万字共31页下载文档
文本预览下载声明
[Type the document title] Redis 运行流程源码解析 作者:nosqlfan on 星期一, 五月28, 2012 ·8 条评论 【阅读:8,222 次】 本文来自@凡趣科技pesiwang 同学的投稿分享,对Redis 运行流程,命令处理的内部实现进行了深 入讲解。 本文分析源码基于Redis 2.4.7 stable 版本。 概述 Redis 通过定义一个struct redisServer 类型的全局变量server 来保存服务器的相关信息(比如:配置 信息,统计信息,服务器状态等等)。启动时通过读取配置文件里边的信息对server 进行初始化 (如果没有指定配置文件,将使用默认值对sever 进行初始化),初始化的内容有:起监听端口, 绑定有新连接时的回调函数,绑定服务器的定时函数,虚拟内存初始化,log 初始化等等。 启动 初始化服务器配置 先来看看redis 的main 函数的入口 Redis.c :1694 int main(int argc, char **argv) { time_t start; initServerConfig(); if (argc == 2) { if (strcmp(argv[1], -v) == 0 || strcmp(argv[1], --version) == 0) version(); if (strcmp(argv[1], --help) == 0) usage(); resetServerSaveParams(); loadServerConfig(argv[1]); } else if ((argc 2)) { usage(); } else { ... } if (server.daemonize) daemonize(); initServer(); ...  initServerConfig 初始化全局变量server 的属性为默认值。  如果命令行指定了配置文件,resetServerSaveParams 重置对落地备份的配置(即重置为默认值)并 读取配置文件的内容对全局变量server 再进行初始化,没有在配置文件中配置的将使用默认值。  如果服务器配置成后台执行,则对服务器进行daemonize 。  initServer 初始化服务器,主要是设置信号处理函数,初始化事件轮询,起监听端口,绑定有新连接 时的回调函数,绑定服务器的定时函数,初始化虚拟内存和log 等等。  创建服务器监听端口。 Redis.c :923 if (server.port != 0) { server.ipfd= anetTcpServer(err,server.port,server.bindaddr); Page 1 of 31 [Type the document title] if (server.ipfd == ANET_ERR) { redisLog(REDIS_WARNING, Opening port %d: %s, server.port, err); exit(1); } }  anetTcpServer 创建一个socket 并进行监听,然后把返回的socket fd 赋值给server.ipfd 。 事件轮询结构体定义 先看看事件轮询的结构体定义 Ae.h :88 /* State of an event based program */ typedef struct aeEventLoop { int maxfd; long long timeEventNextId; aeFileEvent events[AE_SETSIZE]; /* Registered events */ aeFiredEvent fired[AE_SETSIZ
显示全部
相似文档