使用docker 部署codis
使用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的更多相关文章
- ASP.NET Core开发-Docker部署运行
ASP.NET Core开发Docker部署,.NET Core支持Docker 部署运行.我们将ASP.NET Core 部署在Docker 上运行. 大家可能都见识过Docker ,今天我们就详细 ...
- Docker部署Hadoop集群
Docker部署Hadoop集群 2016-09-27 杜亦舒 前几天写了文章"Hadoop 集群搭建"之后,一个朋友留言说希望介绍下如何使用Docker部署,这个建议很好,Doc ...
- 程序开发使用docker部署
我们公司自己研发了一套 grand-line 系统,使用 docker 来部署项目. 我是第一批小白鼠,一开始网络差,build 一次要半个小时,连接进入 web shell 也很慢,部署一个微信项目 ...
- 我使用celery以及docker部署遇到的问题
首先我本机测试时没有问题的,但是在线上docker中,任务一直显示 "Sending due task".超时的任务是 django orm update 操作,本地不会出现这样的 ...
- Docker部署SDN环境
2014-12-03 by muzi Docker image = Java class Docker container = Java object 前言 5月份的时候,当我还是一个大学生的时候,有 ...
- 在生产环境使用Docker部署应用
导读 Docker现在越来越流行,但是真正在生产环境部署Docker还是个比较新的概念,还没有一个标准的流程.作者是ROR的程序员,作者结合平时的部署经验,联系Docker的特点,向大家分享了其在生产 ...
- Docker 使用指南 (六)—— 使用 Docker 部署 Django 容器栈
版权声明:本文由田飞雨原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/98 来源:腾云阁 https://www.qclou ...
- NET Core Docker部署
NET Core Docker部署 前言 在前面文章中,介绍了 ASP.NET Core在 macOS,Linux 上基于Nginx和Jexus的发布和部署,本篇文章主要是如何在Docker容器中运行 ...
- 我使用 Docker 部署 Celery 遇到的问题
问题1 - Sending due task 本机测试时没有问题的,但是在线上 docker 中,任务一直显示 "Sending due task".超时的任务是 Django O ...
随机推荐
- 在uniapp或者vue中单行文字或者符号无法换行的终极解决方案
在VUE开发过程中,会出现比较诡异的情况. 比如常规的英文或中文显示都是很正常的,但是当出现了一些中文符号(比如,!等等)在文末的时候,总是会超出view的显示区域. 那么在遇到上面这种问题我们记得检 ...
- day63:Linux:nginx基础知识&nginx基础模块
目录 1.nginx基础知识 1.1 什么是nginx 1.2 nginx应用场景 1.3 nginx组成结构 1.4 nginx安装部署 1.5 nginx目录结构 1.6 nginx配置文件 1. ...
- vue-integer-plusminus
下载 vue-integer-plusminusvue-integer-plusminus 带有递增和递减按钮的整数输入 现场演示 该组件适合作为自旋按钮,允许键盘功能(向上/向下箭头或页面向上/向下 ...
- day26 Pyhton 面向对象复习
一 class 类名(): pass 对象 object 对象 = 类名() class Person: pass print(Person)#<class '__main__.Person'& ...
- Jmeter之参数化函数助手__randomstring
1.Tools->函数助手对话框,选择__Random String,2表示随机生成的字符长度:3表示从哪些字符中随机生成:然后点击生成,得到对应的变量: 5中372表示该函数随机生成的字符串, ...
- 【编程学习笔记】如何组织构建多文件 C 语言程序!编程也有~
优秀 Unix 程序哲学 首先,你要知道这个 C 程序是一个 Unix 命令行工具.这意味着它运行在(或者可被移植到)那些提供 Unix C 运行环境的操作系统中.当贝尔实验室发明 Unix 后,它从 ...
- logstash-安装
1.下载 cd /usr/local/src wget https://mirrors.huaweicloud.com/logstash/7.8.0/logstash-7.8.0.tar.gz ...
- linux(centos8):firewalld的运行时日志配置
一,firewalld配置日志的用途: 在生产环境中,firewalld的默认配置是不记录日志 我们通过日志记录下防火墙过滤时拒绝的非法ip, 可以主动把这些有攻击性的ip加入到黑名单, 防患于未然 ...
- Nexus 安装教程
Nexus 安装教程 一. CentOS设置 1. 更换阿里源 curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/ ...
- JAVA 基于Jusup爬虫
java爬虫核心:httpclient slf4j jsoup slf4j 配置文件log4j.properties log4j.rootlogger=DEBUG,A1log4j.logger.cn. ...