前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL容器化详细教程

MySQL容器化详细教程

作者头像
MySQL技术
发布2019-11-12 12:44:12
9670
发布2019-11-12 12:44:12
举报
文章被收录于专栏:MySQL技术MySQL技术

前言:

上篇文章介绍了Docker工具的安装及常用命令使用。本篇文章我们会介绍如何在Docker中运行MySQL实例,可能有的小伙伴会问:为什么要在Docker里运行MySQL呢?因为在Docker里部署MySQL实例操作简单,不需要考虑操作系统等依赖差异,而且可以多实例部署,比如说我们原来服务器有安装MySQL5.7,我们想再运行MySQL8.0实例的话只需要用Docker启动MySQL8.0镜像即可。下面我们就来介绍下如何用Docker启动MySQL实例。

▍1.拉取MySQL官方镜像

在上篇文章中我们介绍过Docker中三个基本的概念:镜像,容器,仓库。要用在Docker中部署MySQL,第一步要做的是从官方仓库中拉取MySQL镜像,这里我们从Docker Hub中拉取MySQL镜像。进入Docker Hub,搜索MySQL,可以看到如下画面,其中有不同版本的镜像及使用介绍。

比如我们想拉取MySQL5.7版本及8.0版本的镜像,可以做如下操作:

代码语言:javascript
复制
# 拉取5.7及8.0版本镜像 稍等片刻即可拉取成功docker pull mysql:5.7.23docker pull mysql:8.0.18
# 查看镜像docker imagesREPOSITORY          TAG                 IMAGE ID            CREATED             SIZEmysql               8.0.18              c8ee894bd2bd        2 weeks ago         456MBmysql               5.7.23              1b30b36ae96a        12 months ago       372MB

其实MySQL官方镜像也存在一些缺陷,比如说时区不是北京时间,系统字符集问题等。下面以MySQL5.7.23版本镜像为基础,展示下如何修改构建镜像。

代码语言:javascript
复制
# 创建Dockerfile 主要作用是更改系统字符集及时区 内容如下:cat Dockerfile FROM mysql:5.7.23MAINTAINER wangRUN echo "alias ls='ls --color=auto'" >> /root/.bashrc \    && ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
ENV LANG=C.UTF-8
# 构建镜像docker build -t my-mysql:5.7.23 . Sending build context to Docker daemon  2.048kBStep 1/4 : FROM mysql:5.7.23 ---> 1b30b36ae96aStep 2/4 : MAINTAINER wang ---> Running in a7cc94f95cc7Removing intermediate container a7cc94f95cc7 ---> d9590ed98de5Step 3/4 : RUN echo "alias ls='ls --color=auto'" >> /root/.bashrc     && ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime ---> Running in e698bfdb3817Removing intermediate container e698bfdb3817 ---> 31c9ed9103c5Step 4/4 : ENV LANG=C.UTF-8 ---> Running in eefa296fef94Removing intermediate container eefa296fef94 ---> 10aa697936e9Successfully built 10aa697936e9Successfully tagged my-mysql:5.7.23
# 再次查看镜像即可找到我们新构建的镜像docker imagesREPOSITORY          TAG                 IMAGE ID            CREATED              SIZEmy-mysql            5.7.23              10aa697936e9        About a minute ago   372MBmysql               8.0.18              c8ee894bd2bd        2 weeks ago          456MBmysql               5.7.23              1b30b36ae96a        12 months ago        372MB
▍2.启动MySQL实例

这里为大家介绍如何利用上面构建的镜像来运行MySQL实例,MySQL容器化其实也需要映射端口,数据持久化,加载配置文件等操作,下面给大家演示下具体启动操作。

2.1.创建数据持久化路径及配置文件

代码语言:javascript
复制
# 创建配置文件目录及数据目录mkdir -p /data/mysql57/{cnf,data}
# 添加配置文件my.cnfcd /data/mysql57/cnf/vim my.cnf
# 配置文件内容如下,可自定义[mysqld]pid-file        = /var/run/mysqld/mysqld.pidsocket          = /var/run/mysqld/mysqld.sockdatadir         = /var/lib/mysql
server-id = 33061max_connections = 1000sql_mode = NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTIONlower_case_table_names=1innodb_file_per_table = 1log_timestamps=SYSTEMcharacter-set-server = utf8max_allowed_packet = 32Msort_buffer_size = 4Mread_buffer_size = 4Mjoin_buffer_size = 4Mbinlog_cache_size = 4Mtmp_table_size = 96Mmax_heap_table_size = 96Minnodb_buffer_pool_size = 512M
#logsslow_query_log = 1slow_query_log_file = /var/lib/mysql/slow.loglong_query_time = 3log-bin = /var/lib/mysql/binlogbinlog_format = rowexpire_logs_days = 15log_bin_trust_function_creators = 1

2.2.docker run运行MySQL实例

代码语言:javascript
复制
# 一条命令启动一个MySQL实例docker run -itd -p 33061:3306 --name mysql57 --hostname=mysql57 -v /data/mysql57/cnf:/etc/mysql -v /data/mysql57/data:/var/lib/mysql --privileged=true -e MYSQL_ROOT_PASSWORD=Asdf@123456  my-mysql:5.7.23
# 解释下各个参数的含义-d: 后台运行容器,并返回容器ID-i: 以交互模式运行容器,通常与 -t 同时使用-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用-p: 指定端口映射,格式为:主机(宿主)端口:容器端口--name="mysql57": 为容器指定一个名称--hostname=mysql57: 指定容器的hostname-v: 绑定一个卷--privileged=true: 以特权方式启动容器

2.3.检查容器状态

代码语言:javascript
复制
# 查看容器状态docker psCONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                                NAMES04cd3d99d5cb        my-mysql:5.7.23     "docker-entrypoint.s…"   13 seconds ago      Up 11 seconds       33060/tcp, 0.0.0.0:33061->3306/tcp   mysql57
# 进入容器内docker exec -it mysql57 /bin/bash 或 docker exec -it [CONTAINER ID] /bin/bash
▍3.其他相关操作

到此为止,我们已经在Docker中成功运行了MySQL实例,其实还没有结束,还有好多操作还没讲,比如如何备份恢复,怎么更改配置等,下面简单介绍下这类相关操作。

  • 备份恢复
代码语言:javascript
复制
# 备份docker exec mysql57 sh -c 'exec mysqldump --all-databases -uroot -p"$MYSQL_ROOT_PASSWORD"' > /tmp/all-databases.sql
# 恢复docker exec -i mysql57 sh -c 'exec mysql -uroot -p"$MYSQL_ROOT_PASSWORD"' < /tmp/all-databases.sql
  • 更改配置
代码语言:javascript
复制
# 更改配置只需要修改宿主机 /data/mysql57/cnf/my.cnf 文件,然后重启容器即可docker restart mysql57

如果你想在本地通过工具连接容器内MySQL的话,可以使用宿主机ip加映射端口来连接。比如我们上面创建的MySQL实例就可以通过宿主机ip+30661端口来连接,若无法连接请检查网络及服务器防火墙。

总结:

本文主要介绍在Docker中部署MySQL的方法步骤,体验下来你会发现非常简单方便,而且可以大规模多实例部署。假如你想体验最新版本8.0.18的话,可以自己部署下试试看,其实还可以更简单,比如说直接运行docker run mysql:5.7.23 即可启动一个实例,但是为了更加规范,还是建议将配置文件及数据目录都挂载到宿主机本地。

参考资料:

  • https://hub.docker.com/_/mysql
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-11-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 MySQL技术 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • ▍1.拉取MySQL官方镜像
  • ▍2.启动MySQL实例
  • ▍3.其他相关操作
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档