centos下安装redis

1、安装编译工具
yum install wget  make gcc gcc-c++ zlib-devel openssl openssl-devel pcre-devel kernel keyutils  patch perl


2、安装tcl组件包(安装Redis需要tcl支持)
我是直接yum install tcl安装的,当然也可以单独下载安装


3、安装Redis
下载:http://download.redis.io/redis-stable.tar.gz
上传redis-stable到/home目录


cd /home
tar -zxvf redis-stable.tar.gz #解压
mv redis-stable  /usr/local/redis #移动文件到安装目录
cd /usr/local/redis  #进入安装目录
make && make install #安装


cd  /usr/local/bin #查看是否有下面文件,如果没有,拷贝下面文件到/usr/local/bin目录(我的查看了确定是有的,所以就不需要拷贝文件啦)
cd /usr/local/redis


mkdir -p /usr/local/bin


cp -p redis-server /usr/local/bin


cp -p redis-benchmark /usr/local/bin


cp -p redis-cli /usr/local/bin


cp -p redis-check-dump /usr/local/bin


cp -p redis-check-aof /usr/local/bin


----------------------------------------如果有这些文件,忽略即可


ln -s  /usr/local/redis/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 #使设置立即生效


4、设置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


5、设置redis配置文件参数


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


vi /etc/redis.conf  #编辑


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


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


port 6379  #默认端口


bind 192.168.2.156 (注意:这里有一个问题,原文章中使用127.0.0.1,测试一直有问题,因为你如果在本地使用命令或者telnet是没有问题的,但是在php中使用就不行啦)


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


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


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


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


databases 16  #开启数据库的数量


save 900 1


save 300 10


save 60 10000


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


900秒内,执行1次写操作


300秒内,执行10次写操作


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一些基本配置


#是否作为守护进程运行
daemonize yes
#如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pid
pidfile redis.pid
#绑定主机IP,默认值为127.0.0.1
#bind 127.0.0.1
#Redis默认监听端口
port 6379
#客户端闲置多少秒后,断开连接,默认为300(秒)
timeout 300
#日志记录等级,有4个可选值,debug,verbose(默认值),notice,warning
loglevel verbose
#指定日志输出的文件名,默认值为stdout,也可设为/dev/null屏蔽日志
logfile stdout
#可用数据库数,默认值为16,默认数据库为0
databases 16
#保存数据到disk的策略
#当有一条Keys数据被改变是,900秒刷新到disk一次
save 900 1
#当有10条Keys数据被改变时,300秒刷新到disk一次
save 300 10
#当有1w条keys数据被改变时,60秒刷新到disk一次
save 60 10000
#当dump .rdb数据库的时候是否压缩数据对象
rdbcompression yes
#本地数据库文件名,默认值为dump.rdb
dbfilename dump.rdb
#本地数据库存放路径,默认值为 ./
dir /usr/local/redis/var/


/proc/sys/vm/overcommit_memory
该文件指定了内核针对内存分配的策略,其值可以是0、1、2。
0,表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1,表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2,表示内核允许分配超过所有物理内存和交换空间总和的内存


6、测试redis数据库


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


set mykey this is a test  #写数据


get mykey  #读取数据


exit #退出redis数据库控制台


7、安装php redis扩展
下载地址 https://codeload.github.com/nicolasff/phpredis/zip/maste (找了半天,还是这个地址可以下载,好多都已经不能下载啦)
cd /home/php-redis
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make && make install
下载完成后 在php.ini中添加:extension=redis.so加载redis模块
如果没有指定extension目录,则设置:
extension_dir =  "/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/" (这个是我的so目录,根据个人php扩展目录位置修改)
例如:
extension_dir =  "/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/"
extension=sphinx.so
extension=redis.so


在测试站点php的文件中打印 phpinfo();
可以看到我们刚刚安装的php-redis扩展


8、通过php程序连接redis数据库


ini_set('default_socket_timeout', -1);
$redis = new Redis();
$redis->connect("192.168.2.156","6379");  //php客户端设置的ip及端口
$redis->auth('123456');
//$redis->select(1);
//存储一个 值
$redis->set("say","Hello World");
//$redis->del("say");//删除key或者 delete
//$redis->flushdb();//清除所有缓存
$data = $redis->get("say");     //应输出Hello World
var_dump($data);


注意如果出现以下错误:
Fatal error: Uncaught exception 'RedisException' with message 'Redis server went away' in /usr/local/nginx/html/index.php:56 Stack trace: #0 /usr/local/nginx/html/index.php(56): Redis->set('say', 'Hello World') #1 {main} thrown in /usr/local/nginx/html/index.php on line 56


首先我的问题是 redis.conf中 bind 设置了127.0.0.1,改为实际的IP地址即可
查看防火墙是否允许6397端口,或者关闭防火墙
查看redis服务时候启用 netstat -tunlp | grep redis
修改selinux设置 vi /etc/selinux/config 将SELINUX=permissive | disabled
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值