服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Redis - 在redhat6.4安装redis集群【教程】

在redhat6.4安装redis集群【教程】

2019-10-29 19:34wulei Redis

这篇文章主要介绍了在redhat6.4安装redis集群【教程】,需要的朋友可以参考下

  参考:

  http://redis.io/topics/cluster-tutorial(主要是Creating a Redis Cluster using the create-cluster script部分)

  https://ruby.taobao.org/

  安装一款不熟悉的软件前先看INSTALL,README,这是习惯,生产上要建立普通用户并调节适当参数,下面是以root身份安装运行.

  下载解压并安装redis

  make test提示需要更高版本的tcl,跳到安装过程可能遇到的问题

  

?
1
2
3
4
5
6
wget http://download.redis.io/releases/redis-3.0.7.tar.gz
tar xf redis-3.0.7.tar.gz
cd redis-3.0.7
mkdir -p /opt/redis
make test
make PREFIX=/opt/redis install

  复制两个脚本到安装的目录

 

?
1
2
3
4
5
cp ~/redis-3.0.7/src/redis-trib.rb /opt/redis/
 
 cp ~/redis-3.0.7/utils/create-cluster/create-cluster /opt/redis/1212

  根据实际修改/opt/redis/create-cluster.改动的地方有几处

  a.增加了三个变量BASEDIR,BINDIR和DATADIR,

  b.修改相关命令路径,

  c.start前,先进入DATADIR,start后,返回原目录

  d.clean前,先进入DATADIR,start后,返回原目录

  e.create的host由127.0.0.1改为192.168.1.194(不改有时会报Too many Cluster redirections)

  下面是修改后的shell

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
#!/bin/bash
 
 # Settings
 
 PORT=30000
 
 TIMEOUT=2000
 
 NODES=6
 
 REPLICAS=1
 
 BASEDIR=/opt/redis
 
 BINDIR=$BASEDIR/bin
 
 DATADIR=$BASEDIR/data
 
 
 # You may want to put the above config parameters into config.sh in order to
 
 # override the defaults without modifying this script.
 
 if [ -a config.sh ]
 
 then
 
 source "config.sh"
 
 fi
 
 # Computed vars
 
 ENDPORT=$((PORT+NODES))
 
 if [ "$1" == "start" ]
 
 then
 
 cd $DATADIR
 
 while [ $((PORT < ENDPORT)) != "0" ]; do
 
 PORT=$((PORT+1))
 
 echo "Starting $PORT"
 
 $BINDIR/redis-server --port $PORT --cluster-enabled yes --cluster-config-file nodes-${PORT}.conf --cluster-node-timeout $TIMEOUT --appendonly yes --appendfilename appendonly-${PORT}.aof --dbfilename dump-${PORT}.rdb --logfile ${PORT}.log --daemonize yes
 
 done
 
 cd -
 
 exit 0
 
 fi
 
 if [ "$1" == "create" ]
 
 then
 
 HOSTS=""
 
 while [ $((PORT < ENDPORT)) != "0" ]; do
 
 PORT=$((PORT+1))
 
 HOSTS="$HOSTS 192.168.1.194:$PORT"
 
 done
 
 $BASEDIR/redis-trib.rb create --replicas $REPLICAS $HOSTS
 
 exit 0
 
 fi
 
 if [ "$1" == "stop" ]
 
 then
 
 while [ $((PORT < ENDPORT)) != "0" ]; do
 
 PORT=$((PORT+1))
 
 echo "Stopping $PORT"
 
 $BINDIR/redis-cli -p $PORT shutdown nosave
 
 done
 
 exit 0
 
 fi
 
 if [ "$1" == "watch" ]
 
 then
 
 PORT=$((PORT+1))
 
 while [ 1 ]; do
 
 clear
 
 date
 
 $BINDIR/redis-cli -p $PORT cluster nodes | head -30
 
 sleep 1
 
 done
 
 exit 0
 
 fi
 
 if [ "$1" == "tail" ]
 
 then
 
 INSTANCE=$2
 
 PORT=$((PORT+INSTANCE))
 
 tail -f ${PORT}.log
 
 exit 0
 
 fi
 
 if [ "$1" == "call" ]
 
 then
 
 while [ $((PORT < ENDPORT)) != "0" ]; do
 
 PORT=$((PORT+1))
 
 $BINDIR/redis-cli -p $PORT $2 $3 $4 $5 $6 $7 $8 $9
 
 done
 
 exit 0
 
 fi
 
 if [ "$1" == "clean" ]
 
 then
 
 cd $DATADIR
 
 rm -rf *.log
 
 rm -rf appendonly*.aof
 
 rm -rf dump*.rdb
 
 rm -rf nodes*.conf
 
 cd -
 
 exit 0
 
 fi
 
 echo "Usage: $0 [start|create|stop|watch|tail|clean]"
 
 echo "start -- Launch Redis Cluster instances."
 
 echo "create -- Create a cluster using redis-trib create."
 
 echo "stop -- Stop Redis Cluster instances."
 
 echo "watch -- Show CLUSTER NODES output (first 30 lines) of first node."
 
 echo "tail -- Run tail -f of instance at base port + ID."
 
 echo "clean -- Remove all instances data, logs, configs."123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102

  不要忘了创建数据目录mkdir -p /opt/redis/data

  根据上面的参考,启动集群和停止集群

  启动集群:先敲入/opt/redis/create-cluster start回车,再敲入/opt/redis/create-cluster create回车,再输入yes回车

  停止集群:敲入/opt/redis/create-cluster stop回车

  如果以前启动过,造成不一致数据,create时就会报错,可先/opt/redis/create-cluster clean

  测试

 

?
1
2
3
4
5
<dependency>
 <groupId>redis.clients</groupId>
 <artifactId>jedis</artifactId>
 <version>2.8.1</version>
</dependency>

  声明JedisCluster Bean

 

?
1
2
3
4
5
6
7
8
@Bean
 public JedisCluster jedisCluster(){
  Set<HostAndPort> nodes=new HashSet<>(3);
  nodes.add(new HostAndPort("192.168.1.194",30001));
  nodes.add(new HostAndPort("192.168.1.194",30002));
  nodes.add(new HostAndPort("192.168.1.194",30003));
  return new JedisCluster(nodes,2000,5);
 }

 

  测试set和get

  

?
1
2
3
4
AnnotationConfigApplicationContext context= new AnnotationConfigApplicationContext(AppConfig.class);
 JedisCluster jedisCluster = (JedisCluster) context.getBean("jedisCluster");
 jedisCluster.set("xxx","123");
 System.out.println("jedisCluster.get = " + jedisCluster.get("xxx"));

  安装过程可能遇到的问题:

  make test时,提醒You need tcl 8.5 or newer in order to run the Redis test.到http://www.tcl.tk/software/tcltk/download.html下载Tcl,

 

?
1
2
3
4
5
6
7
wget http://prdownloads.sourceforge.net/tcl/tcl8.5.19-src.tar.gz
tar xf tcl8.5.19-src.tar.gz
cd tcl8.5.19/unix
./configure
make
make test
make install

 

  因为create-cluster create会调用redis-trib.rb,它是一个ruby脚本,所以提示没有安装ruby,就先安装yum install -y ruby

  如果提示加载rubygems错误,使用以下办法安装rubygems

  a.https://rubygems.org/pages/download下载tgz格式的安装包(wget可能不通,在windows用旋风或迅雷下载)

  b.mount -t cifs -o username=xiejx618,password=123456 //192.168.1.115/share /share

  

?
1
2
3
4
cp /share/rubygems-2.6.4.tgz ./
tar xf rubygems-2.6.4.tgz
cd rubygems-2.6.4
ruby setup.rb

  如果再提示no such file to load – rdoc/rdoc,就先安装yum install -y rdoc

  如果再提示 no such file to load – redis,就使用gem install redis -v 3.0.7

  gem又是因为墙原因无法使用默认源,就修改为淘宝源

  可能用到的几个命令

  帮助:gem sources --help

  查看源:gem sources -l

  删除源:gem sources -r https://rubygems.org/

  添加源:gem sources -a https://ruby.taobao.org/

  更新源缓存:gem sources -u

延伸 · 阅读

精彩推荐
  • Redisredis 交集、并集、差集的具体使用

    redis 交集、并集、差集的具体使用

    这篇文章主要介绍了redis 交集、并集、差集的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    xiaojin21cen10152021-07-27
  • Redisredis实现排行榜功能

    redis实现排行榜功能

    排行榜在很多地方都能使用到,redis的zset可以很方便地用来实现排行榜功能,本文就来简单的介绍一下如何使用,具有一定的参考价值,感兴趣的小伙伴们...

    乘月归5022021-08-05
  • Redisredis中如何使用lua脚本让你的灵活性提高5个逼格详解

    redis中如何使用lua脚本让你的灵活性提高5个逼格详解

    这篇文章主要给大家介绍了关于redis中如何使用lua脚本让你的灵活性提高5个逼格的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具...

    一线码农5812019-11-18
  • RedisRedis的配置、启动、操作和关闭方法

    Redis的配置、启动、操作和关闭方法

    今天小编就为大家分享一篇Redis的配置、启动、操作和关闭方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧 ...

    大道化简5312019-11-14
  • RedisRedis 事务知识点相关总结

    Redis 事务知识点相关总结

    这篇文章主要介绍了Redis 事务相关总结,帮助大家更好的理解和学习使用Redis,感兴趣的朋友可以了解下...

    AsiaYe8232021-07-28
  • Redis详解Redis复制原理

    详解Redis复制原理

    与大多数db一样,Redis也提供了复制机制,以满足故障恢复和负载均衡等需求。复制也是Redis高可用的基础,哨兵和集群都是建立在复制基础上实现高可用的...

    李留广10222021-08-09
  • RedisRedis全量复制与部分复制示例详解

    Redis全量复制与部分复制示例详解

    这篇文章主要给大家介绍了关于Redis全量复制与部分复制的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis爬虫具有一定的参考学习...

    豆子先生5052019-11-27
  • RedisRedis如何实现数据库读写分离详解

    Redis如何实现数据库读写分离详解

    Redis的主从架构,能帮助我们实现读多,写少的情况,下面这篇文章主要给大家介绍了关于Redis如何实现数据库读写分离的相关资料,文中通过示例代码介绍...

    罗兵漂流记6092019-11-11