Maison >développement back-end >tutoriel php >Résumé du didacticiel de création de cluster Redis
Le contenu de cet article est un résumé du tutoriel de création de cluster Redis. Le contenu est très détaillé. Les amis dans le besoin peuvent s'y référer. J'espère que cela pourra aider tout le monde.
Cet article rassemble et organise des articles Web, des sites Web et ma propre expérience dans la création de clusters Redis. Le niveau est limité et seul l'environnement de construction est partagé. Cet article est divisé en parties suivantes :
Installation de Redis
Installation et source de remplacement Rvm
Installation, utilisation, désinstallation de Rvm Ruby
Mise à niveau de RubyGems, changement de source, installation de Redis
Configuration du cluster
Test de réussite
Veuillez suivre les étapes ci-dessus pour voir cet article
Instructions :
Pour étudier à utiliser uniquement, je n'assume aucune responsabilité en cas d'utilisation en ligne.
Si vous avez des questions, veuillez laisser un message ci-dessous.
Certaines commandes de l'article n'incluent pas sudo car j'utilise les autorisations root.
wget http://download.redis.io/releases/redis-4.0.10.tar.gz tar xzf redis-4.0.10.tar.gz cd redis-4.0.10 make PREFIX=/usr/local/redis install
Remarque : si vous ne souhaitez pas utiliser Redis en tant que service, vous l'avez déjà installé maintenant
Créez un répertoire où stocker vos fichiers de configuration Redis et vos données : (Dictionnaire Youdao : Créez un répertoire pour stocker les fichiers et données de configuration Redis :)
# 这只是一个目录结构,大家不要着急为什么自己没有,往下看,一步一步来 [root@amor ~]# cd /usr/local/redis [root@amor redis]# tree . ├── bin # 编译安装指定目录后自动生成目录及文件 │ ├── redis-benchmark │ ├── redis-check-aof │ ├── redis-check-rdb │ ├── redis-cli │ ├── redis-sentinel -> redis-server │ └── redis-server ├── conf # 自己建立的存储配置文件的目录及自己创建的单个Redis配置文件 │ └── 6379.conf └── data # 自己建立的存储Redis数据的目录及单个Redis服务数据存储目录 └── 6379 4 directories, 7 files
Remarque : cp /usr/src/redis-4.0.10/src/redis-trib.rb /usr/local/redis/bin/
Vous devrez utiliser
plus tard pour créer le cluster. Copiez le script d'initialisation que vous trouverez dans la distribution Redis sous le répertoire utils dans /etc. /init.d. Nous vous suggérons de l'appeler avec le nom du port sur lequel vous exécutez cette instance de Redis. Par exemple : (Dictionnaire Youdao : copiez le script d'initialisation trouvé dans la distribution Redis sous le répertoire utils dans /etc/init. d. Nous vous recommandons d'utiliser le nom du port sur lequel cette instance Redis s'exécute pour l'appeler. Par exemple :)
sudo cp utils/redis_init_script /etc/init.d/redis_6379
Modifiez le script d'initialisation (Dictionnaire Youdao : Modifier. le script d'initialisation.)
#!/bin/sh # chkconfig 2345 90 25 # linux 开机启动设置 2345 运行级别 90 启动优先级(参考 memcached head /etc/rc.d/rc3.d/S90memcached ) 25 关闭优先级 (参考memcached) # Simple Redis init.d script conceived to work on Linux systems # as it does use of the /proc filesystem. ### BEGIN INIT INFO # Provides: redis_6379 # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Redis data structure server # Description: Redis data structure server. See https://redis.io ### END INIT INFO REDISPORT=6379 EXEC=/usr/local/redis/bin/redis-server # 修改为自己的可执行文件所在目录 CLIEXEC=/usr/local/redis/bin/redis-cli # 修改为自己的可执行文件所在目录 PIDFILE=/var/run/redis_${REDISPORT}.pid # 默认就好 CONF="/usr/local/redis/conf/${REDISPORT}.conf" # 修改为自己的配置文件存放目录 ···省略··· esac
Commencez à modifier redis.conf
Assurez-vous de modifier REDISPORT en fonction du port que vous utilisez à la fois le chemin du fichier pid et. le nom du fichier de configuration dépend du numéro de port. (Dictionnaire Youdao : assurez-vous de modifier la redistribution en conséquence en fonction du port que vous utilisez. Le chemin du fichier pid et le nom du fichier de configuration dépendent du numéro de port.)
Définissez daemonize sur oui (par défaut, il est défini sur non (doit être modifié sur oui)
pidfile sur /var/run/redis_6379.pid (modifiez le port si nécessaire) (la valeur par défaut est suffisante)
port en conséquence. Dans notre exemple, il n'est pas nécessaire car le port par défaut est déjà 6379. (La valeur par défaut est suffisante. Lors de la configuration du cluster, vous devez copier le fichier de configuration et réinitialiser le port)
niveau de journal préféré (la valeur par défaut est suffisante)
fichier journal sur /var/log. /redis_6379.log (la valeur par défaut semble vide et doit être modifiée)
dir sur /var/redis/6379 (étape très importante ! ) (répertoire de sauvegarde des données Redis, besoin de modifier le chemin personnalisé de l'emplacement)
(Modifier vers votre propre répertoire défini. Reportez-vous à la structure de répertoires ci-dessus redis.conf (sous le répertoire src dans votre répertoire de décompression redis) sudo cp redis.conf /usr/local/redis/conf/6379.conf
(Modifiez dans votre propre répertoire défini. Reportez-vous à la structure de répertoires ci-dessus) sudo mkdir /usr/local/redis/data/6379
注:上面的意思是让你们修改 /usr/local/redis/conf/6379.conf,用vim 打开,搜索上述关键词即可,参考以下设置(如果所有的步骤都是粘贴复制的走下来的,直接修改成下面这样:0.0):
port 6379 daemonize yes pidfile /var/run/redis_6379.pid loglevel notice logfile "/var/log/redis_6379.log" dir /usr/local/redis/data/6379
Vous pouvez maintenant essayer d'exécuter ! votre instance avec :
# ubuntu sudo update-rc.d redis_6379 defaults
# centos chkconfig --add redis_6379
sudo /etc/init.d/redis_6379 start
miam installation
sudo /etc/init.d/redis_6379 start /usr/local/redis/bin/redis-server redis.conf # 注意此处缺省:配置文件路径 redis-cli -h 127.0.0.1 -p 6379 shutdownForcer la terminaison
redis-cli shutdown
kill -9 进程号
curl -sSL https://rvm.io/mpapis.asc | gpg2 --import - curl -L get.rvm.io | bash -s stable rvm user gemsets # 建立用户配置目录,更换源的时候需要向 db 文件写入配置信息 echo "ruby_url=https://cache.ruby-china.org/pub/ruby" > ~/.rvm/user/db # 更换源
rvm list known rvm install 2.6 rvm use 2.6 yum -y remove ruby # 卸载centos yum 安装的 1.8 版本 ruby --version rvm uninstall ruby # 此处带不带版本自己测试
gem install rubygems-update rubygems-update gem sources --add https://gems.ruby-china.com/ --remove https://rubygems.org/ gem sources -l gem install redis
注:下面的内容是我自己参考这篇博文加上我熟悉Redis安装后自己的配置过程。大家可以参考NrwLm - Redis 集群搭建详细指南。
cd /usr/local/redis/conf cp 6379.conf redis.conf.default # 用作集群其他配置文件的蓝本 sudo vim redis.conf.default
修改内容如下
bind 192.168.2.123 # 绑定当前机器 IP cluster-enabled yes # 取消注释,启动集群模式 cluster-config-file nodes-6379.conf # 取消注释,修改为 /usr/local/redis/data/6379/nodes-6379.conf (如果遇到需要重新建立集群,不将此项修改为指定路径而和启动配置文件放在一起,会导致建立集群时,删除重建conf 文件) cluster-node-timeout 15000 # 取消注释 appendonly yes # 将 no 修改为 yes
cd /usr/local/redis/conf echo 9001.conf 9002.conf 9003.conf 9004.conf 9005.conf 9006.conf | xargs -n 1 cp -v redis.conf.default sed -i 's/6379/9001/g' 9001.conf sed -i 's/6379/9002/g' 9002.conf sed -i 's/6379/9003/g' 9003.conf sed -i 's/6379/9004/g' 9004.conf sed -i 's/6379/9005/g' 9005.conf sed -i 's/6379/9006/g' 9006.conf
cd /usr/local/redis/data mkdir -p 9001 9002 9003 9004 9005 9006 # 后期可能需要删除该文件件下的文件,用于重建集群,所以,删除命令也写一下 rm -rf 900*/*
/usr/local/redis/bin/redis-server /usr/local/redis/conf/9001.conf /usr/local/redis/bin/redis-server /usr/local/redis/conf/9002.conf /usr/local/redis/bin/redis-server /usr/local/redis/conf/9003.conf /usr/local/redis/bin/redis-server /usr/local/redis/conf/9004.conf /usr/local/redis/bin/redis-server /usr/local/redis/conf/9005.conf /usr/local/redis/bin/redis-server /usr/local/redis/conf/9006.conf
/usr/local/redis/bin/redis-trib.rb create --replicas 1 192.168.2.123:9001 192.168.2.123:9002 192.168.2.123:9003 192.168.2.123:9004 192.168.2.123:9005 192.168.2.123:9006
执行命令: /usr/local/redis/bin/redis-cli -c -h 192.168.2.123 -p 9001
<img src="https://img.php.cn//upload/image/755/105/520/1532744572918545.png" title="1532744572918545.png" alt="Résumé du didacticiel de création de cluster Redis">
如果遇到timeout 请查看自己的防火墙,安装宝塔的尤其注意,请先去安全里面放行 9001:9006 的端口
redis集群 Waiting for the cluster to join 一直等待,redis集群不仅需要开通redis客户端连接的端口,而且需要开通集群总线端口,集群总线端口为redis客户端连接的端口 + 1000
redis /usr/bin/env: ruby: 没有那个文件或目录
执行这个命令 rvm get stable --auto-dotfiles
,或者执行 nvm list
有详细的错误说明(查了资料说,线上不要用rvm安装ruby)
这是我自己的解决方案
# 把这个添加到 /etc/profile 文件中(放到最后就行) rvm use ruby-2.6.0-preview2
相关推荐:
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!