前面写了一篇文章简单介绍Redis的list结构。再写完之后,我觉得有必要熟悉Redis的启动过程和如何读取Redis的命令,因此本文将通过分析代码来介绍Redis的启动过程,通过查看Redis 的启动脚本,得知Redis的启动时从Redis.c的main方法开始的。Redis启动可以分为以下几个步骤:
- 初始化Redis服务器全局配置
- 重置服务器Save参数(具体下文详解)和加载配置文件
- 初始化服务器
- 加载数据库
- 开始网络监听
一,初始化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()方法中完成的,次方法利用上两步设置的参数进一步初始化服务器:
- 创建用来维护clients和slaves的list
- 创建共享对象。redisObject这个struct里有个变量叫做refcount,这个变量就是用来实现共享的。Redis的对象目前Redis只支持共享StringObject。Redis的共享对象有两大类比:第一类:Redis server的各种操作需要经常用到的各类对象,如:Redis Command的分隔符 "\r\n",用于Redis command的reply的"+OK\r\n"或者"-ERR\r\n"等对象,因为在Redis的各种操作这类对象要被频繁使用,所以就在启动Redis的时候创建好,然后共用这些对象,减少时间成本和空间成本;第二,类的共享对象就是对应于数字的StringObject,如:Set "olylakers1" 1234; Set "olylakes2" 1234;在Redis内部,"olylakers1"和"olylakers2"这两个key都指向由数字1234转化的StringObject。这样在海量数据和特定存储内容下,可以节省大量的内存空间。可用通过REDIS_SHARED_INTEGERS这个参数来指定Redis启动的时候创建多少个第二类共享对象,默认的参数是10000,即创建的StrongObject个取值范围是0-9999之间。
- 创建Pub/Sub通道
- 初始化网络监听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里面读取这些命令的记录,然后重新把这些命令执行一遍即可。需要注意的是,如果开启了VM,那么在从appendfile加载数据的时候可能要涉及swap操作。
- 从redisdb加载数据:如果没有开启appendonly,那么则需要从db file加载数据到内存,其过程是:
- 通过处理select命令,选择DB
- 然后从db file读取key和value
- 检查key是否过期,如果过期则跳过这个key,如果不过期,则把数据Add到对应的db的dict中
- 如果开启了VM,则从db file中load数据,也可能涉及到swap操作
五,开始网络监听:
Redis的网络监听没有采用libevent等,而是自己实现了一套简单的机遇event驱动的API,具体见ae.c。因为这一部分内容比较多,因此后面会单独写篇文章来描述其过程。
以上五个部分就是Redis启动的全部过程,
分享到:
相关推荐
暂无Redis开发实操之春运迁移民页面Redis启动到连接,使用Redis Hash,排序集,流,TairGis等结构实现一个春运迁徙页面。 ,Redis的运维实战Redis社区及运营方式介绍,云Redis特性介绍及运维解法,高级容灾。 Redis...
db服务器连接mysql+redis高可用高性能框架干货1、使用c++语言,vs2019开发垮平台[windows和linux]连接MySql和redis框架。2、使用MySql持久化玩家数据,redis做玩家数据缓存层,redis不做数据持久化。mysql搭配redis...
├─补充1:拔高课程(Redis3.0持久化、集群、MySQL5.6优化、Tomcat7优化) │ │ 打开必读.txt │ │ │ ├─课前资料 │ │ ├─MySQL5.6优化 │ │ │ MySql5.6性能优化.docx │ │ │ │ │ ├─Redis集群 │ ...
Redis | 分布式缓存数据库 | [https://redis.io/](https://redis.io/) Solr & Elasticsearch | 分布式全文搜索引擎 | [http://lucene.apache.org/solr/](http://lucene.apache.org/solr/) [https://www.elastic.co/]...
智能识别创建不同的连接 对于只读操作、非事务操作LCN将不开启代理功能,返回本地连接对象,对于补偿事务的启动方将开启回滚连接对象,执行完业务以后马上回滚事务。 LCN连接重用机制 当模块在同一次事务下被重复...
6.springboot的启动原理,SpringBoot启动用到的注解,解释微服务?springboot登陆拦截? 9.mybatis和hibernate主要的区别?mybatis框架介绍? 16.hashmap原理?底层怎么实现的?如何取得key值?用代码怎么写? 17...
但很少全面有的案例告诉你如何去做,既然是从0到1,希望以下代码案例可以帮助到你。当然最终落实到生产,还有很长的路要走,要根据自己的业务进行编码,实施并部署。 启动说明 启动前 请配置 application....
然后导入sql文件,修改相应的的配置,关于主从配置请自行百度啦,运行起项目,然后需要把`GameService`类以及`CommentService`类里面的`afterPropertiesSet`方法里面的代码注释掉,这是第一次启动加载缓存的代码。...
1个目标文件,JNDI的使用例子,有源代码,可以下载参考,JNDI的使用,初始化Context,它是连接JNDI树的起始点,查找你要的对象,打印找到的对象,关闭Context…… ftp文件传输 2个目标文件,FTP的目标是:(1)提高...
2.7、SpringBoot启动方式1 4 2.8、SpringBoot启动方式2 4 2.9、SpringBoot启动方式3 5 三、 Web开发 5 3.1、静态资源访问 5 3.2、渲染Web页面 5 3.3、使用Freemarker模板引擎渲染web视图 6 3.3.1、pom文件...
1个目标文件,JNDI的使用例子,有源代码,可以下载参考,JNDI的使用,初始化Context,它是连接JNDI树的起始点,查找你要的对象,打印找到的对象,关闭Context…… ftp文件传输 2个目标文件,FTP的目标是:(1)提高...
1.原理1.请求开始前,根据key查询查到结果:报错未查到结果:存入key-value-expireTimekey=ip+url+args2.请求结束后,直接删除key不管key是否存在,直接删除是否删除,可配置3.expireTime过期时间,防止一个请求卡死...
myscan依赖burpsuite和redis,需启动redis和burpsuite插入myscan的插件。 突破性的burp强大的抓包和解析数据包的功能,插件调取api把burp的请求体和响应体的处理数据整合成json数据传输到redis。 myscan调取redis...
1 目标 致力于建立全球最完善的 Java 高并发理论体系。让我们的程序更加可靠,跳槽面试更轻松。 2 深入底层原理,实现并发业务 线程N种实现方式 线程启动你真的会么? 线程停止、中断的最佳实践 线程生命周期 趣解...
1. 启动本项目时,需提前启动 Nacos、RocketMQ、MySQL、Redis、ElasticSearch、Sentinal 实例。 2. conntector 与 connector-2 这两个模块并不一样,connector-2 使用了 Dubbo 进行消息转发(实验阶段),而 ...
spring boot 项目代码,直接启动,第一部分 点睛Spring 4.x 第1 章 Spring 基础 ..........................................2 1.1 Spring 概述 ............................................. 2 1.2 Spring 项目...
Springboot学习示例 博客文章链接 (15)Spring Boot2.0 和邮件 (16)Spring Boot2.0 整合Spring Security (17)Spring Boot2.0 整合Shiro (18)Spring Boot2.0 与监控管理
05 系统启动流程 06 grub加密 07 bios加密 08 top命令 09 free命令 10 进程管理 第6章 01 上节课复习 02 磁盘分区 03 文件系统与挂载 04 挂载信息讲解 05 磁盘用满的两种情况 06 软连接和硬链接 07 软连接和硬链接...
Testsuite启动任何必需的数据库(PostgreSQL,mongo,redis)。 在每次测试之前,测试套件将测试数据填充到数据库中。 Testsuite启动其自己的Web服务器(模拟服务器),该服务器模仿(嘲弄)被测试的微服务