单节点多实例
IP | 端口 |
---|---|
10.0.0.70 | 7000 |
10.0.0.70 | 7001 |
10.0.0.70 | 7002 |
10.0.0.70 | 7003 |
10.0.0.70 | 7004 |
10.0.0.70 | 7005 |
[root@redis-cluster01 ~]# yum install ruby rubygems -y
[root@redis-cluster01 ~]# gem sources --add https://gems.ruby-china.com/ --remove https://rubygems.org/
https://gems.ruby-china.com/ added to sources
https://rubygems.org/ removed from sources
[root@redis-cluster01 ~]# gem sources -l
*** CURRENT SOURCES ***
https://gems.ruby-china.com/
[root@redis-cluster01 ~]# gem install redis
Fetching: redis-4.1.0.gem (100%)
ERROR: Error installing redis:
redis requires Ruby version >= 2.2.2.
报错:提示版本过低
解决方法:手动下载
[root@redis-cluster01 ~]# curl -O -L https://cache.ruby-lang.org/pub/ruby/2.2/ruby-2.2.7.tar.gz
[root@redis-cluster01 ~]# tar zxf ruby-2.2.7.tar.gz
[root@redis-cluster01 ~]# cd ruby-2.2.7
[root@redis-cluster01 ruby-2.2.7]# ./configure --prefix=/usr/local/ruby-2.2.7
[root@redis-cluster01 ruby-2.2.7]# make && make install
[root@redis-cluster01 ruby-2.2.7]# cp /usr/local/ruby-2.2.7/bin/ruby /usr/bin/ruby
[root@redis-cluster01 ruby-2.2.7]# ruby --version
ruby 2.2.7p470 (2017-03-28 revision 58194) [x86_64-linux]
[root@redis-cluster01 ruby-2.2.7]# gem install redis
ERROR: Loading command: install (LoadError)
cannot load such file – zlib
ERROR: While executing gem … (NoMethodError)
undefined method `invoke_with_build_args’ for nil:NilClass
报错:缺少zlib依赖
解决:安装依赖
[root@redis-cluster01 zlib]# cd ext/zlib
[root@redis-cluster01 zlib]# ruby ./extconf.rb
checking for deflateReset() in -lz… yes
checking for zlib.h… yes
checking for crc32_combine() in zlib.h… yes
checking for adler32_combine() in zlib.h… yes
checking for z_crc_t in zlib.h… yes
creating Makefile
[root@redis-cluster01 zlib]# make
compiling zlib.c
linking shared-object zlib.so
[root@redis-cluster01 zlib]# make install
/usr/bin/install -c -m 0755 zlib.so /usr/local/ruby-2.2.7/lib/ruby/site_ruby/2.2.0/x86_64-linux
[root@redis-cluster01 zlib]# gem install redis
ERROR: While executing gem … (Gem::Exception)
Unable to require openssl, install OpenSSL and rebuild ruby (preferred) or use non-HTTPS sources
报错:缺少openssl依赖
解决:安装依赖
yum install openssl-devel
[root@redis-cluster01 zlib]# cd …/openssl/
[root@redis-cluster01 openssl]# ruby ./extconf.rb
#修改Makefile中的KaTeX parse error: Expected 'EOF', got '#' at position 50: …ster01 openssl]#̲ sed -i 's#(top_srcdir)/include/ruby.h#$(top_srcdir)…/…#g’ Makefile
[root@redis-cluster01 openssl]# make && make install
[root@redis-cluster01 openssl]# gem install redis
Fetching: redis-4.1.0.gem (100%)
Successfully installed redis-4.1.0
Parsing documentation for redis-4.1.0
Installing ri documentation for redis-4.1.0
Done installing documentation for redis after 1 seconds
1 gem installed
[root@redis-cluster01 ~]# mkdir /application/redis-cluster
[root@redis-cluster01 ~]# mkdir /application/redis-cluster/{7000,7001,7002,7003,7004,7005}
[root@redis-cluster01 ~]# for num inseq 7000 7005
;do cp /application/redis/{redis.conf,redis-cli,redis-server} /application/redis-cluster/${num}/;done
[root@redis-cluster01 ~]# cat redis-cluster.sh
#!/bin/bash
Redis_Dir=/application/redis-cluster/
Redis_Config=redis.conf
cd ${Redis_Dir}
for num inseq 7000 7005
do
sed -i “s/port 6379/port $num/g” n u m / {num}/ num/{Redis_Config}
sed -i “s#/var/run/redis_6379.pid#/var/run/redis_${num}.pid#g” n u m / {num}/ num/{Redis_Config}
sed -i “s/appendonly no/appendonly yes/g” n u m / {num}/ num/{Redis_Config}
echo “cluster-enabled yes” >> n u m / {num}/ num/{Redis_Config}
echo "cluster-config-file n u m n o d e s . c o n f " > > {num}_nodes.conf" >> numnodes.conf">>{num}/ R e d i s C o n f i g e c h o " c l u s t e r − n o d e − t i m e o u t 5000 " > > {Redis_Config} echo "cluster-node-timeout 5000" >> RedisConfigecho"cluster−node−timeout5000">>{num}/${Redis_Config}
done
[root@redis-cluster01 ~]# bash redis-cluster.sh
[root@redis-cluster01 ~]# cat rcluster_start.sh
#!/bin/bash
Redis_Dir=/application/redis-cluster/
Redis_Config=redis.conf
cd ${Redis_Dir}
for num inseq 7000 7005
do
${num}/redis-server ${num}/redis.conf
done
[root@redis-cluster01 ~]# bash rcluster_start.sh
31495:C 22 Apr 20:37:52.783 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
31495:C 22 Apr 20:37:52.784 # Redis version=4.0.9, bits=64, commit=00000000, modified=0, pid=31495, just started
31495:C 22 Apr 20:37:52.784 # Configura
…
.
.
[root@redis-cluster01 ~]# ss -lntup|grep 700*
tcp LISTEN 0 128 10.0.0.70:17000 : users:((“redis-server”,pid=31496,fd=9))
tcp LISTEN 0 128 10.0.0.70:17001 : users:((“redis-server”,pid=31498,fd=9))
tcp LISTEN 0 128 10.0.0.70:17002 : users:((“redis-server”,pid=31500,fd=9))
tcp LISTEN 0 128 10.0.0.70:17003 : users:((“redis-server”,pid=31508,fd=9))
tcp LISTEN 0 128 10.0.0.70:17004 : users:((“redis-server”,pid=31513,fd=9))
tcp LISTEN 0 128 10.0.0.70:17005 : users:((“redis-server”,pid=31518,fd=9))
tcp LISTEN 0 128 10.0.0.70:7000 : users:((“redis-server”,pid=31496,fd=6))
tcp LISTEN 0 128 10.0.0.70:7001 : users:((“redis-server”,pid=31498,fd=6))
tcp LISTEN 0 128 10.0.0.70:7002 : users:((“redis-server”,pid=31500,fd=6))
tcp LISTEN 0 128 10.0.0.70:7003 : users:((“redis-server”,pid=31508,fd=6))
tcp LISTEN 0 128 10.0.0.70:7004 : users:((“redis-server”,pid=31513,fd=6))
tcp LISTEN 0 128 10.0.0.70:7005 : users:((“redis-server”,pid=31518,fd=6))
[root@redis-cluster01 ~]# cp redis-4.0.9/src/redis-trib.rb /application/redis-cluster/
[root@redis-cluster01 ~]# ruby /application/redis-cluster/redis-trib.rb create --replicas 1 10.0.0.70:7000 10.0.0.70:7001 10.0.0.70:7002 10.0.0.70:7003 10.0.0.70:7004 10.0.0.70:7005
Creating cluster
[ERR] Sorry, can’t connect to node 10.0.0.70:7000
解决方法:在client.rb中添加密码
[root@redis-cluster01 ~]# find / -name client.rb
/root/ruby-2.2.7/lib/xmlrpc/client.rb
/usr/share/ruby/xmlrpc/client.rb
/usr/local/ruby-2.2.7/lib/ruby/2.2.0/xmlrpc/client.rb
/usr/local/ruby-2.2.7/lib/ruby/gems/2.2.0/gems/redis-4.1.0/lib/redis/client.rb
[root@redis-cluster01 ~]# grep “:password =>” /usr/local/ruby-2.2.7/lib/ruby/gems/2.2.0/gems/redis-4.1.0/lib/redis/client.rb
:password => nil,
[root@redis-cluster01 ~]# grep “:password =>” /usr/local/ruby-2.2.7/lib/ruby/gems/2.2.0/gems/redis-4.1.0/lib/redis/client.rb
:password => “000000”,
[root@redis-cluster01 ~]# ruby /application/redis-cluster/redis-trib.rb create --replicas 1 10.0.0.70:7000 10.0.0.70:7001 10.0.0.70:7002 10.0.0.70:7003 10.0.0.70:7004 10.0.0.70:7005
>>> Creating cluster
>>> Performing hash slots allocation on 6 nodes…
Using 3 masters:
10.0.0.70:7000
10.0.0.70:7001
10.0.0.70:7002
Adding replica 10.0.0.70:7004 to 10.0.0.70:7000
Adding replica 10.0.0.70:7005 to 10.0.0.70:7001
Adding replica 10.0.0.70:7003 to 10.0.0.70:7002
>>> Trying to optimize slaves allocation for anti-affinity
[WARNING] Some slaves are in the same host as their master
M: 0c81f4cc063b9d93b871ef1101dbd5cf7ab6b62d 10.0.0.70:7000
slots:0-5460 (5461 slots) master
M: 3686833312e5d8579e6769ea102a722c218d6e80 10.0.0.70:7001
slots:5461-10922 (5462 slots) master
M: e351397ed6db615a85bdf118b1b2272ac04d084d 10.0.0.70:7002
slots:10923-16383 (5461 slots) master
S: fb3449137208ac212bc0e61403523b076a671efa 10.0.0.70:7003
replicates 3686833312e5d8579e6769ea102a722c218d6e80
S: 0a18ed047615d869237836d749c5cfa45dd003c7 10.0.0.70:7004
replicates e351397ed6db615a85bdf118b1b2272ac04d084d
S: 3df229bcd1369a38c1b686904ae44b1707810257 10.0.0.70:7005
replicates 0c81f4cc063b9d93b871ef1101dbd5cf7ab6b62d
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.0.0.70:7000)
M: 0c81f4cc063b9d93b871ef1101dbd5cf7ab6b62d 10.0.0.70:7000
slots:0-5460 (5461 slots) master
1 additional replica(s)
M: 3686833312e5d8579e6769ea102a722c218d6e80 10.0.0.70:7001
slots:5461-10922 (5462 slots) master
1 additional replica(s)
M: e351397ed6db615a85bdf118b1b2272ac04d084d 10.0.0.70:7002
slots:10923-16383 (5461 slots) master
1 additional replica(s)
S: 3df229bcd1369a38c1b686904ae44b1707810257 10.0.0.70:7005
slots: (0 slots) slave
replicates 0c81f4cc063b9d93b871ef1101dbd5cf7ab6b62d
S: 0a18ed047615d869237836d749c5cfa45dd003c7 10.0.0.70:7004
slots: (0 slots) slave
replicates e351397ed6db615a85bdf118b1b2272ac04d084d
S: fb3449137208ac212bc0e61403523b076a671efa 10.0.0.70:7003
slots: (0 slots) slave
replicates 3686833312e5d8579e6769ea102a722c218d6e80
[OK] All nodes agree about slots configuration.
>>> Check for open slots…
>>> Check slots coverage…
[OK] All 16384 slots covered.
[root@redis-cluster01 ~]# /application/redis/redis-cli -c -h 10.0.0.70 -p 7000 -a 000000
10.0.0.70:7000> info replication
# Replication
role:master
connected_slaves:1
min_slaves_good_slaves:1
slave0:ip=10.0.0.70,port=7005,state=online,offset=28,lag=1 ###7005端口的实例为7000实例的从节点
master_replid:3260ce1209f497c9a3fc79051be604eacc562d9f
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:28
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:28
10.0.0.70:7000> KEYS *
(empty list or set)
10.0.0.70:7000> set name liang
-> Redirected to slot [5798] located at 10.0.0.70:7001 ###数据被分配到70001实例上
OK
10.0.0.70:7001> KEYS *###查看的时候自动跳到70001实例。
\1) “name”