容器部署MySQL

简介: docker run -d --name mysql --restart always \ -e MYSQL_ROOT_PASSWORD=admin \ -e TZ=Asia/Shanghai -p 3306:3306 \ -v /data/mysql:/var/lib/mysql \ mysql:5.7.31 \ --character-set-server=utf8 \ --collation-server=utf8_general_ci

1673477237447.png

一、镜像准备

mysql镜像下载地址:https://hub.docker.com/_/mysql

这里以下载5.7.31为例

docker pull mysql:5.7.31

下载后可以通过命令查看

docker images

可以将下载好的命令保存为本地文件,方便日后使用,避免重复下载(会保存在当前目录下)

docker save mysql:5.7.31 -o mysql.5.7.31.tar

可以将保存的镜像文件加载

docker load -i mysql.5.7.31.tar

二、一个简单的实例

运行实例

docker run -d --name mysql --restart always \
-e MYSQL_ROOT_PASSWORD=admin \
-e TZ=Asia/Shanghai -p 3306:3306 \
-v /data/mysql:/var/lib/mysql \
mysql:5.7.31 \
--character-set-server=utf8 \
--collation-server=utf8_general_ci

说明:

  • name mysql 指定实例名称 “mysql” 可以根据需要更改
    restart always 容器退出时总是重启容器
    e MYSQL_ROOT_PASSWORD=admin 配置root用户的密码为 “admin”
    e TZ=Asia/Shanghai 设置容器时区为 亚洲/上海
    p 3306:3306 暴露容器的端口给主机,前面是主机端口,后面是容器端口
    v /data/mysql:/var/lib/mysql 容器卷挂载,宿主机的 “/data/mysql” 目录与容器的 "/var/lib/mysql" 挂载
    character-set-server=utf8 --collation-server=utf8_general_ci 设置默认编码格式为utf8,解决中文乱码问题

查看mysql日志

docker logs -f mysql

说明:

  • f 参数持续跟踪日志变化 可以省略
  • mysql 为容器名称,根据实际名称调整

通过shell访问容器内部

docker exec -it mysql bash

通过sql文件初始化数据库

docker exec -i mysql sh -c 'exec mysql -uroot -p"$MYSQL_ROOT_PASSWORD"' < /data/db_backup.sql

三、可能出现的问题

创建mysql容器失败

创建mysql容器成功
docker run --name mysql \
-v /media/yoyo/w/MyDocument/Python_Test_Project/2020_08/20200825/mysql/conf:/etc/mysql/mysql.conf.d \
-v /media/yoyo/w/MyDocument/Python_Test_Project/2020_08/20200825/mysql/data:/var/lib/mysql \
-v /media/yoyo/w/MyDocument/Python_Test_Project/2020_08/20200825/mysql/logs:/logs \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7

可能的原因:

  1. -v 映射宿主的路径太长
  2. 宿主路径权限问题
  3. 如果目录中有文件,第二次创建容器失败

四、Docker创建进入mysql容器

运行”docker pull mysql”获取mysql镜像

[root@localhost ~]# docker pull mysql
Using default tag: latest
latest: Pulling from library/mysql
85b1f47fba49: Pull complete
5671503d4f93: Pull complete
3b43b3b913cb: Pull complete
4fbb803665d0: Pull complete
05808866e6f9: Pull complete
1d8c65d48cfa: Pull complete
e189e187b2b5: Pull complete
02d3e6011ee8: Pull complete
d43b32d5ce04: Pull complete
2a809168ab45: Pull complete
Digest: sha256:1a2f9361228e9b10b4c77a651b460828514845dc7ac51735b919c2c4aec864b7
Status: Downloaded newer image for mysql:latest

在后台启动mysql容器(–name指定了容器的名称,方便之后进入容器的命令行,MYSQL_ROOT_PASSWORD=admin指定了mysql的root密码,-d表示在后台运行)

Administrator@SKY-20170607FIJ MINGW64 ~
$ docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=admin -d mysql
c6215e8c1fd73bc395a0c92e93f7e7145baedbe99c7ff639ccc9f5641bddf583

进入容器bash并进入mysql命令行:

Administrator@SKY-20170607FIJ MINGW64 ~
$ docker exec -it mysql bash
root@c6215e8c1fd7:/# mysql -uroot -padmin
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 5
Server version: 5.7.20 MySQL Community Server (GPL)
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show databases;
Database
information_schema
mysql
performance_schema
sys

4 rows in set (0.00 sec)
mysql>

退出mysql镜像

exit
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
6月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
1026 108
|
6月前
|
运维 监控 数据可视化
小白也能部署应用,3个免费的容器化部署工具测评
本文对比了三款容器化部署工具:Docker Compose、Portainer 和 Websoft9。Docker Compose 适合开发者编排多容器应用,Portainer 提供图形化管理界面,而 Websoft9 则面向中小企业和非技术人员,提供一键部署与全流程运维支持,真正实现“开箱即用”。三款工具各有定位,Websoft9 更贴近大众用户需求。
小白也能部署应用,3个免费的容器化部署工具测评
|
8月前
|
运维 监控 数据可视化
容器化部署革命:Docker实战指南
容器化部署革命:Docker实战指南
|
4月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
636 5
|
4月前
|
存储 关系型数据库 MySQL
MySQL Docker 容器化部署全指南
MySQL是一款开源关系型数据库,广泛用于Web及企业应用。Docker容器化部署可解决环境不一致、依赖冲突问题,实现高效、隔离、轻量的MySQL服务运行,支持数据持久化与快速迁移,适用于开发、测试及生产环境。
773 5
|
8月前
|
存储 运维 安全
Docker化运维:容器部署的实践指南
Docker化运维:容器部署的实践指南
|
6月前
|
运维 数据可视化 C++
2025 热门的 Web 化容器部署工具对比:Portainer VS Websoft9
2025年热门Web化容器部署工具对比:Portainer与Websoft9。Portainer以轻量可视化管理见长,适合技术团队运维;Websoft9则提供一站式应用部署与容器管理,内置丰富开源模板,降低中小企业部署门槛。两者各有优势,助力企业提升容器化效率。
464 1
2025 热门的 Web 化容器部署工具对比:Portainer VS Websoft9
|
5月前
|
存储 Kubernetes 持续交付
为什么Docker容器化改变了开发与部署?
为什么Docker容器化改变了开发与部署?
|
6月前
|
关系型数据库 MySQL 数据库
为什么 MySQL 不推荐用 Docker 部署?
本文探讨了MySQL是否适合容器化的问题,分析了Docker容器在数据安全、性能瓶颈、状态管理及资源隔离等方面的挑战,并指出目前主流分布式数据库如TDSQL和OceanBase仍倾向于部署在物理机或KVM上。
343 0

推荐镜像

更多