使用 Docker 部署 MySql

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 使用 Docker 部署 MySql

前言
虽然不建议将需要持久化的数据保存在容器中,但是自己平时做个小项目玩玩还是没什么问题的。

拉取镜像
docker pull mysql
不加 tag 的话默认从 DockerHub 拉取最新版本的

启动容器
运行一下试试

docker run mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql_test mysql
这里的 -e 参数是必须指定的,作用是设置数据库的密码,否则将无法启动容器。

复制容器内的文件到宿主机

现在我们还没有进入容器,可以在宿主机的命令行中输入 docker ps 查看当前正在运行的容器,如果没出什么问题的话应该可以看到一个名为 mysql_test 的容器正在运行。在学习数据库的时候我们已经知道了 MySql 的数据库文件默认位于 /var/lib/mysql/ 中,配置文件在 /etc/mysql/conf.d 和 /etc/my.cnf。

我们不对默认的配置做更改,所以就没必要挂载 conf.d 目录到宿主机了,只需要映射一下容器内的数据库文件,以防止容器宕掉了导致数据的丢失。

docker cp mysql_test:/var/lib/mysql $PWD/
这里的 cp 命令作用是复制容器内的文件,后面的 $PWD 为 当前所在的宿主机目录,例如我现在的目录是 /home/hsk/box_container/mysql/,复制出来的 mysql 文件夹就会在我当前的路径下。

启动一个新的容器
将默认的数据库文件复制出来后,就可以删除之前测试用的容器了,在删除之前 我们要先停掉它:

docker stop mysql_test
删除旧容器:

docker rm mysql_test
创建一个新的容器并挂载卷,映射端口:

docker run \
-d \
--name mysql01 \
-p 3309:3306 \
-v /home/hsk/box_container/mysql01/conf.d/:/etc/mysql/conf.d \
-v /home/hsk/box_container/mysql01/mysql/:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql
-d 表示让容器在后台运行
--name 为容器起一个名字
-p 映射端口,这里把容器内的 3306 端口映射到了宿主机的 3309
-v 挂载卷,冒号前是宿主机目录,冒号后是容器内目录
-e 容器的环境配置

进入容器
使用 docker exec -it <容器ID|容器name> /bin/bash 指令进入模拟终端:

docker exec -it mysql01 /bin/bash
进入容器后,启动 MySql 交互命令行:

mysql -hlocalhost -uroot -p123456

查看数据库表:

mysql> show databases;
Database
information_schema
mysql
performance_schema
sys

4 rows in set (0.00 sec)
外部挂载进来的默认数数据库表都正常加载了

创建新的数据库
由于我的数据库基础不是很好,而且过了很长时间已经忘了基本所有的 SQL语句,所以这里使用 DBeaver 图形化数据库工具来创建数据库和添加数据,类似于大家上课时用到的 Navicat

防火墙放行端口:

在创建容器的时候我们指定了对外映射端口 3309,所以要放行该端口以供外网访问,如果像我一样使用云服务商提供的服务器的话具体去官网控制台放行一下端口就行了,如果是在自己家搭建的服务器在有 公网IP 的条件下去路由器管理界面设置,本机的话就不需要配置了。

使用 DBeaver 连接数据库:

新建连接 -> mysql

没有报错就说明连接成功了

创建数据库:

右键「数据库」,选择「新建」,我起名为 FruitDatabase

新建表:

选择「数据库」,点击「创建」-> 「表」,我起名为 fruit_table

新增列,配置主键:

直接点击鼠标操作就行,无需输入任何 SQL语句,但是要了解数据类型、键等基础知识。我创建的字段如下所示 ↓

再随便添加点数据:

回到容器
插入数据完成后,进入容器中检查下:

docker exec -it mysql01 /bin/bash

bash-4.4# mysql -hlocalhost -uroot -p123456

mysql> show databases;
Database
FruitDatabase
information_schema
mysql
performance_schema
sys

5 rows in set (0.00 sec)

mysql> use FruitDatabase
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed

mysql> show tables;
Tables_in_FruitDatabase
fruit

1 row in set (0.00 sec)

mysql> select * from fruit_table;
fruit_name fruit_id price stock avatar
????? 1 24.20 70 http://www.xxx.com/apple.jpg
????? 2 74.20 80 http://www.xxx.com/pears.jpg
???? 3 78.40 190 http://www.xxx.com/jujube.jpg
????? 4 78.00 8 http://www.xxx.com/jackfruit.jpg
????? 5 24.20 70 http://www.xxx.com/litchi.jpg

5 rows in set (0.00 sec)

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
1月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
430 108
|
1月前
|
运维 Devops 持续交付
揭秘 Docker 自动部署神器 Websoft9:热门开源软件一键部署
在企业IT建设中,软件部署常面临效率低、易出错等问题。通过Docker与自动化工具,可实现高效、标准化和可追溯的部署流程,提升企业应用交付效率,降低运维门槛,助力中小企业实现自动化部署。
140 5
揭秘 Docker 自动部署神器 Websoft9:热门开源软件一键部署
|
14天前
|
JavaScript 算法 前端开发
【Docker项目实战】使用Docker部署paopao-ce微社区
【Docker项目实战】使用Docker部署paopao-ce微社区
159 84
【Docker项目实战】使用Docker部署paopao-ce微社区
|
23天前
|
运维 Cloud Native 开发者
Docker:现代化应用开发与部署的神器
Docker:现代化应用开发与部署的神器
165 101
|
1月前
|
设计模式 Linux 开发工具
Docker部署会吗?
本段内容主要介绍了Docker常用命令、Linux基础指令及日志查看方法,还涉及SpringMVC的执行流程、设计模式与注解,适合用于面试中技术能力的展示。
76 0
|
5天前
|
存储 Docker Python
docker 部署 sftp
本文介绍SFTP服务的部署与配置,包括users.conf用户配置规则、Docker容器运行命令及上传目录权限说明,重点解析atmoz/sftp镜像的chroot机制与子目录映射,确保用户登录后正确访问/upload目录,并提供Python脚本实现文件上传示例。
43 13
docker 部署 sftp
|
6天前
|
运维 Linux 数据库
基于 Docker 部署 n8n 指南,新手一看就会
本教程详解如何通过 Docker 快速部署开源自动化工具 n8n,适合新手快速上手。内容涵盖官方部署步骤、常见难点及第三方一键部署方案,助你高效搭建自动化工作流平台。
140 6
|
2月前
|
搜索推荐 应用服务中间件 数据安全/隐私保护
【Docker项目实战】使用Docker部署Organizr个人导航页
【Docker项目实战】使用Docker部署Organizr个人导航页
374 76
【Docker项目实战】使用Docker部署Organizr个人导航页
|
13天前
|
前端开发 JavaScript 应用服务中间件
在Docker部署的前端应用中使用动态环境变量
以上步骤展示了如何在 Docker 配置过程中处理并注入环墨遁形成可执行操作流程,并确保最终用户能够无缝地与之交互而无须关心背后复杂性。
54 13
|
16天前
|
存储 Kubernetes 持续交付
为什么Docker容器化改变了开发与部署?
为什么Docker容器化改变了开发与部署?