美文网首页我爱编程
2018-04-10 学习Windows下搭建redis集群

2018-04-10 学习Windows下搭建redis集群

作者: 中国色 | 来源:发表于2018-04-10 22:56 被阅读0次

    操作系统:win10

    redis版本:3.2.1-x64

    ruby版本:2.5.1-1-x64

    rubygems版本:2.7.6

        今天突然想简单的搭建一个redis的集群,因为系统是Windows上的,所以就网上查找了一番搭建集群的相关博客和攻略,经过各种问题后,成功运行了。现在记下来,省的忘记了。。。

        其中相关程序的版本经过搭建后,就暂时确立为以上版本,放在百度云盘上,地址:https://pan.baidu.com/s/1D5Xyl-3fonr8mKUlNQA2Ug,密码:00x5。搭建过程中出现过一些问题,有些是因为ruby版本太低,有些是安装不正确等各种因素,具体的一些原因可以查看博客https://blog.csdn.net/asas1314/article/details/50203923,上面总结的挺好的,就不详细讲了。

    一、 下载redis

        下载上述百度云盘中的redis,解压到任意文件夹中,我直接下载到桌面上了,就干脆解压到桌面上去了,里面文件如下所示(其中的redis-trib.rb是没有的,需要另外下载的):

    二、 配置三主三从集群

        解压后,将redis复制五份,配置三主三从集群,由于redis默认端口为6379,所以另外五份分别为6380,6381,6382,6383,6384。我建立的如下所示:

        其中每一个文件夹想当于一个redis。

    三、 修改每一份redis的配置

        以6379为例,打开文件夹中的redis.windows.conf文件,分别修改里面的如下数据:

        port 6379                 //修改默认端口,与文件夹相同即可

        cluster-enabledyes        //开启实例的集群模式

        cluster-config-filenodes-6379.conf        //设定保存节点配置文件的路径,节点文件自动生成,无需修改

        cluster-node-timeout5000      //调整为  5000,那么在创建集群的时候,不会超时。

        appendonly yes            //开启appendonly模式后,redis将每一次写操作请求都追加到appendonly.aof文件中

        另外,在每个文件夹中写一个bat用来启动redis,内容如下:

        title redis-6379

        redis-server.exeredis.windows.conf

        建立完成之后,可以分别点击每个文件夹中的bat,启动每个redis。

    四、 安装ruby

        redis建立的的集群需要ruby环境,所以下载云盘中的rebyinstaller,全部下一步,该勾选的全部勾选上,路径默认即可。之前因为下载安装的2.4.4-1的版本,安装之后出现了点问题,所以升级了ruby为2.5.1-1的版本。

    五、 安装rubygems

        下载云盘的版本后解压缩,启动cmd进入到解压后的文件夹中,直接运行ruby setup.rb执行安装即可。

        然后执行命令gem install redis,安装redis的相关依赖。

    六、下载集群脚本redis-trib.rb

        我是在github上直接把antirez的redis项目克隆到本地后,直接在src中复制出来的,如果嫌麻烦,可以用我云盘上传的那个。我是将文件和之前建立的6379等文件夹放到了一起,似乎放在哪里都不要紧的感觉,这方面没试过。

    七、 执行集群构建脚本

        进入到redis-trib.rb所在的文件夹中,执行命令redis-trib.rb create --replicas 1 127.0.0.1:6379 127.0.0.1:6380

    127.0.0.1:6381 127.0.0.1:6382 127.0.0.1:6383 127.0.0.1:6384,即可构建集群。

        其中会出现Can I set the above configuration? (type 'yes' to accept),输入yes,最后出现两个OK的时候差不多就是构建成功了。其中上面也可以看到主从节点的对应关系,以及每个节点的slot区间。

    八、 测试集群

        例如进入6379的文件夹,输入命令redis-cli.exe -h 127.0.0.1 -p 6379 -c(h自然是主机号,p是端口号,c连接集群结点时使用,此选项可防止moved和ask异常。)后,开启redis,然后,例如输入一个set name hello,然后集群会自动将这个保存到6380的redis中,集群之间也会自动的跳转过去,然后在6380中去get name,自然可以获取的到。

    九、 关闭和重新启动集群

        网上查看了很久,似乎关闭和重新启动集群主要是关闭redis服务和重新启动redis服务,其中靠谱的解答如下:

    (1)通过redis-cli连接服务器后执行shutdown命令,则执行停止redis服务操作。

    (2)可以使用shutdown命令关闭redis服务器外,还可以使用kill+进程号的方式关闭redis服务。

    (3)不要使用Kill 9方式关闭redis进程,这样redis不会进行持久化操作,除此之外,还会造成缓冲区等资源不能优雅关闭,极端情况下会造成AOF和复制丢失数据的情况

    (4)shutdown还有一个参数,代表关闭redis服务前是否生产持久化文件

         shutdown save|nosave

    相关文章

      网友评论

        本文标题:2018-04-10 学习Windows下搭建redis集群

        本文链接:https://www.haomeiwen.com/subject/izjohftx.html