使用docker 部署codis

原文地址:https://www.jianshu.com/p/85e72ae6fec3

codis的架构图

1、zookeeeper,用于存放统一配置信息和集群状态

2、codis-fe,codis管理后台的前端页面。(可以看到是vue的地位)

3、codis-dashboard,coids的管理后台系统。(可以看成是提供后端接口的服务)

4、codis-proxy。工作服务器,负责redsi命令的的分发。

5、codis-group。真正存数据取数据的地方。

6、redis-sentinel。用来监控codis-group的主redis是否工作,用于redsi的主挂了之后,触发主从切换。

部署流程

一、下载源码

mkdir codis && cd codis
git clone https://github.com/CodisLabs/codis.git -b release3.2

二、构建镜像imag

1、使用Docker multi-stage build多阶段构建机制,编译alpine版本的codis,使用阿里云的软件源,加速依赖安装,然后设置时区为上海,打包后200M左右,修改Dockerfile如下。

修改dockerFile文件

FROM golang:1.10.3-alpine3.8 as builder

ENV GOPATH /go
ENV CODIS ${GOPATH}/src/github.com/CodisLabs/codis
ENV PATH ${GOPATH}/bin:${PATH}:${CODIS}/bin
COPY . ${CODIS} RUN echo -e "https://mirrors.aliyun.com/alpine/v3.8/main/\nhttps://mirrors.aliyun.com/alpine/v3.8/community/" > /etc/apk/repositories ;\
apk add --no-cache --virtual .build-deps \
make \
bash \
gcc \
musl-dev \
autoconf \
linux-headers \
; \
make -C ${CODIS} distclean ;\
make -C ${CODIS} build-all ;\
apk del .build-deps FROM alpine:3.8
ENV PATH ${PATH}:/codis/bin RUN echo -e "https://mirrors.aliyun.com/alpine/v3.8/main/\nhttps://mirrors.aliyun.com/alpine/v3.8/community/" > /etc/apk/repositories ;\
apk add --no-cache tzdata ;\
cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime COPY --from=builder /go/src/github.com/CodisLabs/codis /codis WORKDIR /codis

执行

docker build -f Dockerfile -t codis-image .

构建镜像



构建过程比较长,因为codis的运行需要go环境,需要把go环境打包到image里面

三、修改配置文件

在config目录下面

修改dashboard.toml

修改proxy.toml

配置redis.toml

protected-mode no
dir "/codis"

修改docker.sh里面的server

server)
for ((i=0;i<4;i++)); do
let port="26379 + i"
docker rm -f "Codis-S${port}" &> /dev/null
docker run --net=host --name "Codis-S${port}" -d \
-v `realpath ../config/redis.conf`:/codis/redis.conf \
-v `realpath log`:/codis/log \
codis-image \
codis-server redis.conf --logfile log/${port}.log --port ${port}
done
;;

四、启动应用

sh docker.sh zookeeper
sh docker.sh dashboard
sh docker.sh fv
sh docker.sh proxy
sh docker.sh server

启动3个sentinel

docker run --net=host --name "Codis-T46380" -d \
-v `realpath ../config/sentinel.conf`:/codis/sentinel.conf \
-v `realpath log`:/codis/log \
codis-image \
redis-sentinel sentinel.conf --port 46380 --protected-mode no docker run --net=host --name "Codis-T46381" -d \
-v `realpath ../config/sentinel.conf`:/codis/sentinel.conf \
-v `realpath log`:/codis/log \
codis-image \
redis-sentinel sentinel.conf --port 46381 --protected-mode no
docker run --net=host --name "Codis-T46382" -d \
-v `realpath ../config/sentinel.conf`:/codis/sentinel.conf \
-v `realpath log`:/codis/log \
codis-image \
redis-sentinel sentinel.conf --port 46382 --protected-mode no

浏览器进入192.168.2.136:8080端口(IP换成自己的服务器ip)



1、新增proxy

2、新增group和redis-server

这里我们有4台redsi-server分成2组;每组两台

2.1、点击新增group

2.2、再点击新增server

2.3、再点击标记为从redsi



2.4点击分配group的solt



2.5新增3个sentinel,然后点击syn

有2个master组,3个sentinel。

五、测试高可用

现在可以通过redis-cli192.168.2.136:29000端口去连接redis;

执行set a a ,set b b后的页面显示

执行docker stop Codis-S26381把group2的主停掉

执行get a,get b查看结果,依旧有数据

执行docker start Codis-S26381重启26381

使用docker 部署codis的更多相关文章

  1. ASP.NET Core开发-Docker部署运行

    ASP.NET Core开发Docker部署,.NET Core支持Docker 部署运行.我们将ASP.NET Core 部署在Docker 上运行. 大家可能都见识过Docker ,今天我们就详细 ...

  2. Docker部署Hadoop集群

    Docker部署Hadoop集群 2016-09-27 杜亦舒 前几天写了文章"Hadoop 集群搭建"之后,一个朋友留言说希望介绍下如何使用Docker部署,这个建议很好,Doc ...

  3. 程序开发使用docker部署

    我们公司自己研发了一套 grand-line 系统,使用 docker 来部署项目. 我是第一批小白鼠,一开始网络差,build 一次要半个小时,连接进入 web shell 也很慢,部署一个微信项目 ...

  4. 我使用celery以及docker部署遇到的问题

    首先我本机测试时没有问题的,但是在线上docker中,任务一直显示 "Sending due task".超时的任务是 django orm update 操作,本地不会出现这样的 ...

  5. Docker部署SDN环境

    2014-12-03 by muzi Docker image = Java class Docker container = Java object 前言 5月份的时候,当我还是一个大学生的时候,有 ...

  6. 在生产环境使用Docker部署应用

    导读 Docker现在越来越流行,但是真正在生产环境部署Docker还是个比较新的概念,还没有一个标准的流程.作者是ROR的程序员,作者结合平时的部署经验,联系Docker的特点,向大家分享了其在生产 ...

  7. Docker 使用指南 (六)—— 使用 Docker 部署 Django 容器栈

    版权声明:本文由田飞雨原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/98 来源:腾云阁 https://www.qclou ...

  8. NET Core Docker部署

    NET Core Docker部署 前言 在前面文章中,介绍了 ASP.NET Core在 macOS,Linux 上基于Nginx和Jexus的发布和部署,本篇文章主要是如何在Docker容器中运行 ...

  9. 我使用 Docker 部署 Celery 遇到的问题

    问题1 - Sending due task 本机测试时没有问题的,但是在线上 docker 中,任务一直显示 "Sending due task".超时的任务是 Django O ...

随机推荐

  1. Excel双击“单元格”后,自动跳转到相关“工作表

    Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)If Target.Column = ...

  2. 044 01 Android 零基础入门 01 Java基础语法 05 Java流程控制之循环结构 06 使用do-while循环实现猜字游戏

    044 01 Android 零基础入门 01 Java基础语法 05 Java流程控制之循环结构 06 使用do-while循环实现猜字游戏 本文知识点:do-while循环深入运用 案例练习 案例 ...

  3. Java知识系统回顾整理01基础05控制流程07结束外部循环

    一.break是结束当前循环 二.结束当前循环实例 break; 只能结束当前循环 public class HelloWorld { public static void main(String[] ...

  4. Java (三)APACHE Commons IO 常规操作

    上一篇:Java (二)基于Eclipse配置Commons IO的环境 例1:查看文件.文件夹的长度(大小). 1 import java.io.File; 2 3 import org.apach ...

  5. 【比赛记录】8.21 div2

    A 选择一个点\(B(x,0)\)使得\(|dis(A,B)-x|=k.\) 题目实际上就是找到一个最接近\(n\)的数,使得它可以分成两个数\(a,b,\)使\(a-b=k.\) 我们考虑先分成一个 ...

  6. WSL2 bug

    错误现象 Stdout: Stderr: 2020/05/27 20:01:37 resolving /mnt/host/c/Program Files/Docker/Docker/resources ...

  7. Springcloud技术分享

    Springcloud技术分享 Spring Cloud 是一套完整的微服务解决方案,基于 Spring Boot 框架,准确的说,它不是一个框架,而是一个大的容器,它将市面上较好的微服务框架集成进来 ...

  8. 多测师讲解unittest介绍及自动化测试实现流程_高级讲师肖sir

    unittest框架介绍 unittest框架是python中一个标准的库中的一个模块,该模块包括许多的类如 test case类.test suit类.texttest runner类.textte ...

  9. MeteoInfoLab脚本示例:水汽通量散度计算

    用ncep数据计算水汽通量散度的脚本.需要air, uwnd, vwnd和rhum变量.数据是4维数据,需要固定时间维和高度维,数据中纬度维的数据是反向的,因此读取时需要特殊的设置(::-1).脚本中 ...

  10. 工业级wifi模块

    工业级wifi模块 工业级wifi模块ZLSN7004是上海卓岚开发的一款高性能的Wifi.以太网转串口模块.与普通的wifi模块定位在低成本不同,7004定位在高稳定性.丰富功能,设计目标是面向对功 ...