一.Redis介绍
1.redis是什么?
remote dIctionary server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。Redis提供了一些丰富的数据结构,包括 lists, sets, ordered sets 以及 hashes ,当然还有和Memcached一样的 strings结构.Redis当还包括了对这些数据结构的丰富操作。
Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。
2.redis特点
Redis 与其他 key - value 缓存产品有以下三个特点:
Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
Redis支持数据的备份,即master-slave模式的数据备份。
二.安装Redis
1.安装依赖包
yum -y install gcc-c++
yum -y install tcl
yum –y install wget
2.下载redis源码包
wget http://download.redis.io/releases/redis-2.8.24.tar.gz
3.编译安装redis
mv redis-2.8.24.tar.gz /usr/src/
cd /usr/src/
tar xf redis-2.8.24.tar.gz
cd redis-2.8.24
make && make install
echo $? #查看编译安装是否出错
4.查看版本号
redis-server --version
5.设置配置文件路径
mkdir -p /usr/local/redis
cp redis.conf /usr/local/redis/
6.修改后台运行
vim /usr/local/redis/redis.conf
将daemonize no 修改为 daemonize yes。作用是使redis后台运行,否则启动redis服务端时会报报警告,导致redis客服端连接不上
7.启动与关闭redis
/usr/local/bin/redis-server /usr/local/redis/redis.conf 启动
killall -9 redis-server 关闭
netstat -anpt | grep 6379
8.暂时修改redis密码为 redis@ranye
修改redis.conf配置文件,改参数:requirepass + 密码
9.修改redis端口号
cp /usr/local/redis/redis.conf /usr/local/redis/redis9532.conf
mkdir -p /var/log/redis/
mkdir -p /var/run/redis
vim /usr/local/redis/redis9532.conf
修改:
pidfile /var/run/redis/redis9532-server.pid
port 9532
~
logfile /var/log/redis/redis9532-server.log
~
dbfilename dump9532.rdb
killall -9 redis-server #关掉之前启动的redis
/usr/local/bin/redis-server /usr/local/redis/redis9532.conf #重新启动
netstat -anpt | grep redis #检查端口号是否更改
redis-cli -p 9532 #登录客户端测试
10.持久化配置(基于快照)
redis是内存数据库,它把数据存储在内存中,这样在加快读取速度的同时也对数据安全性产生了新的问题,即当redis所在服务器发生宕机后,redis数据库里的所有数据将会全部丢失。
为了解决这个问题,redis提供了持久化功能——RDB和AOF。通俗的讲就是将内存中的数据写入硬盘中。
[root@server6 ~]# mkdir -p /data/redis9532-rdb #创建持久化数据文件存放的路径
[root@server6 ~]# vim /usr/local/redis/redis9532.conf
save 900 1
save 300 10
save 60 10000
dbfilename "dump9532.rdb" #持久化文件名称
dir "/data/redis9532-rdb" #持久化数据文件存放的路径
#重启redis生效
[root@server6 ~]# killall redis-server
[root@server6 ~]# /usr/local/bin/redis-server /usr/local/redis/redis9532.conf
三.配置Redis主从
1.安装redis2
安装步骤同上
2.修改 redis 的redis.conf 文件
slaveof ip + 端口号 //去掉此行注释,并改为redis1的ip地址和端口号
3.配置redis2密码为 Redis@ranye.slave
修改redis.conf配置文件,改参数:requirepass + 密码
4.启动redis2
/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf
5.测试redis1与redis2数据是否能够同步
在redis1写入数据
set name chenjaixin
get name
然后在redis2上查看
get name #如显示chenjaixin 则表示同步成功
注意:在配置redis复制功能的时候如果主数据库设置了密码,需要在从数据的配置文件中通过masterauth参数设置主数据库的密码,这样从数据库在连接主数据库时就会自动使用auth命令认证了。相当于做了一个免密码登录。
(如果redis有密码,必须设置masterauth参数,否则数据是同步不过来的)