本实验的目的是搭建redis服务器,测试,并配置主从服务
一、前期准备工作
1、准备两台服务器,我这里是192.168.4.123和192.168.4.124两台服务器;
2、安装依赖包:gcc,yum -y install gcc,版本redis-4.0.6
3、make && make install 编译和编译安装,软件版本是
cd redis-4.0.6/
make MALLOC=libc //解决zmalloc.h:50:31: 致命错误
make install PREFIX=/usr/local/redis //指定安装路径
将配置文件移动到redis目录: mv redis.conf /usr/local/redis/etc/
4、启动服务:/usr/local/redis/bin/redis-server
二、配置文件修改和测试
1、如何让redis在后台运行,修改配置文件
vim /usr/local/redis/etc/redis.conf
把136:daemonize no 把no改成yes
2、让redis开机自启,
A、cp /usr/local/redis/etc/redis.conf /etc/redis/6379.conf //拷贝配置文件
B、cp /root/redis-4.0.6/utils/redis_init_script /etc/init.d/redis //拷贝启动脚本
C、vim /etc/init.d/redis 编辑启动脚本,添加如下两行
# chkconfig: 2345 10 90
# description: Start and Stop redis
D、修改启动脚本,填写真实的安装路径
EXEC=/usr/local/redis/bin/redis-server
CLIEXEC=/usr/local/redis/bin/redis-cli
E、设为开机启动:chkconfig redis on
3、启动、停止redis服务:
service redis start
service redis stop
4、客户端连接:/usr/local/redis/bin/redis-cli
/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf
5、/var/lib/redis/6379/ //硬盘上放置数据库文件的目录
三、redis数据库的基本的数据类型
1、字符类型:key=value
127.0.0.1:6379> set name haha
OK
127.0.0.1:6379> get name
"haha"
2、Hash(哈希) hset(单次写入),hmset(多次写入)
127.0.0.1:6379> hmset myhash file1 "hello" file2 "world"
OK
127.0.0.1:6379> hget myhash file1
"hello"
3、List(列表):先进后出的数据
127.0.0.1:6379> lpush list redis
(integer) 1
127.0.0.1:6379> lpush list mongodb
(integer) 2
127.0.0.1:6379> lpush list memcached
(integer) 3
127.0.0.1:6379> lrange list 0 1 //取出第1-2个变量的值
1) "memcached"
2) "mongodb"
4、ttl list //查看变量的生存时间,默认不限时间
expire list 20 //设置变量生存时间
四、设置redis主从数据库
1、4.123做数主据库:编辑配置文件 vim /etc/redis/6379.conf
requirepass 123456 //设置密码为123456
2、重启服务,可以连接进去,但是操作不了,正确的连接方式:
redis-cli -a 123456
3、因为添加了密码,直接停掉服务不行,可以在启动脚本
vim /etc/init.d/redis_6379
$CLIEXEC -a 123456 -p $REDISPORT shutdown
4、在4.124上设置配置文件:/etc/redis/6379.conf
slaveof 192.168.2.100 6379 //添加主服务器的ip地址和端口
masterauth 123456 //添加主服务器的密码
5、 info replication //查看主从信息
如果主从不能同步,请修改主服务器的配置文件,把
bind 127.0.0.1 注释掉或者修改为 bind 0.0.0.0
6、验证:在4.124上登陆进去后 keys * //查看是否有变量在里面