写点什么

使用 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:54708

评论

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

Dr-autosync TiDB 集群的计划内和计划外切换验证步骤

TiDB 社区干货传送门

实践案例 集群管理 安装 & 部署 数据库架构选型 6.x 实践

【分布式技术专题】「分布式技术架构」一文带你厘清分布式事务协议及分布式一致性协议的算法原理和核心流程机制(Paxos篇)

码界西柚

分布式 PAXOS paxos协议 算法分析

文盘Rust -- 安全连接 TiDB/Mysql

TiDB 社区干货传送门

开发语言

TiDB SQL调优案例之避免TiFlash帮倒忙

TiDB 社区干货传送门

性能调优 实践案例 故障排查/诊断

基于 Apache Flink 的实时计算数据流业务引擎在京东零售的实践和落地

Apache Flink

大数据 flink 实时计算

TiDB容器化的管理利器--TiDB Operator

TiDB 社区干货传送门

集群管理 新版本/特性发布 安装 & 部署 新版本/特性解读

你可能并不了解 Milvus

Zilliz

SaaS Milvus 社区活动

云数据库TiDB免费试用初体验

TiDB 社区干货传送门

版本测评 安装 & 部署

深入理解spring mvc启动过程与原理

三十而立

Java spring 程序员 开发 IT

国家高新技术企业是国企吗?获得高新企业证书有什么用?

行云管家

高新企业 高新技术

基于 TiCDC 的 TiDB 复制集群的计划内和计划外切换验证步骤

TiDB 社区干货传送门

性能调优 实践案例 故障排查/诊断 数据库架构选型

TiCDC 源码解读(6)- TiCDC Puller 模块介绍

TiDB 社区干货传送门

TiDB 源码解读 TiCDC 源码解读

手把手教你写spring boot starter

三十而立

Java 程序员 IT springboot boot

面试没有分库分表经验,就看这篇

三十而立

Java sql 程序员 IT 分库

搭建阿里云 TiDB 的灾备,让我安欣睡个好觉

TiDB 社区干货传送门

实践案例 安装 & 部署 备份 & 恢复 数据库架构设计

基于阿里云数据库TiDB的性能压测初体验

TiDB 社区干货传送门

性能测评 6.x 实践

pytest学习和使用1-pytest安装和版本查看

Python 自动化测试 pytest

pytest学习和使用2-初步使用和用例运行

Python 自动化测试 pytest

武汉等保测评有限公司有哪几家?具体位于哪里?

行云管家

等保 等保测评 等保2.0 武汉

TiCDC 源码解读(5)-- TiCDC DDL 事件处理逻辑 与 Filter 实现介绍

TiDB 社区干货传送门

TiCDC 源码解读

将TiDB各服务组件混布到物理机集群和K8S环境

TiDB 社区干货传送门

实践案例 集群管理 管理与运维 安装 & 部署 数据库架构设计

BSN-DDC基础网络详解(五):接入DDC网络(2)

BSN研习社

BSN-DDC基础网络

Java 8 的异步利器:CompletableFuture源码解析(建议精读)

Java你猿哥

Java ssm java8 源码解析

温湿度计设备通过阿里云IoT物联网套件上报数据到钉钉群机器人实践——数据价值类

阿里云AIoT

JavaScript Serverless 物联网 机器人 机器学习/深度学习

监控告警处理之tidb_server_critical_error_total

TiDB 社区干货传送门

监控 故障排查/诊断

Apache APISIX 3.2.0 LTS 正式发布

API7.ai 技术团队

快速尝鲜:RabbitMQ 搭建完就得用起来

Java你猿哥

Java Spring Boot ssm RabbitMQ

1个案例读懂——游戏产品如何用A/B测试做增长

字节跳动数据平台

云服务 AB testing实战 A/B测试 企业号 3 月 PK 榜

NFTScan 与 UniPass 达成合作伙伴,双方在多链 NFT 数据方面展开合作!

NFT Research

NFT

携程 x TiDB丨应对全球业务海量数据增长,一栈式 HTAP 实现架构革新

TiDB 社区干货传送门

设计消息队列存储消息数据的 MySQL 表格

Geek_7d539e

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