【docker】基于Dockerfile构建mysqld服务镜像

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

一 创建构建目录结构

    # mkdir  -pv docker/mysql# cd docker/mysql/

二 写Dockerfile 文件

     # vim  Dockerfile  
     #此处sshd:latest 为上篇文章中创建的镜   
     FROM sshd:latestMAINTAINER mykernel(www.mykernel.cn)
     
     #安装软件 
     RUN ENV DEBIAN_FRONTEND noninteractive apt-get update && \
     apt-get -yq install mysql-server-5.6 pwgen && \
     rm -rf /var/lib/apt/lists/*
     
     # 删除预安装的数据库文件
     RUN rm -rf /var/lib/mysql/*
     
     # 添加文件夹下的 MYSQL 配置文件
     ADD my.cnf /etc/mysql/conf.d/my.cnf
     ADD mysqld_charset.cnf /etc/mysql/conf.d/mysqld_charset.cnf
     ADD authorized_keys /root/.ssh/authorized_keys
     
     # 添加 MYSQL 的脚本
     ADD import_sql.sh /import_sql.sh
     ADD run.sh /run.shRUN chmod 755 /*.sh
     
     # 设置环境变量,用户名以及密码
     ENV MYSQL_USER adminENV MYSQL_PASS **Random**
     
     # 设置主从复制模式下的环境变量
     ENV REPLICATION_MASTER **False**
     ENV REPLICATION_SLAVE **False**
     ENV REPLICATION_USER replica
     ENV REPLICATION_PASS replica
     
     # 设置可以允许挂载的卷,可以用来备份数据库和配置文件
     VOLUME  ["/etc/mysql", "/var/lib/mysql"]
     
     # 设置可以映射的端口,如果是从我们的 sshd 镜像继承的话,默认还会开启 22 端口
     EXPOSE 3306
     
     CMD ["/run.sh"]

三 准备Dockefile中需要的ADD的文件

     # touch my.cnf  mysqld_charset.cnf  authorized_keys   import_sql.sh run.sh

(1)my.cnf为mysql运行时候的主配置文件,需要根据自己的实际情况进行书写
(2)mysqld_charset.cnf为mysql运行时候的字符配置,需要根据自己的实际情况进行书写
(3) import_sql.sh
(4)run.sh 此处提供带主从复制和自定义密码的run文件

四 创建镜像

     # docker build -t mysql:first  .

五 测试

     # sudo docker run -d -p 1027:22 -p 1026:3306 --name mysql mysql:first

通过xshell 连接进容器,查看服务器是否启动;此处直接使用mysql命令,便可以以root的身份进入,配置好相关用户之后使用关闭容器,docker commit进行提交。
通过mysql默认的用户名和用户密码远程连接mysqld 测试,默认用户为admin密码可以使用docker logs mysql查看。admin用户具有root的所有权限。

说明:每次如果是使用-P选项启动容器,每次stop容器之后再start,端口将会发生变化,所以建议使用-p指定固定的端口。可以减少修改iptables规则或者云服务器的安全策略

六 挂载mysql数据卷

     # docker run -d -P -v  /mydata/mysql:/var/lib/mysql  mysql:first

其实mysql的dockerfile文件中已经使用了VOLUME 指令为容器创建一个一直有效的空间(不会因为删除容器而被删除),但是这个空间是新创建的,而且物理机上命令比较复杂。此处可以直接使用-v选项挂载一个宿主机现在的目录,而且容器可以直接访问该目录下的所有数据。

七 设置mysql默认用户的密码

默认的mysql密码在启动容器之后使用docker logs |查看。修改默认用户(admin)的密码:

     # docker run -d -P -e MYSQL_PASS="your_pass"   mysql:first

-e参数可以来设定容器内任意的环境变量。甚至覆盖已经存在的环境变量,或者是在Dockerfile中通过ENV设定的环境变量。

八 启用主从模式

创建mysql主容器

     # docker run -d -e REPLICATION_MASTER=true -P -name mysql:first

创建mysql从容器(–link name:alias)

     # docker run -d -e  REPLICATION_SLAVE=true --link mysql:mysql mysql:first

注意:此处主容器的–name必须为mysql,否则会报错。



本文转自 Mr_sheng 51CTO博客,原文链接:http://blog.51cto.com/sf1314/2047686

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1天前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第20天】 在微服务架构日益普及的今天,Docker作为其重要的实现技术之一,承载着大量应用的运行。然而,随之而来的是对于容器健康状态、资源使用情况以及性能指标的监控需求急剧增加。本文旨在探讨构建一个高效且稳定的Docker容器监控体系,不仅涵盖了监控工具的选择与配置,还详细阐述了监控数据的分析与处理流程。通过精心设计的监控策略和实时响应机制,我们能够确保系统的稳定性,并及时发现及处理潜在的问题。
|
4天前
|
Kubernetes 持续交付 Docker
构建高效微服务架构:Docker与Kubernetes的完美搭档
【5月更文挑战第17天】在当今云计算和微服务架构的大潮中,Docker容器化技术和Kubernetes容器编排系统成为了后端开发领域的热门技术栈。本文将探讨如何通过Docker和Kubernetes的结合使用来构建一个高效、可扩展且易于管理的微服务环境。我们将从基础概念出发,深入到实际操作层面,最后讨论这种组合对持续集成和持续部署(CI/CD)流程的影响,旨在为开发者和企业提供一种可靠的后端服务解决方案。
|
4天前
|
存储 Linux Docker
CentOS7修改Docker容器和镜像默认存储位置
CentOS7修改Docker容器和镜像默认存储位置
|
6天前
|
存储 前端开发 JavaScript
基于 GitHub Workflow和 Docker 构建 NextJS
基于 GitHub Workflow和 Docker 构建 NextJS
9 0
|
6天前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第14天】 在现代微服务架构中,Docker容器作为应用部署的基本单元,其运行状态的监控对于保障系统稳定性和性能至关重要。本文将探讨如何构建一个高效且稳定的Docker容器监控体系,涵盖监控工具的选择、关键指标的采集、数据可视化以及告警机制的设计。通过对Prometheus和Grafana的整合使用,实现对容器资源利用率、网络IO以及应用健康状态的全方位监控,确保系统的高可用性和故障快速响应。
|
6天前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第13天】在微服务架构和容器化部署日益普及的背景下,对Docker容器的监控变得尤为重要。本文将探讨一种构建高效稳定Docker容器监控体系的方法,通过集成Prometheus和cAdvisor工具,实现对容器资源使用情况、性能指标和运行状态的实时监控。同时,结合Grafana进行数据可视化,为运维人员提供直观的分析界面,以便及时发现和解决潜在问题,保障系统的高可用性和稳定性。
31 6
|
6天前
|
运维 安全 API
构建高效自动化运维体系:Ansible与Docker的协同实践
【5月更文挑战第13天】在现代IT基础设施管理中,自动化运维已成为提升效率、确保一致性和降低人为错误的关键。本文通过深入探讨Ansible和Docker的集成实践,揭示了如何构建一个灵活、可扩展且高效的自动化运维体系。我们将从理论到实践,展示如何利用这两种技术实现自动化部署、管理和扩展应用服务,以及它们如何帮助运维团队应对快速变化的业务需求和复杂的IT环境。
31 1
|
6天前
|
存储 安全 开发者
如何删除 Docker 镜像、容器和卷?
【5月更文挑战第11天】
25 2
如何删除 Docker 镜像、容器和卷?
|
6天前
|
存储 Apache Swift
无限套娃_docker入门(镜像、容器、仓库)
无限套娃_docker入门(镜像、容器、仓库)
36 0
|
6天前
|
安全 JavaScript Docker
修改docker镜像版本,容器大小缩小10%!
`shigen`,一位专注于Java、Python、Vue和Shell的博主,分享其通过修改Docker镜像版本实现容器瘦身的技巧。将服务从`1.0.0`更新至`1.0.1`,基于Alpine版Docker镜像,容器体积减小至原来的10%。文章展示了问题背景、选择轻量级镜像的原因及步骤,包括Docker镜像版本对比、构建和启动新容器的过程,并证实功能未受影响。`file-server`更新将发布在GitHub上,期待用户试用。一起学习,每天进步!
35 2
修改docker镜像版本,容器大小缩小10%!