redis-3.0.6源码包编译安装

redis源码包编译安装

1.简介

  redis是一个开源的key-value数据库。它又经常被认为是一个数据结构服务器。因为它的value不仅包括基本的string类型还有 list,set ,sorted sethash类型。当然这些类型的元素也都是string类型。也就是说list,set这些集合类型也只能包含
string 类型。你可以在这些类型上做很多原子性的操作。比如对一个字符value追加字符串(APPEND命令)。加加或者减减一个数字字符串(INCR命令,当 然是按整数处理的).可以对list类型进行push,或者pop元素操作(可以模拟栈和队列)。对于set类型可以进行一些集合相关操作 (intersection union difference)memcache也有类似与++,--的命令。
不过memcache的 value只包括string类型。远没有redisvalue类型丰富。和memcahe一样为了性能。redis的数据通常都是放到内存中的。当然 redis可以每间隔一定时间将内存中数据写入到磁盘以防止数据丢失。redis也支持主从复制机制(master-slave replication)。redis的其他特性包括简单的事务支持和 发布订阅(pub/sub)通道功能,而且redis配置管理非常简单。还有各种语言版本的开源客户端类库。


2.安装

安装步骤:

1、安装编译工具

  yum install wget  make gcc gcc-c++ zlib-devel openssl openssl-devel pcre-devel kernel keyutils  patch perl


2、redis下载

  下载地址:http://redis.io/download


3、解压源码包

 tar -zxvf redis-3.0.6.tar.gz


4、开始编译安装redis

 cd redis-3.0.6

 make && make install

 cd /usr/local/bin #查看是否有下面文件(redis-server、redis-benchmark、redis-cli、redis-check-dump、redis-check-aof),如果没有,拷贝下面文件到/usr/local/bin目录

 ln -s /root/redis-3.0.6/redis.conf /etc/redis.conf  #添加配置文件软连接

 vi /etc/redis.conf  #编辑 

 daemonize yes  #设置后台启动redis

 :wq! #保存退出

 redis-server /etc/redis.conf #启动redis服务

 redis-cli shutdown #关闭redis

 vi /etc/sysctl.conf #编辑,在最后一行添加下面代码

 vm.overcommit_memory = 1

 :wq! #保存退出

 sysctl -p #使编辑的配置文件设置立即生效

 

5、设置redis开机启动

 vi /etc/init.d/redis #编辑,添加以下代码

#!/bin/sh
# chkconfig:   2345 90 10
# description:  Redis is a persistent key-value database
# redis    Startup script for redis processes
# processname: redis
redis_path="/usr/local/bin/redis-server"
redis_conf="/etc/redis.conf"
redis_pid="/var/run/redis.pid"
# Source function library.
. /etc/rc.d/init.d/functions
[ -x $redis_path ] || exit 0
RETVAL=0
prog="redis"
# Start daemons.
start() {
if [ -e $redis_pid -a ! -z $redis_pid ];then
echo $prog" already running...."
exit 1
fi
echo -n $"Starting $prog "
# Single instance for all caches
$redis_path $redis_conf
RETVAL=$?
[ $RETVAL -eq 0 ] && {
touch /var/lock/subsys/$prog
success $"$prog"
}
echo
return $RETVAL
}
# Stop daemons.
stop() {
echo -n $"Stopping $prog "
killproc -d 10 $redis_path
echo
[ $RETVAL = 0 ] && rm -f $redis_pid /var/lock/subsys/$prog
RETVAL=$?
return $RETVAL
}
# See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status $prog
RETVAL=$?
;;
restart)
stop
start
;;
condrestart)
if test "x`pidof redis`" != x; then
stop
start
fi
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart}"
exit 1
esac
exit $RETVAL

 :wq! #强制保存退出

 chmod 755 /etc/init.d/redis #添加脚本执行权限

 chkconfig --add redis #添加开启启动

 chkconfig --level 2345 redis on #设置启动级别

 chkconfig --list redis #查看启动级别

 service redis restart #重新启动redis


6、设置redis配置文件参数

 mkdir -p /usr/local/redis/var #创建redis数据库存放目录

 vi /etc/redis.conf #编辑redis配置文件

 daemonize yes #以后台daemon方式运行redis

 pidfile "/var/run/redis.pid" #redis以后台运行,默认pid文件路径/var/run/redis.pid

 port 6379 #redis默认端口

 bind 127.0.0.1 #默认绑定本机所有ip地址,为了安全,可以只监听内网ip

 timeout 300 #客户端超时设置,单位为秒

 loglevel verbose #设置日志级别,支持四个级别:debug、notice、verbose、warning

 logfile stdout #日志记录方式,默认为标准输出,logs不写文件,输出到空设备/deb/null

 logfile "/usr/local/redis/var/redis.log" #可以指定日志文件路径

 databases 16 #开启数据库的数量

 

 创建本地数据库快照,格式:save * *

 save 900 1 #900秒内,执行1次写操作

 save 300 10 #300秒内,执行10次写操作

 save 60 10000 #60秒内,执行10000次写操作


 rdbcompression yes #启用数据库lzf压缩,也可以设置为no

 dbfilename dump.rdb #本地快照数据库名称

 dir "/usr/local/redis/var/" #本地快照数据库存放目录

 requirepass 123456 #设置redis数据库连接密码

 maxclients 10000 #同一时间最大客户端连接数,0为无限制

 maxmemory 1024MB #设定redis最大使用内存,值要小于物理内存,必须设置

 appendonly yes #开启日志记录,相当于MySQL的binlog

 appendfilename "appendonly.aof" #日志文件名,注意:不是目录路径

 appendfsync everysec #每秒执行同步,还有两个参数always、no一般设置为everysec,相当于MySQL事物日志的写                 方式

 :wq! #保存退出

 service redis restart #重启redis


6、测试redis数据库

 redis-cli -a 123456 #连接redis数据库,注意:-a后面跟redis数据库密码

 set name www.baidu.com #写数据

 get name #读取数据

 exit #退出redis数据库控制台

 redis-benchmark -h 127.0.0.1 -p 6379 -c 1000 -n 100000  #1000个并发连接,100000个请求,测试127.0.0.1端口为6379的redis服务器性能




你可能感兴趣的:(redis-3.0.6源码包编译安装)