redis集群搭建
1. 下载redis安装源码包,下载链接地址:redis download。
2. 集群中redis集群节点端口号7000~7005,端口号即集群下各实例文件夹,数据存储在 端口号/data 文件夹中。如图1:
data:image/s3,"s3://crabby-images/be88f/be88f89af363703eab379388350f61cbdd25970c" alt=""
3. 复制执行脚本。如图2:
data:image/s3,"s3://crabby-images/67225/672259df0bdc408e101b03942fc79f13ca32bf6e" alt=""
4. 创建一个新的redis实例。如图3:
data:image/s3,"s3://crabby-images/46067/460675f33452788e8b831ca9f0e2fb71f5a65ba0" alt=""
5. 修改redis.conf。修改配置如下:
data:image/s3,"s3://crabby-images/7d4db/7d4dbeb6ce226e728c8543ed5b18491dbaca624a" alt=""
port 7000(每个节点的端口号)
daemonize yes
bind 127.0.0.1(绑定当前机器 IP)
dir /home/xiaodongsun/Documents/redis-cluster/7000/data/(数据文件存放位置)
pidfile /var/run/redis_7000.pid(pid 7000和port要对应)
cluster-enabled yes(启动集群模式)
cluster-config-file nodes7000.conf(7000和port要对应)
cluster-node-timeout 15000
appendonly yes
6. 复制5个实例。如图4:
data:image/s3,"s3://crabby-images/0376e/0376efd7c5cf39921ccea450aa186ca3e7304c5d" alt=""
7. 修改7001~7005的redis.conf配置文件。如图5:
data:image/s3,"s3://crabby-images/3528f/3528ff86f37bfc1877f6cc8f36612a2fd30f522d" alt=""
vim redis.conf
#全局替换
:%s/7000/7001/g
检查主要是替换4行:
port 7002
dir /usr/local/redis-cluster/7002/data/
cluster-config-file nodes-7002.conf
pidfile /var/run/redis_7002.pid
8. 分别启动6台redis实例。如图6:
data:image/s3,"s3://crabby-images/f803f/f803f8f1b29f663647fea45e0bccbc80c2c64692" alt=""
连接其中一台测试:
data:image/s3,"s3://crabby-images/44ff2/44ff23e64422b7f37597a4c3579dbaab94e64ab3" alt=""
CLUSTERDOWN Hash slot not served(不是提供散列的列槽)
安装ruby环境(redis集群命令行工具redis-trib.rb命令需要借助ruby环境)
sudo apt-get install ruby
Ubuntu 16.04在搭建Redis Cluster搭建时,使用gem install redis时出现:ERROR: While executing gem ... (Gem::FilePermissionError) You don't have write permissions for the /var/lib/gems/2.3.0 directory.
data:image/s3,"s3://crabby-images/d9367/d93678f9d0a96038d7db848441b21cbd96b80517" alt=""
解决方式(参考官网安装教程):
sudo apt-get update
sudo apt-get install git-core curl zlib1g-dev build-essential libssl-dev libreadline-dev libyaml-dev libsqlite3-dev sqlite3 libxml2-dev libxslt1-dev libcurl4-openssl-dev python-software-properties libffi-dev
cd
git clone https://github.com/rbenv/rbenv.git ~/.rbenv
echo 'export PATH="$HOME/.rbenv/bin:$PATH"' >> ~/.bashrc
echo 'eval "$(rbenv init -)"' >> ~/.bashrc
exec $SHELL
git clone https://github.com/rbenv/ruby-build.git ~/.rbenv/plugins/ruby-build
echo 'export PATH="$HOME/.rbenv/plugins/ruby-build/bin:$PATH"' >> ~/.bashrc
exec $SHELL
rbenv install 2.3.1
rbenv global 2.3.1
ruby -v
重新运行:gem install redis
data:image/s3,"s3://crabby-images/1de68/1de68007749fe6e397b2ddefc9557e1833a86840" alt=""
9. 创建集群。如图7:
data:image/s3,"s3://crabby-images/fcb2e/fcb2e91db00b7d23bd3a722b60a09757bde37b7d" alt=""
创建完成后:
data:image/s3,"s3://crabby-images/352ae/352ae429d3a338e648d22433893dcfb211b2cc49" alt=""
10. 客户端连接redis集群测试
集群写入数据报错:
data:image/s3,"s3://crabby-images/bb04f/bb04fbbced66dd4c13f7659257338311a3c28e88" alt=""
错误原因: 连接参数需要添加 "-c"(集群连接方式)
data:image/s3,"s3://crabby-images/81e6b/81e6b54feccb03f8c22994593bf4e474b80ba52c" alt=""
到此基本上已完成初步的集群搭建更多信息参考官网: http://www.redis.cn/topics/cluster-tutorial.html
Java操作redis cluster:https://github.com/xiaodongsun-github/tutorials/blob/master/springboot-redis-cluster/src/main/java/com/example/SpringbootRedisClusterApplication.java