这样我们就可以先从外部观察,尝试执行一些命令,在了解了这些命令执行的外部表现之后,再钻进去看对应的源码是如何实现的。要想读懂这些代码,首先我们需要理解redis的事件机制。
而且,一旦理解了redis的事件循环(event loop)的机制,我们还会搞明白一个有趣的问题:为什么redis是单线程执行却能同时处理多个请求?(当然严格来说redis运行起来并非只有一个线程,但除了主线程之外,redis的其它线程只是起辅助作用,它们是一些在后台运行做异步耗时任务的线程)
从main函数开始,沿着代码执行路径,实际上我们可以一直追下去。我们还是限定一下范围。
从main函数开始,一步步追踪下去,最终到达任一redis命令的执行入口。或者,你也可以自己去完成剩下的探索了。
初始化流程和事件循环概述
redis源码的main函数在源文件server.c中。main函数开始执行后的逻辑可以分为两个阶段:
各种初始化(包括事件循环的初始化);
执行事件循环。
这两个执行阶段可以用下面的流程图来表达(点击看大图)
以上就是redis源码是什么语言的详细内容。