程序员小李:"老王,我有个问题想请教您。MySQL 能不能部署在 Docker 里?我听说很多人说不行,性能会有瓶颈。"
架构师老王:"摸摸自己光突突的脑袋, 小李啊,这个问题可不简单。以前确实很多人说不行,但现在技术发展这么快,情况可能不一样了。"
小李:"那您的意思是,现在可以了?"
老王:"也不能这么说。性能、数据安全、运维复杂度,这些都是需要考虑的。不过,已经有不少公司在生产环境里用 Docker 跑 MySQL 了,效果还不错。"
Docker(鲸鱼)+MySQL(海豚)到底如何,我们来具体看看:

一、业界大厂
我们来看看业界使用情况:
1.1、京东超70%的MySQL在Docker中

刘风才是京东的资深数据库专家,他分享了京东在MySQL数据库Docker化方面的实践经验。京东从最初的小规模使用,到现在超过70%的MySQL数据库 运行在Docker容器中。
当然京东也不是所有的业务都适合把 mysql 部署在 docker 容器中。比如,
刘风才演讲中也提出:数据文件多于1T多的情况下是不太合适部署在Docker上的;再有就是在性能上要求特别高的,特别重要的核心系统目前仍跑在物理机上,后面随着Docker技术不断的改进,会陆续地迁到Docker上。
1.2、 同程艺龙:大规模 MySQL 容器化实践

同程艺龙的机票事业群 CTO 王晓波在QCon北京2018大会上做了《MySQL的Docker容器化大规模实践》的主题演讲。他分享了同程艺龙如何大规模实践基于Docker的MySQL私有云平台,集成了高可用、快速部署、自动化备份、性能监控等多项自动化运维功能。该平台支撑了总量90%以上的MySQL服务(实际数量超过2000个),资源利用率提升了30倍,数据库交付能力提升了70倍,并经受住了业务高峰期的考验。
当然不仅仅是京东、同程像阿里云、腾讯、字节、美团等都有把 Mysql 部署在 Docker 容器中的案例。
二、官方情况
MySql 官方文档提供了 mysql 的 docker 部署方式,文档中并没有明确的表明这种方式是适用于开发、测试或生产。那就是通用性的,也就是说生产也可以使用。
以下就是安装的脚本可以看到配置文件和数据都是挂载到宿主机上。
typescript
docker run --name=mysql1 \
--mount type=bind,src=/path-on-host-machine/my.cnf,dst=/etc/my.cnf \
--mount type=bind,src=/path-on-host-machine/datadir,dst=/var/lib/mysql \
-d container-registry.oracle.com/mysql/community-server:tag
再看看镜像文件,可以看到 oralce 官方 7 年前就发布了 mysql5.7 的镜像。

三、具体分析
反方观点:生产环境MySQL不该部署在Docker里
反方主要担心数据持久化、性能、复杂性、备份恢复和安全性等问题,觉得在Docker里跑MySQL风险挺大。
正方观点:生产环境MySQL可以部署在Docker里
正方则认为Docker的灵活性、可移植性、资源隔离、自动化管理以及社区支持都挺好,生产环境用Docker部署MySQL是可行的,而且有成熟的解决方案来应对数据持久化和性能等问题。
总结
争议的焦点主要在于Docker容器会不会影响性能。其实 Docker和虚拟机不一样,虚拟机是模拟物理机硬件,而Docker是基于Linux内核的cgroups和namespaces技术,实现了CPU、内存、网络和I/O的共享与隔离,性能损失很小。

Docker 和传统虚拟化方式的不同之处,在于 Docker 是在操作系统层面上实现虚拟化,直接复用本地主机的操作系统,而传统方式则是在硬件层面实现。
Docker的特点:
- 轻量级:共享宿主机内核,启动快,资源占用少。
- 隔离性:容器之间相互隔离,不会互相干扰。
- 可移植性:容器可以在任何支持Docker的平台上运行,不用改代码。
四、结尾
Docker虚拟化操作系统而不是硬件
随着技术的发展,Docker在数据库部署中的应用可能会越来越多。
所以,生产环境在Docker里部署MySQL,虽然有争议,但大厂都在用,官方也支持,技术也在不断进步,未来可能是个趋势。
我是栈江湖,如果你喜欢此文章,不要忘记点赞+关注!