写点什么

使用 Docker 过程中必须注意到的七件事

  • 2020-03-12
  • 本文字数:1845 字

    阅读完需:约 6 分钟

使用Docker过程中必须注意到的七件事

本人以技术栈 Redis 为例,列举并解释了一些面向 Docker 进行应用程序开发和系统搭建中所需要注意的问题和技巧,以及 Caicloud 平台在 Docker 管理和帮助企业应用向 Docker 转化中的作用。由于应用程序千差万别,应用场景层出不穷,本文仅起到抛砖引玉的作用。


我们总结基于 Docker 的 Redis 组件的使用注意事项如下:



(图片来源于网络)


## Redis的外部存储挂载 1.Persistence被开启:无论是RDB还是AOF模式,都会需要在硬盘上进行存储。以RDB为例,会自动存在本地硬盘一个叫dump.rdb的文件。如果没有挂载外部存储,这些数据在docker销毁后会消失。2.主从设置下Replication对硬盘的需求:在Redis 2.8以前,Master与Slave的同步需要用存储(硬盘)作为中间媒介(自2.8此同步可不经过硬盘,但还属于试验内容)。在Docker环境下需要挂载Volume以保证这个步骤能正常运行。

Redis 不能跑在 daemonize 的模式

Docker 的容器需要其中的主进程一直在前端运行,使用 daemonize 的模式会使得 container 在运行后立即退出。幸运的是在 Redis 的配置文件中 daemonize 模式默认被关闭。如需运行 daemon 模式,应该在 docker 层面通过-d 命令来进行。

Redis 的日志文件目录应置为空

Docker 的容器所产生的日志会被系统自动接收和管理;同时 Caicloud 的集群管理平台更会监测和聚合系统中所有容器的日志。因此在配置文件中将 logfile 设为空会享受 Docker 和 Caicloud 的自动日志收集和管理。

Redis Snapshot 的注意事项

1、在主从结构下 Snapshot 应开启:如果在 Redis 的 Master 节点上配置了 Persistenceoff (数据不会自动存储到硬盘上),那么我们同时还应该关掉 Master 节点的自动重启功能。由于 Caicloud 的自动修复功能会重启实效的容器(包括 RedisMaster),我们应开启 Snapshot 功能。


2、对 Persistence 的需求:Redis 会把 Snapshot 产生的 rdb 文件写在指定的目录中。默认情况下这个对应在 Docker 内部的一个目录,会随着 Docker 的销毁而销毁。如果有 Persistence 的需求,应该在生成 Dockerfile 和运行 Redis 容器时同时挂载外部的存储。

Redis 的端口映射

Docker 的容器在运行时默认会将容器内的应用端口映射成一个随机的主机端口,但这样会打破一些 Redis 服务。比如 sentinel 需要根据默认端口规则 (26379) 来进行自动发现。因此在 Docker 下运行 Redis 一定要使用 –p port:port 的格式来明确使用默认的 Redis 端口规则。

Redis 主从结构中的 Master 节点的发现

在主从结构中,从节点(slave)需要在配置文件中使用 Master 节点的 IP,来实现与 Master 节点的互连。传统架构中这个 IP 可以预先通过静态绑定。在 Caicloud 体系中,系统不需要静态绑定具体的 IP 地址,而是可以通过 DNS 动态地发现,并通过运行 Docker 时的 CMD 命令来使用特定的脚本将 Master IP 动态添加到配置中。

多个 Redis 集群共存的情况

Caicloud下不会出现两个Redis Cluster混为一起的情况,因为 Caicloud 的独特网络特性(扁平化,每个机器有自己的网段)。如例子中提到的两个 Redis 集群混在一起需要如下条件:


  • 在某一个物理机上运行来自两个 Redis 集群的 server 实例(from cluster A and cluster B);

  • 在两个 Redis 集群中存在两个 server 实例(from cluster A and cluster B)碰巧有同样的 IP(在纯 Docker 环境下有可能,因为每个主机上的 Docker 会随机分配网段和 IP)

  • 在 Caicloud 环境下,每个 Redis server 都会被分配一个不同的 IP,每两个 Redis server 的 IP 必定不相同(每个机器有自己的网段,所以不同机器上的 Docker 在给 container 分配地址的时候不会撞车)。


本文转载自才云 Caicloud 公众号。


原文链接:https://mp.weixin.qq.com/s/EVy2Vg9Zhe3DRd4LQj-usg


2020-03-12 22:54670

评论

发布
暂无评论
发现更多内容

一文简述:钓鱼攻击知多少

穿过生命散发芬芳

6月月更 钓鱼攻击

华为云如何实现实时音视频全球低时延网络架构【上】

坚果

6月月更

为 Serverless Devs 插上 Terraform 的翅膀,解耦代码和基础设施,实现企业级多环境部署(下)

阿里巴巴云原生

阿里云 开源 云原生 Serverless Devs

华为云招募工业智能领域合作伙伴,强力扶持+商业变现

华为云开发者联盟

云计算 华为云 工业数据智能

如何做好研发效能度量及指标选取

思码逸研发效能

研发效能

博睿数据出席阿里云可观测技术峰会,数字体验管理驱动可持续发展

博睿数据

可观测性 智能运维 博睿数据 数字体验管理

年中大促 | 集成无忧,超值套餐 6 折起

融云 RongCloud

支持在 Kubernetes 运行,添加多种连接器,SeaTunnel 2.1.2 版本正式发布!

Apache SeaTunnel

Apache 大数据 开源 workflow

预约直播|机器学习PAI:AI加速计划

阿里云大数据AI技术

AI 模型开发训练

如何给研发团队分钱?

菜根老谭

研发体系 绩效管理 激励体系

一张图解码 OpenCloudOS 社区开放日

腾源会

[译]关于 Python 中的数字你可能不知道的 3 件事

宇宙之一粟

Python 6月月更

如何低成本快速搭建企业知识库?

小炮

Fegin的解析

卢卡多多

OpenFegin 6月月更

5分钟快速上线Web应用和API(Vercel)

Liam

前端 前端开发 开发 Postman API

C语言字符串与内存库函数的介绍与模拟实现

未见花闻

6月月更

axios(二)

小恺

6月月更

关河因果将机器学习融合逻辑规则,突破黑盒壁垒

6979阿强

数据分析 大数据分析 关河因果 关河智图 因果分析

活动预约|阿里云如何搭建云服务 SRE 与可观测体系

阿里巴巴云原生

阿里云 云原生 可观测 峰会

物联网开源开发平台 Shifu 开放内测!第一版技术文档发布

亚马逊云科技 (Amazon Web Services)

物联网 Tech 专栏

如何在物联网低代码平台中使用数据字典功能?

AIRIOT

物联网 低代码平台

数据库每日一题---第20天:按日期分组销售产品

知心宝贝

数据库 程序员 前端 后端 6月月更

万字攻略,详解腾讯面试(T1-T9)核心技术点,面试题整理

C++后台开发

后台开发 面试题 Linux服务器开发 C++后台开发 腾讯面试

学习 | 写论文看这一篇就够了~

写程序的小王叔叔

学习笔记 论文阅读 论文写作 6月月更

数据科学家是不是特有前途的职业?

袁袁袁袁满

再读凤凰架构-分布式架构更清晰

AiDaddy

分布式 凤凰架构

51万奖池邀你参战!第二届阿里云ECS CloudBuild开发者大赛来袭

阿里云弹性计算

阿里云 分布式缓存 开发者大赛 加密计算 大数据加速

数字经济加速落地,能为中小企业带来什么?

脑极体

使用GetX构建更优雅的Flutter页面结构

岛上码农

flutter ios 前端 安卓开发 6月月更

网页制作存在的一些难点

源字节1号

详解openGauss多线程架构启动过程

华为云开发者联盟

数据库 后端

使用Docker过程中必须注意到的七件事_语言 & 开发_才云科技_InfoQ精选文章