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.
Avant-propos
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.
Installation de Redis
Compiler et installer
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
Faire de Redis une référence de service : Redis Quick Start
-
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
Copier après la connexionRemarque :
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
Copier après la connexion -
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
Copier après la connexionCommencez à 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)
- Définissez le
pidfile sur /var/run/redis_6379.pid (modifiez le port si nécessaire) (la valeur par défaut est suffisante)
- Modifiez le
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)
- Définissez votre
niveau de journal préféré (la valeur par défaut est suffisante)
- Définissez le
fichier journal sur /var/log. /redis_6379.log (la valeur par défaut semble vide et doit être modifiée)
- Définissez le
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
- Modifiez le fichier de configuration en veillant à effectuer les modifications suivantes : >Enfin, ajoutez le nouveau script d'initialisation Redis à tous les niveaux d'exécution par défaut à l'aide de la commande suivante : ( Dictionnaire Youdao : Enfin, utilisez la commande suivante pour ajouter le nouveau script d'initialisation Redis à tous les niveaux d'exécution par défaut :)
注:上面的意思是让你们修改 /usr/local/redis/conf/6379.conf,用vim 打开,搜索上述关键词即可,参考以下设置(如果所有的步骤都是粘贴复制的走下来的,直接修改成下面这样:0.0):
Copier après la connexionport 6379 daemonize yes pidfile /var/run/redis_6379.pid loglevel notice logfile "/var/log/redis_6379.log" dir /usr/local/redis/data/6379
Copier après la connexion -
Vous pouvez maintenant essayer d'exécuter ! votre instance avec :
# ubuntu sudo update-rc.d redis_6379 defaults
Copier après la connexion# centos chkconfig --add redis_6379
Copier après la connexion - Test
sudo /etc/init.d/redis_6379 start
Copier après la connexion
miam installation
/etc/init.d/redis-server stop
- /etc/init.d/redis-server start
- /etc/init.d/redis-server restart
- Trois façons d'installer le code source
- Remarque : Si vous arrêtez simplement le redis local, veuillez exécuter :
sudo /etc/init.d/redis_6379 start /usr/local/redis/bin/redis-server redis.conf # 注意此处缺省:配置文件路径 redis-cli -h 127.0.0.1 -p 6379 shutdown
redis-cli shutdown
kill -9 进程号
Rvm 安装 更换源
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 Ruby 安装、使用、卸载
rvm list known rvm install 2.6 rvm use 2.6 yum -y remove ruby # 卸载centos yum 安装的 1.8 版本 ruby --version rvm uninstall ruby # 此处带不带版本自己测试
RubyGems 升级、更换源、安装redis
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 集群搭建详细指南。
开启 Redis cluster
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*/*
启动Redis cluster 节点
/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="/static/imghw/default1.png" data-src="https://img.php.cn//upload/image/755/105/520/1532744572918545.png" class="lazy" 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
Copier après la connexion
相关推荐:
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Le mode Redis Cluster déploie les instances Redis sur plusieurs serveurs grâce à la rupture, à l'amélioration de l'évolutivité et de la disponibilité. Les étapes de construction sont les suivantes: Créez des instances de redis étranges avec différents ports; Créer 3 instances Sentinel, Moniteur Redis Instances et basculement; Configurer les fichiers de configuration Sentinel, ajouter des informations d'instance Redis de surveillance et des paramètres de basculement; Configurer les fichiers de configuration d'instance Redis, activer le mode de cluster et spécifier le chemin du fichier d'informations de cluster; Créer un fichier nœuds.conf, contenant des informations de chaque instance redis; Démarrez le cluster, exécutez la commande CREATE pour créer un cluster et spécifiez le nombre de répliques; Connectez-vous au cluster pour exécuter la commande d'informations de cluster pour vérifier l'état du cluster; faire

L'avenir de PHP sera réalisé en s'adaptant aux nouvelles tendances technologiques et en introduisant des fonctionnalités innovantes: 1) s'adapter aux architectures de cloud computing, de conteneurisation et de microservice, en prenant en charge Docker et Kubernetes; 2) introduire des compilateurs JIT et des types d'énumération pour améliorer l'efficacité des performances et du traitement des données; 3) Optimiser en continu les performances et promouvoir les meilleures pratiques.

Comment effacer les données Redis: utilisez la commande flushall pour effacer toutes les valeurs de clé. Utilisez la commande flushdb pour effacer la valeur clé de la base de données actuellement sélectionnée. Utilisez SELECT pour commuter les bases de données, puis utilisez FlushDB pour effacer plusieurs bases de données. Utilisez la commande del pour supprimer une clé spécifique. Utilisez l'outil Redis-CLI pour effacer les données.

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.

Le PHP reste important dans le développement Web moderne, en particulier dans la gestion de contenu et les plateformes de commerce électronique. 1) PHP a un écosystème riche et un fort soutien-cadre, tels que Laravel et Symfony. 2) L'optimisation des performances peut être obtenue via Opcache et Nginx. 3) PHP8.0 introduit le compilateur JIT pour améliorer les performances. 4) Les applications natives dans le cloud sont déployées via Docker et Kubernetes pour améliorer la flexibilité et l'évolutivité.

PHP et Python ont chacun leurs propres avantages et choisissent en fonction des exigences du projet. 1.Php convient au développement Web, en particulier pour le développement rapide et la maintenance des sites Web. 2. Python convient à la science des données, à l'apprentissage automatique et à l'intelligence artificielle, avec syntaxe concise et adaptée aux débutants.

Pour lire une file d'attente à partir de Redis, vous devez obtenir le nom de la file d'attente, lire les éléments à l'aide de la commande LPOP et traiter la file d'attente vide. Les étapes spécifiques sont les suivantes: Obtenez le nom de la file d'attente: Nommez-le avec le préfixe de "Fitre:" tel que "Fitre: My-Quyue". Utilisez la commande LPOP: éjectez l'élément de la tête de la file d'attente et renvoyez sa valeur, telle que la file d'attente LPOP: My-Queue. Traitement des files d'attente vides: si la file d'attente est vide, LPOP renvoie NIL et vous pouvez vérifier si la file d'attente existe avant de lire l'élément.

Les raisons pour lesquelles PHP est la pile technologique préférée pour de nombreux sites Web incluent sa facilité d'utilisation, son soutien communautaire solide et son utilisation généralisée. 1) Facile à apprendre et à utiliser, adapté aux débutants. 2) Avoir une énorme communauté de développeurs et des ressources riches. 3) Largement utilisé dans WordPress, Drupal et d'autres plateformes. 4) Intégrez étroitement aux serveurs Web pour simplifier le déploiement du développement.
