Docker中MySQL的安装与实践

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 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
目录
相关文章
|
16天前
|
弹性计算 Ubuntu Linux
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS自动化部署。支持Ubuntu 22.04/20.04、CentOS 7.7-7.9及Alibaba Cloud Linux 3.2104 LTS。前提条件:ECS实例需运行中且有公网。步骤:选择Docker扩展并安装,验证成功通过命令`docker -v`查看版本号。
188 79
|
3天前
|
前端开发 应用服务中间件 nginx
docker安装nginx,前端项目运行
通过上述步骤,你可以轻松地在Docker中部署Nginx并运行前端项目。这种方法不仅简化了部署流程,还确保了环境的一致性,提高了开发和运维的效率。确保按步骤操作,并根据项目的具体需求进行相应的配置调整。
43 25
|
3天前
|
安全 数据安全/隐私保护 Docker
docker私有仓库harbor安装
通过以上步骤,您可以成功在企业内部安装和配置Harbor私有仓库,方便地管理和分发Docker镜像。Harbor不仅提供了基础的镜像管理功能,还增强了安全性、身份管理和审计功能,使其成为企业级容器镜像管理的理想选择。
37 22
|
10天前
|
安全 关系型数据库 MySQL
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
80 16
|
9天前
|
SQL 关系型数据库 MySQL
docker-compose部署mysql8
使用docker-compose容器化部署mysql8
|
19天前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
80 14
|
16天前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
66 7
|
安全 Docker 容器
5个建议遵循的Docker最佳实践
本文讲的是5个建议遵循的Docker最佳实践【编者的话】本文介绍了5个Docker在实际应用场景下的最佳实践,能够帮助我们构建安全可靠的应用。
1496 0
|
8天前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
155 93
|
1月前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
261 77