Maison >développement back-end >tutoriel php >Résumé du didacticiel de création de cluster Redis

Résumé du didacticiel de création de cluster Redis

不言
不言original
2018-07-28 10:25:211697parcourir

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 :)

    Résumé du didacticiel de création de cluster 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)

    • 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):
      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
  • Test

    sudo /etc/init.d/redis_6379 start

Redis stop and start

miam installationRésumé du didacticiel de création de cluster Redis

/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
Forcer la terminaison

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

Résumé du didacticiel de création de cluster Redis

Résumé du didacticiel de création de cluster Redis

创建数据存储文件

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

Résumé du didacticiel de création de cluster Redis

创建集群

/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

Résumé du didacticiel de création de cluster Redis

测试

执行命令: /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客户端连接的端口 + 1000Résumé du didacticiel de création de cluster Redis

  • redis /usr/bin/env: ruby: 没有那个文件或目录

    • 执行这个命令 rvm get stable --auto-dotfiles,或者执行 nvm list 有详细的错误说明(查了资料说,线上不要用rvm安装ruby)

    Résumé du didacticiel de création de cluster Redis

    • 这是我自己的解决方案

      # 把这个添加到 /etc/profile 文件中(放到最后就行)
      rvm use ruby-2.6.0-preview2

相关推荐:

CentOS7系统安装和配置Memcached的方法

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn