Redis 是一个高性能的key-value数据库,属于NoSQL的一种。它提供了Python,Ruby,Erlang,PHP客户端,使用很方便。它跟memcached类似,不过数据可以持久化,而且支持的数据类型更丰富。有字符串,链表,集合和有序集合。支持在服务器端计算集合的并,交和补集(difference)等,还支持多种排序功能。
1、安装
1 | $ wget http://download.redis.io/releases/redis-2.8.19.tar.gz |
2、编译完成后就会生成相关的二进制可执行文件,为了便于管理。创建3个目录分别用来存放可执行二进制文件、配置文件、数据持久化文件。将src目录下的二进制文件redis-benchmark、redis-check-aof、redis-check-dump、redis-cli、redis-sentinel(非必需)、redis-server拷贝到bin目录,配置文件redis.conf、sentinel.conf(非必需)拷贝到etc目录。
1 | $ mkdir -p /usr/local/redis/{bin,db,etc} |
redis-server:Redis服务器的daemon启动程序,对应的默认配置文件redis.conf。
redis-benchmark:Redis性能测试工具。
redis-cli:Redis命令行操作工具,类似于mysql的控制台。
redis-check-aof/redis-check-dump:修复损坏的数据文件file.aof/dump.rdb。
redis-sentinel:用于管理多个Redis服务器(instance),为集群提供监控、提醒、自动故障迁移服务,对应的配置文件sentinel.conf。
3、按需调整默认配置的相关参数并启动
1 | # 以守护进程的模式运行实例 |
启动redis,可以看到redis默认监听TCP的6379端口
1 | $ /usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf |
查看redis的日志时发现在启动的时候抛出了两条警告:
1 | [5430] 20 Dec 15:09:15.859 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect. |
根据警告提示我们需要将内核参数vm.overcommit_memory设置为1,net.core.somaxconn设置成更大的数值,默认是128。编辑文件/etc/sysctl.conf,追加2行
1 | #sysctl文件追加的参数 |
关于这两个内核参数的解释:
vm.overcommit_memory 指定了内核针对内存分配的策略,其值可以是0、1、2。
0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2, 表示内核允许分配超过所有物理内存和交换空间总和的内存。
net.core.somaxconn
定义了系统中每一个端口最大的监听队列的长度,这是个全局的参数,默认值为128,在某些应用下可能会限制接收新TCP连接侦听队列的大小。
4、用redis提供的命令行工具进行一些简单的操作
1 | $ /usr/local/redis/bin/redis-cli |