1集群结构说明

集群中有三个主节点,三个从节点,一共六个结点。因此要构建六个redis的docker容器。在宿主机中将这六个独立的redis结点关联成一个redis集群。需要用到官方提供的ruby脚本。

2构建redis基础镜像

本文选择版本为redis-3.0.7,如果需要其他版本,直接修改wget后面地址中的版本号即可。

代码清单2-1 下载&编译redis源码包

# mkdir –p /usr/docker_root/redis_cluster
# cd /usr/docker_root/redis_cluster
# wget http://download.redis.io/releases/redis-3.0.7.tar.gz
# tar zxvf redis-3.0.7.tar.gz
# cd redis-3.0.7
# make

PS: 如果你连 # 也复制了,那你还是别看了……

我们已经在宿主机编译好了redis源码,在src路径下有我们需要的可执行文件:redis-cli,redis-server和redis-trib.rb。redis-trib.rb是redis官方提供的ruby脚本,用来构建redis集群

修改redis.conf。在redis-3.0.7的根路径下有redis的配置文件redis.conf。将其移动到上一级路径/usr/docker_root/redis_cluster/ 下。

依据代码清单2-2,修改redis.conf文件中的对应参数值。

daemonize : 是否后台运行,将其设为no,表示前台运行。

port :redis服务监听的端口。

logfile : 指定日志文件路径。

appendonly : 是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。

cluster-node-timeout : 集群结点超时限制。

代码清单2-2 需要修改的配置参数

daemonize no
port 6379
logfile "/var/log/redis/redis-server.log"
appendonly yes
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000

下面构建redis基础镜像。以Dockerfile方式构建。

代码清单2-3 创建redis基础镜像的Dockerfile

# pwd

/usr/docker_root/redis_cluster

# vim Dockerfile

我们来看看Dockerfile的内容,如代码清单2-4所示。

代码清单2-4 Dockerfile

FROM ubuntu:14.04 
ADD redis-3.0.7.tar.gz /
RUN mkdir -p /redis
ADD redis.conf /redis/ RUN apt-get -yqq update
RUN apt-get install -y gcc make WORKDIR /redis-3.0.7
RUN make
RUN mv /redis-3.0.7/src/redis-server /redis/ WORKDIR /
RUN rm -rf /redis-3.0.7 RUN apt-get remove --purge -y gcc make VOLUME ["/var/log/redis/"] EXPOSE 6379

将本地的redis源码包复制到镜像的根路径下,ADD命令会在复制过后自动解包。被复制的对象必须处于Dockerfile同一路径,且ADD后面必须使用相对路径。

将我们修改后的配置文件也复制到镜像内。

为编译源码包,需要安装gcc和make,安装之前先更新apt-get。更新和安装时间较长。

编译源码包。当然编译也需要一段时间。

编译后,容器中只需要可执行文件redis-server,所以将该文件移到/redis/路径下。现在redis-server 和redis.conf都在/redis/下。

将redis-3.0.7路径整个删除。

gcc和make也可以卸载掉。

指定数据卷,通过这个数据卷可以查看redis运行的日志文件。

公开redis默认端口6379。

因为不会执行这个镜像,所有没有包含ENTRYPOINT和CMD指令。我们基于这个镜像构建别的镜像。

现在我们构建redis基础镜像

代码清单2-5 构建redis基础镜像

# docker build -t redis:3.0.7 .

构建过程与网络带宽有关,十分钟左右,构建完成。成功构建镜像之后,运行docker images,可以看见zcq/redis_base镜像,如图2-2所示,镜像size有290.4MB。

3构建redis结点镜像

我们继续构建redis结点镜像,这个镜像将会用于生成提供redis服务的docker容器。

代码清单3-1 创建redis结点镜像的Dockerfile

# mkdir redis_node

# cd redis_node

# vim Dockerfile

Dockerfile如代码清单3-2所示。

代码清单3-2 redis结点镜像Dockerfile
FROM redis:3.0.7
ENTRYPOINT ["/redis/redis-server", "/redis/redis.conf"]

构建redis结点镜像。

代码清单3-3 构建redis结点镜像

# docker build -t redis-cluster:3.0.7 .

查看redis结点镜像redis-cluster:3.0.7,如上图。

 

4创建redis结点容器

依次创建六个redis结点容器,如代码清单4-1所示。

代码清单4-1 创建redis结点

# docker run -d --name redis01 -p 30001:6379 redis-cluster:3.0.7
# docker run -d --name redis02 redis-cluster:3.0.7
# docker run -d --name redis03 redis-cluster:3.0.7
# docker run -d --name redis04 redis-cluster:3.0.7
# docker run -d --name redis05 redis-cluster:3.0.7
# docker run -d --name redis06 redis-cluster:3.0.7

docker-compose.yml

version: "2"
services:
  redis01:
    image: redis-cluster:3.0.7
    ports:
      - 6379:6379
    container_name: redis01

  redis02:
    image: redis-cluster:3.0.7
    container_name: redis02

  redis03:
    image: redis-cluster:3.0.7
    container_name: redis03

  redis04:
    image: redis-cluster:3.0.7
    container_name: redis04

  redis05:
    image: redis-cluster:3.0.7
    container_name: redis05

  redis06:
    image: redis-cluster:3.0.7
    container_name: redis06

启动:COMPOSE_PROJECT_NAME=test docker-compose up -d

是不是很奇怪第一个容器的打开方式有点不一样,第一个容器做了端口映射,是专门留给客户端访问的,这样客户端就可以通过宿主机的30001端口访问redis集群了。

查看各容器IP地址

代码清单4-2 查看redis结点IP

# docker inspect redis01 redis02 redis03 redis04 redis05 redis06 | grep \"IPAddress\"| grep 172

"IPAddress": "172.19.0.16",

"IPAddress": "172.19.0.17",

"IPAddress": "172.19.0.15",

"IPAddress": "172.19.0.19",

"IPAddress": "172.19.0.14",

"IPAddress": "172.19.0.18",

5搭建redis集群

前文已经提到,要构建集群需要使用官方提供的ruby脚本,也就是redis-3.0.7/src/redis-trib.rb,因此需要先安装ruby的环境。

一般需要安装ruby1.9的版本,可以自己下载安装。

代码清单5-1 安装ruby环境

# yum install ruby

# yum install rubygems

手动安装步骤:

tar -xzf ruby-1.9.3-p194.tar.gz解压安装包

./configure --prefix=/usr/local/ruby

由于redhat新版本(redhat5.4不报错,开发环境会报错)默认openssl的配置变更取消了对EC_xx的支持,make 会出错,

此时需要修改ext/openssl/ossl_pkey_ec.c代码,修改的内容如下

修改762行开始处:

if (id == s_GFp_simple) {

method = EC_GFp_simple_method();

} else if (id == s_GFp_mont) {

method = EC_GFp_mont_method();

} else if (id == s_GFp_nist) {

method = EC_GFp_nist_method();

#if !defined (OPENSSL_NO_EC2M)

} else if (id == s_GF2m_simple) {

method = EC_GF2m_simple_method();

#endif

修改817行开始处:

if (id == s_GFp) {

new_curve = EC_GROUP_new_curve_GFp;

#if !defined (OPENSSL_NO_EC2M)

} else if (id == s_GF2m) {

new_curve = EC_GROUP_new_curve_GF2m;

#endif

} else {

ossl_raise(rb_eArgError, "unknown symbol, must be :GFp or :GF2m");

}

修改完成后执行如下命令

make

make install

安装完成后设置PATH路径,把安装的ruby放在系统PATH前面,

避免调用操作系统自带的ruby  (开发环境REDHAT自带为1.8版本,而1.8版本不能用于redis集群的部署,至少用1.9以上)   ,

修改~/.bash_profile

#PATH=$PATH:$HOME/bin—原来的配置

PATH=/usr/local/ruby/bin:$PATH:$HOME/bin—修改后的配置

修改后保存,并执行 source ~/.bash_profile生效

执行ruby -v 查看ruby版本

运行redis-trib.rb脚本还需要安装redis的ruby包。

代码清单5-2 安装redis的ruby包
# gem install redis --version 3.0.7


由于源的原因,可能下载失败,那就手动下载下来安装

download地址:http://rubygems.org/gems/redis/versions/3.0.7

代码清单5-3 手动下载&安装redis的ruby包

# wget https://rubygems.org/downloads/redis-3.0.7.gem --no-check-certificate
# gem install -l redis-3.0.7.gem


一切准备就绪,开始搭建redis集群吧!参照代码清单5-4,但是你还是要修改一下IP地址,你的容器地址应该不可能和我的一毛一样吧。

代码清单5-4 搭建redis集群

# cd /usr/docker_root/redis_cluster/redis-3.0.7/src/

[root@localhost src]# ./redis-trib.rb create --replicas 1 172.19.0.16:6379 \

172.19.0.17:6379 \

172.19.0.15:6379 \

172.19.0.19:6379 \

172.19.0.14:6379 \

172.19.0.18:6379

执行结果代码代码清单5-5所示

代码清单5-5 搭建redis集群输出结果

>>> Creating cluster
>>> Performing hash slots allocation on 6 nodes...
Using 3 masters:
172.19.0.16:6379
172.19.0.17:6379
172.19.0.15:6379
Adding replica 172.19.0.19:6379 to 172.19.0.16:6379
Adding replica 172.19.0.14:6379 to 172.19.0.17:6379
Adding replica 172.19.0.18:6379 to 172.19.0.15:6379
M: 6dd5bbcb3866b26d84d237de94d706c5612195bc 172.19.0.16:6379
slots:0-5460 (5461 slots) master
M: 3bd685c9e976cff50148b4cf432079bf5c82b132 172.19.0.17:6379
slots:5461-10922 (5462 slots) master
M: 001c39d6516064496ea257dab40e9089632e3226 172.19.0.15:6379
slots:10923-16383 (5461 slots) master
S: 9dbc596a889579f3efff3e89c868ff4bd6ab46bd 172.19.0.19:6379
replicates 6dd5bbcb3866b26d84d237de94d706c5612195bc
S: 060ace103346ca3a14446c092c324cb587847914 172.19.0.14:6379
replicates 3bd685c9e976cff50148b4cf432079bf5c82b132
S: bb81d9eb1084df2ce66ea3cc38ca4be7a6b009fe 172.19.0.18:6379
replicates 001c39d6516064496ea257dab40e9089632e3226
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join...
>>> Performing Cluster Check (using node 172.19.0.16:6379)
M: 6dd5bbcb3866b26d84d237de94d706c5612195bc 172.19.0.16:6379
slots:0-5460 (5461 slots) master
M: 3bd685c9e976cff50148b4cf432079bf5c82b132 172.19.0.17:6379
slots:5461-10922 (5462 slots) master
M: 001c39d6516064496ea257dab40e9089632e3226 172.19.0.15:6379
slots:10923-16383 (5461 slots) master
M: 9dbc596a889579f3efff3e89c868ff4bd6ab46bd 172.19.0.19:6379
slots: (0 slots) master
replicates 6dd5bbcb3866b26d84d237de94d706c5612195bc
M: 060ace103346ca3a14446c092c324cb587847914 172.19.0.14:6379
slots: (0 slots) master
replicates 3bd685c9e976cff50148b4cf432079bf5c82b132
M: bb81d9eb1084df2ce66ea3cc38ca4be7a6b009fe 172.19.0.18:6379
slots: (0 slots) master
replicates 001c39d6516064496ea257dab40e9089632e3226
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.

使用redis-cli连接redis集群,注意有–c

代码清单5-6 连接redis集群

# redis-cli -p 30001 –c
127.0.0.1:30001> info
下面显示集群的相关信息
# Server
redis_version:3.0.7
redis_git_sha1:00000000
redis_git_dirty:0
(省略一部分……)
# CPU
used_cpu_sys:2.21
used_cpu_user:1.63
used_cpu_sys_children:0.00
used_cpu_user_children:0.00 # Cluster
cluster_enabled:1
# Keyspace
127.0.0.1:30001>

做个set操作试试,见图5-1.

 

图5-1 set操作

看到了吗?Redirected to slot [15495] located at 172.17.0.67:6379。a的value被存储到172.17.0.67:6379结点上的槽[15495]里。下面的地址也变成了172.17.0.67:6379>。再试试get操作。

图5-2 get操作

大功告成!祝贺!!!

转载自:http://www.2cto.com/net/201608/532256.html

本人做了微调。不过实现的结果不变。

使用Docker构建redis集群--最靠谱的版本的更多相关文章

  1. Docker 构建 redis 集群

    安装docker 1.yum install docker 方法一: 1. docker pull redis 2.docker run -d --name redis-1 -p 7001:6379 ...

  2. 轻松构建 基于docker的 redis 集群

    下面跟着我来 一步一步构建redis 集群吧. 集群的目录结构见GitHub源码(文章末尾) 1,安装docker环境,根据自身的操作系统,google下即可. 2,我们在服务器上,搭建所需目录结构. ...

  3. Docker快速构建Redis集群(cluster)

    Docker快速构建Redis集群(cluster) 以所有redis实例运行在同一台宿主机上为例子 搭建步骤 redis集群目录清单 . ├── Dockerfile ├── make_master ...

  4. docker 实现redis集群搭建

    摘要:接触docker以来,似乎养成了一种习惯,安装什么应用软件都想往docker方向做,今天就想来尝试下使用docker搭建redis集群. 首先,我们需要理论知识:Redis Cluster是Re ...

  5. Docker Swarm redis 集群搭建

    Docker Swarm redis 集群搭建 环境1: 系统:Linux Centos 7.4 x64 内核:Linux docker 3.10.0-693.2.2.el7.x86_64 Docke ...

  6. 基于Docker的redis集群搭建

    Redis集群官方介绍:http://www.redis.cn/topics/cluster-tutorial.html 基于Docker搭建Redis集群 环境:6个节点,三主三从 制作Redis镜 ...

  7. docker搭建redis集群

    一.简介 docker作为一个容器技术,在搭建资源隔离性服务上具有很大的优势,在一台服务器上可以启动多个docker容器,感觉每个在容器里面部署的服务就像是部署在不同的服务器上.此次基于docker以 ...

  8. Docker 构建 RabbitMQ 集群

    刚开始,关于RabbitMQ集群的搭建,我找到了这篇文章:Docker 安装 RabbitMQ 集群 从而找到了第三方的RabbitMQ集群容器 rabbitmq-server 但是这个容器只有3.6 ...

  9. Docker:Docker搭建Redis集群(6)

    国外的公有云实在是太慢了,经常time out 这里搜集几个国内出名的: hub.c.163.com (网易:https://c.163.com/hub#/m/home/) dev.aliyun.co ...

随机推荐

  1. 【JAVA】Runtime

    1.内存管理:Java提供了无用单元自动收集机制.通过totalMemory()和freeMemory()方法可以知道对象的堆内存有多大,还剩多少.Java 会周期性的回收垃圾对象(未使用的对象),以 ...

  2. c#向数据库插入较大数据(SqlBulkCopy)

    因为要向数据库添加一些数据,数据量较大 1.使用sql语句批量提交速度较慢 2.用事物批量提交,速度一般 3.用SqlBulkCopy方法写入数据,速度较快 /// <summary> / ...

  3. 服务器中配置多个Tomcat及内存溢出配置

    1.更改server.xml文件中端口(启动.关闭端口) 2.在startup.bat文件开头加上 SET JAVA_HOME=C:\Program Files (x86)\Java\jdk1.8.0 ...

  4. Remoting and web services using Spring[摘自官网]

    spring document url: http://docs.spring.io/spring/docs/ Using Hessian First we’ll have to create a n ...

  5. context上下文 php版解释

    context翻译为上下文其实不是很好,只是翻译理解大概的作用,对于开发来说,context是对定义的使用的变量,常量或者说是配置, 部分的函数功能除了缺省值之外,往往需要手动设置一些定义量来配合当前 ...

  6. office 365 online api

    https://view.officeapps.live.com/op/view.aspx?src=http://bookfuns.com/1.ppt

  7. WINDOWS下PhoneGap(Cordova)安装笔记

    1.首先下载Node.js  安装nodejs很简单直接点击安装文件下一步直至成功即可,安装notejs的同时npm也会同时安装 成功后打开notejs的命令行工具 输入“node -v”," ...

  8. linux下解压

    (1).*.tar 用 tar –xvf 解压  (2).*.gz 用 gzip -d或者gunzip 解压  (3).*.tar.gz和*.tgz 用 tar –xzf 解压  (4).*.bz2 ...

  9. JMeter学习-032-JMeter常见四种变量简介

    在JMeter自动化测试脚本编写过程中,经常需要对测试脚本进行一些参数设置.例如,设置测试计划的全局变量(方便切换不同的测试环境).样本线程(HTTP请求等)的参数传递等. 通常,JMeter中常用的 ...

  10. Net中httpResponse和httpRequest的简单实用;

    这对象很简单,封装很多常用的方法和属性:使用起来也很方便: 这个关键是要对我们的 http中的各种协议要很了解滴呀: 模拟一个简单的暴力破解: public static class HttpInfo ...