Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。有字符串,链表,集 合和有序集合。支持在服务器端计算集合的并,交和补集(difference)等,还支持多种排序功能。所以Redis也可以被看成是一个数据结构服务器。

一、下载稳定版()
Redis 使用标准的 major.minor.patchlevel版本做法。 stable表示稳定版本,一般用偶数版本,如:1.2, 2.0, 2.2, 2.4, 2.6,2.8。 奇数标识不稳定版本,如:2.9.x,他未来的稳定版本是3.0。
wget http://download.redis.io/releases/redis-2.8.19.tar.gz
二、解压缩编译
tar zxvf redis-2.8.19.tar.gz
cd redis-2.8.19
make
mv redis-2.8.19 redis
mkdir /usr/local/redis/var/
mkdir /usr/local/redis/etc
cp /usr/local/redis/redis.conf /usr/local/redis/etc
make命令执行完成后,会在当前目录下生成本个可执行文件,分别是redis-server、redis-cli、redis-benchmark、redis-stat,它们的作用如下:

redis-server:Redis服务器的daemon启动程序
redis-cli:Redis命令行操作工具。当然,你也可以用telnet根据其纯文本协议来操作
redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能
redis-stat:Redis状态检测工具,可以检测Redis当前状态参数及延迟状况

五、修改配置文件

/etc/sysctl.conf
添加

vm.overcommit_memory=1
刷新配置使之生效

sysctl vm.overcommit_memory=1
补充介绍:

**如果内存情况比较紧张的话,需要设定内核参数:
echo 1 > /proc/sys/vm/overcommit_memory

内核参数说明如下:

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

**编辑redis.conf配置文件(/etc/redis.conf),按需求做出适当调整,比如:
daemonize yes #转为守护进程,否则启动时会每隔5秒输出一行监控信息
save 60 1000 #减小改变次数,其实这个可以根据情况进行指定
maxmemory 256000000 #分配256M内存

在我们成功安装Redis后,我们直接执行redis-server即可运行Redis,此时它是按照默认配置来运行的(默认配置甚至不是后台运 行)。我们希望Redis按我们的要求运行,则我们需要修改配置文件,Redis的配置文件就是我们上面第二个cp操作的redis.conf文件,目前 它被我们拷贝到了/usr/local/redis/etc/目录下。修改它就可以配置我们的server了。如何修改?下面是redis.conf的主 要配置参数的意义:
daemonize:是否以后台daemon方式运行
pidfile:pid文件位置
port:监听的端口号
timeout:请求超时时间
loglevel:log信息级别
logfile:log文件位置
databases:开启数据库的数量
save * *:保存快照的频率,第一个*表示多长时间,第三个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件。
rdbcompression:是否使用压缩
dbfilename:数据快照文件名(只是文件名,不包括目录)
dir:数据快照的保存目录(这个是目录)
appendonly:是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。
appendfsync:appendonlylog如何同步到磁盘(三个选项,分别是每次写都强制调用fsync、每秒启用一次fsync、不调用fsync等待系统自己同步)

下面是一个略做修改后的配置文件内容:
vi /usr/local/redis/etc/redis.conf



daemonize yes
requirepass 123456
pidfile /usr/local/redis/var/redis.pid
port 6379
timeout 300
loglevel debug
logfile /usr/local/redis/var/redis.log
stop-writes-on-bgsave-error no
databases 16
save 900 1
save 300 10
save 60 10000
rdbcompression yes
dbfilename dump.rdb
dir /usr/local/redis/var/
appendonly no
appendfsync always



  

创建/usr/local/redis/redisd 启动文件,输入以下内容
vi /usr/local/redis/redisd



#!/bin/sh

function_start_redis()
{
printf "Starting ReDis...\n"
/usr/local/redis/redis/src/redis-server /usr/local/redis/etc/redis.conf
}

function_stop_redis()
{
printf "Stoping ReDis...\n"
/usr/local/redis/redis/src/redis-cli shutdown
}

function_restart_redis()
{
printf "Restarting ReDis...\n"
function_stop_redis
sleep 5
function_start_redis
}

if [ "$1" = "start" ]; then
function_start_redis
elif [ "$1" = "stop" ]; then
function_stop_redis
elif [ "$1" = "restart" ]; then
function_restart_redis
else
printf "Usage: /usr/local/redis/redisd {start|stop|restart}\n"
fi



 

chmod +x /usr/local/redis/redisd
然后在命令行执行:

/usr/local/redis/redisd start

查看是否成功启动
/usr/local/redis/src/redis-cli ping
出现下面提示,说明redis安装运行成功
PONG

启动命令行客户端赋值取值
/usr/local/redis/redis/src/redis-cli set mykey somevalue
/usr/local/redis/redis/src/redis-cli get mykey

关闭服务

/usr/local/redis/redisd stop

Redis主从配置
REDIS主从配置相当简单,一些文章啰里罗嗦的写了一大篇,其实就两句话:
打开从机的redis.conf
Port 6381 (注:不能跟主机的一样)
Sleverof 10.0.0.149 6383 (注:ip为主机IP,6383为主机REDIS端口号)
先重启主机,再重启从机
运行./redis-server redis.conf
若出现:的样子,说明配置成功

 

客户端也可以使用telnet形式连接。

[root@dbcache conf]# telnet 127.0.0.1 6379
Trying 127.0.0.1...
Connected to dbcache (127.0.0.1).
Escape character is '^]'.
set foo 3
bar
+OK
get foo
$3
bar
^]
telnet> quit
Connection closed.

 

PHP访问带密码的Redis

1. 设置Redis密码,以提供远程登陆
打开redis.conf配置文件,找到requirepass,然后修改如下:

requirepass yourpassword
yourpassword就是redis验证密码,设置密码以后发现可以登陆,但是无法执行命令了。
命令如下:

redis-cli -h 127.0.0.1 -p 6379//启动redis客户端,并连接服务器
keys * //输出服务器中的所有key
报错如下

(error) ERR operation not permitted

这时候你可以用授权命令进行授权,就不报错了
命令如下:

auth youpassword

2. PHP访问Redis

复制代码

$redis = new Redis();
$conn = $redis->connect('localhost', 6379);
$auth = $redis->auth('123456'); //设置密码
var_dump($auth);
$redis->set('access_token', "123213213213213213");
$redis->set('expired_time', 1464344863);var_dump($redis->get("access_token"));
var_dump($redis->get("expired_time"));