Docker中MySQL的安装与实践

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL 是世界上最受欢迎的开源数据库。凭借其可靠性、易用性和性能,MySQL 已成为 Web 应用程序的数据库优先选择。我们在写 Demo 项目或者学习的时候,都经常会使用到 MysQL 数据库或集群,使用 Docker 能方便随时随地的搭建数据库环境。


一、MySQL 镜像下载



1. 查找 MySQL 镜像


登录 Docker Hub 官网搜索 MySQL 镜像,或者直接访问 https://hub.docker.com/_/mysql

也可以在终端使用docker search mysql来搜索 MySQL 镜像,OFFICAL 列为 OK 的为官方镜像。


2. 下载MySQL镜像


从 Docker Hub 拉取 MySQL 5.7 镜像,命令如下:

$ docker pull mysql:5.7

使用docker pull mysql:来指定下载镜像的 tag,不指定默认为 latest。下载完成后使用docker images来查看本地已经下载好的镜像。

$ docker images
REPOSITORY    TAG    IMAGE ID    CREATED    SIZE
mysql       5.7    718a6da099d8  3 weeks ago  448MB


二、MySQL 容器运行



安装完成后,可以使用docker run 命令来运行 MySQL 容器。


1. 配置端口映射


$ docker run --name mysql -p 3306:3306 -d mysql:5.7
8c3026a0acd14f53e702a9854b2ffe4aa2668a552e11e171b3ae667cbe691d31


  • --name:指定容器名称,方便对容器的操作
  • -p ::指定端口映射,将容器的端口映射到主机的端口
  • -d:指定容器在后台运行,以守护进程的形式运行
  • 8c3026a...:容器ID,对容器进行操作时用于指定容器

运行成功后可以使用下面命令查看运行中的 MySQL 容器:

# 查看运行中的容器
$ docker ps # 或 docker container ls
CONTAINER ID    IMAGE    COMMAND    CREATED    STATUS    PORTS    NAMES
# 查看所有容器
$ docker ps -a # 或 docker container ls -a
CONTAINER ID    IMAGE    COMMAND           CREATED      STATUS        PORTS    NAMES
1280ffeb3616    mysql:5.7  "docker-entrypoint.s…"   52 seconds ago  Exited (1) 50 seconds ago      mysql

我们发现没有运行成功的容器,再使用docker ps -a命令查看所有容器,查看STATUS列发现容器状态为已经退出。此时使用docker logs mysql来查看容器运行的日志来找出问题:

$ docker logs mysql
2020-08-30 03:25:12+00:00 [Note] [Entrypoint]: Entrypoint script for MySQL Server 5.7.31-1debian10 started.
2020-08-30 03:25:12+00:00 [Note] [Entrypoint]: Switching to dedicated user 'mysql'
2020-08-30 03:25:12+00:00 [Note] [Entrypoint]: Entrypoint script for MySQL Server 5.7.31-1debian10 started.
2020-08-30 03:25:12+00:00 [ERROR] [Entrypoint]: Database is uninitialized and password option is not specified
        You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD

日志提示我们需要指定一个MYSQL_ROOT_PASSWORDMYSQL_ALLOW_EMPTY_PASSWORDMYSQL_RANDOM_ROOT_PASSWORD的环境变量来作为数据库 root 用户的密码。


2. 配置环境变量


移除刚才运行失败的容器,并指定环境变量重新运行:

# 移除容器
$ docker container rm mysql
mysql
# 指定端口映射和环境变量运行
$ docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
bdfa70905470e241daaf9fcd332c957550e24b10b74c4a2232001c79e3dae898


  • -e key=value:用于指定容器中系统的环境变量

此时使用docker ps查看容器已经运行成功了,接下来我们可以使用 MySQL 数据库客户端来连接使用了。使用下面命令,并输入我们刚才配置的密码,就可以进入数据库了。

$ mysql -h 127.0.0.1 -u root -p

微信图片_20220519203134.png


3. 查看数据卷


在 Docker 中,MySQL 数据库的数据持久化是通过创建数据卷来实现的,也就是说所有在数据库中存储的数据,都会保存在主机上,使用下面命令来查看数据卷详情:

# 查看数据卷
$ docker volume ls
DRIVER    VOLUME NAME
local      b25a62989527e7b0c9113300cdde9fb26354d96c863e942712d02dc2756c80ca
# 查看数据卷详情 
$ docker inspect b25a62989527e7b0c9113300cdde9fb26354d96c863e942712d02dc2756c80ca
[
    {
        "CreatedAt": "2020-08-30T11:35:15+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/b25a62989527e7b0c9113300cdde9fb26354d96c863e942712d02dc2756c80ca/_data",
        "Name": "b25a62989527e7b0c9113300cdde9fb26354d96c863e942712d02dc2756c80ca",
        "Options": null,
        "Scope": "local"
    }
]
# 查看数据卷绑定的主机目录
$ sudo ls /var/lib/docker/volumes/b25a62989527e7b0c9113300cdde9fb26354d96c863e942712d02dc2756c80ca/_data
auto.cnf    client-cert.pem    ib_logfile0    ibtmp1    private_key.pem    server-key.pem
ca-key.pem    client-key.pem    ib_logfile1    mysql public_key.pem    sys
ca.pem    ib_buffer_pool    ibdata1    performance_schema    server-cert.pem

从上面的操作可以看出,数据库数据实际保存的位置在主机的目录下,这样就可以实现 MySQL 容器的数据持久化了。

使用 Docker 搭建数据库环境,不管是单节点还是集群,只需要很简单的操作就能实现,再也不用担心虚拟机消耗太多的电脑资源,也不用担心环境之间有什么差异,因此,我们在学习过程中,只需要关注知识点功能的实现。


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
4天前
|
消息中间件 Kafka Docker
docker compose 安装 kafka
通过本文的步骤,您可以快速在本地使用 Docker Compose 安装并配置 Kafka 和 Zookeeper。Docker Compose 简化了多容器应用的管理,方便快速搭建和测试分布式系统。
33 2
|
5天前
|
监控 Linux PHP
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
54 20
|
6天前
|
Ubuntu API 网络虚拟化
ubuntu22 编译安装docker,和docker容器方式安装 deepseek
本脚本适用于Ubuntu 22.04,主要功能包括编译安装Docker和安装DeepSeek模型。首先通过Apt源配置安装Docker,确保网络稳定(建议使用VPN)。接着下载并配置Docker二进制文件,创建Docker用户组并设置守护进程。随后拉取Debian 12镜像,安装系统必备工具,配置Ollama模型管理器,并最终部署和运行DeepSeek模型,提供API接口进行交互测试。
129 15
|
12天前
|
关系型数据库 MySQL 数据库
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
91 42
|
13天前
|
关系型数据库 MySQL 数据库
Docker下Mysql8数据备份与恢复
通过以上步骤,您可以在Docker环境下高效地备份和恢复MySQL 8数据库。备份数据时,使用 `mysqldump`工具生成逻辑备份文件,并存储到指定目录;恢复数据时,使用 `mysql`工具从备份文件中读取数据并恢复到数据库。自动化脚本和定时任务的配置可以进一步简化备份和恢复的管理过程。
73 41
|
16天前
|
Linux Docker 容器
安装docker-18.06报错Error: libseccomp conflicts with docker-18.06
通过这些步骤,您可以成功在CentOS上安装Docker 18.06,并解决libseccomp的冲突问题。这些方法确保系统兼容性,并保证Docker的正常运行。
53 27
|
21天前
|
存储 关系型数据库 MySQL
美团面试:MySQL为什么 不用 Docker部署?
45岁老架构师尼恩在读者交流群中分享了关于“MySQL为什么不推荐使用Docker部署”的深入分析。通过系统化的梳理,尼恩帮助读者理解为何大型MySQL数据库通常不使用Docker部署,主要涉及性能、管理复杂度和稳定性等方面的考量。文章详细解释了有状态容器的特点、Docker的资源隔离问题以及磁盘IO性能损耗,并提供了小型MySQL使用Docker的最佳实践。此外,尼恩还介绍了Share Nothing架构的优势及其应用场景,强调了配置管理和数据持久化的挑战。最后,尼恩建议读者参考《尼恩Java面试宝典PDF》以提升技术能力,更好地应对面试中的难题。
|
3天前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
44 25
|
25天前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决