Redis 安装及调试
Redis安装与调试Linux版本:64位CentOS 7
Redis版本:3.0.7
Redis官网:http://redis.io/
Redis常用命令:http://redis.io/commands
安装Redis
wget http://download.redis.io/releases/redis-3.0.7.tar.gz
tar xzf redis-3.0.7.tar.gz
cd redis-3.0.7
make PREFIX=/usr/redis-3.0.7 install
make过程如果报错(如果安装目录放在usr/local/redis-3.0.7 下,执行make貌似没问题或者第一次make报gcc等缺失,二次make前执行,make distclean一下就不会报jemalloc/jemalloc.h没那个文件或者目录错误)
cd src && make all
make[1]: 进入目录“/opt/redis-3.0.7/src”
CC adlist.o
In file included from adlist.c:34:0:
zmalloc.h:50:31: 致命错误:jemalloc/jemalloc.h:没有那个文件或目录
include <jemalloc/jemalloc.h>
^
编译中断。
make[1]: *** [adlist.o] 错误 1
make[1]: 离开目录“/opt/redis-3.0.7/src”
make: *** [all] 错误 2
解决办法是:
make MALLOC=libc
注意:Redis并没有自己实现内存池,没有在标准的系统内存分配器上再加上自己的东西。
redis-2.4以上自带jemalloc,你不需要加任何参数,通过zmalloc.c源码中我们可以看到,Redis在编译时,会先判断是否使用tcmalloc,如果是,会用tcmalloc对应的函数替换掉标准的libc中的函数实现。其次会判断jemalloc是否使得,最后如果都没有使用才会用标准的libc中的内存管理函数。所以用tcmalloc优化请谨慎使用,这两着分配器碎片率相差不大,建议用自带jemalloc。
如果要安装tcmalloc可以这样:
make USE_TCMALLOC=yes
参考:利用TCMalloc替换Nginx和Redis默认glibc库的malloc内存分配(http://blog.csdn.net/unix21/article/details/12119059)
make命令执行完成后,会在src目录下生成5个可执行文件,分别是redis-server、redis-cli、redis-benchmark、redis-check-aof、redis-check-dump,它们的作用如下:
redis-server:Redis服务器的daemon启动程序
redis-cli:Redis命令行操作工具。当然,你也可以用telnet根据其纯文本协议来操作
redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能
redis-check-aof:更新日志检查
redis-check-dump:用于本地数据库检查
为什么没用标准的Linux安装三板斧呢?官方维基是这样说的:Redis can run just fine without a configuration file (when executed without a config file a standard configuration is used). With thedefault configuration Redis will log to the standard output so you can check what happens. Later, you canchange the default settings.
也可以make install,这样就是把可运行文件复制到/usr/local/bin里而已。
make之后,会出现一句提示:
Hint: To run 'make test' is a good idea 😉
不要运行make test ,会很麻烦,真实测试redis是否有效运行工作,将redis安装完毕后,做几个应用就可以试验下是否成功安装。
运行Redis
3.0.7版本,redis-server被放到了src文件夹下。
启动Redis服务端
/usr/redis-3.0.7/bin/redis-server
如果没有更改daemonize no配置,会看见运行的信息。