CentOS下安装redis
1. redis简介
redis是一个开源的使用ANSIC语言编写、支持网络、可基于内存亦可持久化的日志型、高性能的Key-Value数据库,并提供多种语言的API。
2. 安装步骤
1.需要安装gcc。
yum install gcc-c++
2.下载redis的源码包,下载地址:http://download.redis.io/releases/redis-3.0.0.tar.gz
3.把源码包上传到Linux服务器。
4.解压源码包
tar -zxvf redis-3.0.0.tar.gz
5.进入redis目录使用make命令
cd redis-3.0.0/
make
6.使用make install指定目录安装redis
# 指定安装目录为/usr/local/redis
make install PREFIX=/usr/local/redis
3. 启动redis服务器
1.前端启动模式
# 默认是前端启动模式,端口为6379
/usr/local/redis/bin/redis-server
2.后端启动
1) 从redis的源码目录中复制redis.conf到redis的安装目录。
cp redis.conf /usr/local/redis/bin/
将daemonize no 改为 daemonize yes
3) 根据配置文件后端启动
./redis-server redis.conf
4. redis常用命令
启动redis客户端
[root@VM_161_110_centos bin]# ./redis-cli
127.0.0.1:6379> ping
PONG
127.0.0.1:6379> set a 1
OK
127.0.0.1:6379> get a
"1"
127.0.0.1:6379> keys *
1) "a"
127.0.0.1:6379> incr a
(integer) 2
127.0.0.1:6379> decr a
(integer) 1
127.0.0.1:6379> del a
(integer) 1
127.0.0.1:6379> keys *
(empty list or set)
5. redis常用数据类型
- String(主要)
- Hash(主要)
- List
- Set
- SortedSet
6. redis集群的搭建
6.1. redis-cluster 架构图
- redis-cluster把所有的物理节点映射到[0-16383]slot(哈希槽)上,cluster 负责维护node(节点)<->slot(槽)<->value(值)。
- redis 集群中内置了 16384 (2^14 14位)个哈希槽,当需要在 Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。
6.2. redis-cluster投票:容错
- 领着投票过程是集群中所有master(主节点)参与,如果半数以上master节点与该master节点通信超过集群节点超时的时间(
cluster-node-timeout
),则认为当前master节点挂掉。 - 什么时候整个集群不可用(
cluster_state:fail
)?
6.3. 集群的节点规划
3个节点的集群,每个节点有一主一备,理论上需要6台服务器(没有辣么多钱)。所以搭建一个伪分布式的集群,使用6个redis实例来模拟。
6.4. 搭建ruby环境
- 搭建集群需要使用到官方提供的ruby脚本,需要安装ruby的环境。
yum install ruby
yum install rubygems # 安装ruby包管理器
- 安装ruby所需要gem包
gem包下载地址:http://download.csdn.net/detail/xuda27/9668339
gem install redis-3.0.0.gem
6.5. 集群的搭建
第一步:创建6个redis实例,端口号从7001~7006
1. 在/usr/local/
创建redis-cluster
目录并从/usr/local/redis
的redis文件夹复制到redis-cluster文件夹下并将文件夹重名为redis01,以此类推创建redis02、redis03、……redis06。
2. 把创建集群的ruby脚本复制到redis-cluster
目录下,即 将redis源码包(src目录)下的redis-trib.rb
复制到redis-cluster
目录下。
#1.将redis目录下所有文件复制到redis-cluster目录下并将文件夹重名为redis01
cp -r redis /usr/local/redis-cluster/redis01
#2.将redis-trib.rb复制到redis-cluster目录下
cp redis-trib.rb /usr/local/redis-cluster
第二步:修改6个redis实例下的bin目录下的redis.conf配置文件
1、修改端口号
这里是修改了redis01的端口,剩余5个redis实例的端口分别为7002至7006。
2、打开cluster-enable前面的注释。
告诉redis要使用集群。
第三步:启动6个redis实例。
在redis-cluster
目录下创建startup.sh
用于启动6个redis实例,并给startup.sh
赋予执行权限。
#创建startup.sh
[root@VM_161_110_centos redis-cluster]# vim startup.sh
cd redis01/bin
./redis-server redis.conf
cd ..
cd ..
cd redis02/bin
./redis-server redis.conf
cd ..
cd ..
cd redis03/bin
./redis-server redis.conf
cd ..
cd ..
cd redis04/bin
./redis-server redis.conf
cd ..
cd ..
cd redis05/bin
./redis-server redis.conf
cd ..
cd ..
cd redis06/bin
./redis-server redis.conf
cd ..
cd ..
# 创建shutdown.sh 用于关闭集群
[root@VM_161_110_centos redis-cluster]# vim shutdown.sh
redis01/bin/redis-cli -p 7001 shutdown
redis01/bin/redis-cli -p 7002 shutdown
redis01/bin/redis-cli -p 7003 shutdown
redis01/bin/redis-cli -p 7004 shutdown
redis01/bin/redis-cli -p 7005 shutdown
redis01/bin/redis-cli -p 7006 shutdown
# 赋予执行权限
chmod +x startup.sh
chmod +x shutdown.sh
# 启动6个redis实例
./startup.sh
# 关闭6个redis实例
./shutdown.sh
# 查看redis进程运行:
ps aux|grep redis
redis-cluster
创建好的目录结构:
第五步:创建集群。
需要知道Linux服务器的ip地址,可以用ifconfig
命令查看。
./redis-trib.rb create --replicas 1 10.104.161.110:7001 10.104.161.110:7002 10.104.161.110:7003 10.104.161.110:7004 10.104.161.110:7005 10.104.161.110:7006
集群创建的信息:
# 主节点有槽,从节点没有槽
>>> Performing hash slots allocation on 6 nodes...
Using 3 masters:
10.104.161.110:7001
10.104.161.110:7002
10.104.161.110:7003
Adding replica 10.104.161.110:7004 to 10.104.161.110:7001
Adding replica 10.104.161.110:7005 to 10.104.161.110:7002
Adding replica 10.104.161.110:7006 to 10.104.161.110:7003
M: 131a1d2c7a02cd38e9f61138975863fc8c20d0ea 10.104.161.110:7001
slots:0-5460 (5461 slots) master
M: e2a9a28c3842d37aa602182110f93598c2936da5 10.104.161.110:7002
slots:5461-10922 (5462 slots) master
M: 5e0096b41ae8ae5b06539a311c5741d01163497e 10.104.161.110:7003
slots:10923-16383 (5461 slots) master
S: 0920f150bbd8553414492bb51c1ea03055484ee6 10.104.161.110:7004
replicates 131a1d2c7a02cd38e9f61138975863fc8c20d0ea
S: e2439d0425c7abbf437b76b50ebe1db6066f51ef 10.104.161.110:7005
replicates e2a9a28c3842d37aa602182110f93598c2936da5
S: 1127ebb56980ebb23c45d3c5a4c79c92840470df 10.104.161.110:7006
replicates 5e0096b41ae8ae5b06539a311c5741d01163497e
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join.....
>>> Performing Cluster Check (using node 10.104.161.110:7001)
M: 131a1d2c7a02cd38e9f61138975863fc8c20d0ea 10.104.161.110:7001
slots:0-5460 (5461 slots) master
M: e2a9a28c3842d37aa602182110f93598c2936da5 10.104.161.110:7002
slots:5461-10922 (5462 slots) master
M: 5e0096b41ae8ae5b06539a311c5741d01163497e 10.104.161.110:7003
slots:10923-16383 (5461 slots) master
M: 0920f150bbd8553414492bb51c1ea03055484ee6 10.104.161.110:7004
slots: (0 slots) master
replicates 131a1d2c7a02cd38e9f61138975863fc8c20d0ea
M: e2439d0425c7abbf437b76b50ebe1db6066f51ef 10.104.161.110:7005
slots: (0 slots) master
replicates e2a9a28c3842d37aa602182110f93598c2936da5
M: 1127ebb56980ebb23c45d3c5a4c79c92840470df 10.104.161.110:7006
slots: (0 slots) master
replicates 5e0096b41ae8ae5b06539a311c5741d01163497e
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
6.6. 测试集群
在redis01至redis06下的bin下有redis-cli,任选其一使用,如:
# -h 表示主机ip地址 -p 表示端口(7001-7006) -c 表示集群(cluster)
redis01/bin/redis-cli -h 10.104.161.110 -p 7002 -c
测试瞎玩:
[root@VM_161_110_centos redis-cluster]# redis01/bin/redis-cli -h 10.104.161.110 -p 7001 -c
10.104.161.110:7001> set b 99
OK
10.104.161.110:7001> get b
"99"
10.104.161.110:7001> get a
-> Redirected to slot [15495] located at 10.104.161.110:7003
"100"
10.104.161.110:7003> ping
PONG
注意:如果你在远程服务器下搭建redis记得开启7001至7006端口和6379端口,则以后好使用redis。
# 打开7001端口
iptables -A INPUT -ptcp --dport 7001 -j ACCEPT