如何在 Docker 容器中运行 MySQL

本指南逐步解释了如何在几分钟内设置在 Docker 容器中运行的新 MySQL 服务器。

Docker 的一大优点是您可以快速使用它来试用应用程序,而无需直接在您的机器上安装它。您可以使用 Docker 在容器中运行数据库,就像它是远程服务器一样,并测试您的应用程序如何与其交互。

使用 Docker 容器运行 MySQL 是一种广泛使用的机制。事实上,MySQL 是与 Docker 容器一起使用的最流行的数据库之一。

要将 MySQL 创建为 Docker 容器,主机应安装 Docker。如果你没有安装它,这里有一个如何在 Ubuntu 上安装 Docker 的分步指南。

0. 配置镜像地址

修改daemon配置文件/etc/docker/daemon.json来使用加速器

{
"registry-mirrors": [ "https://docker.mirrors.ustc.edu.cn" ]
}
重启docker和deamon

sudo systemctl daemon-reload
sudo systemctl restart docker
 

1. 拉取 MySQL Docker 镜像

要在 Docker 中创建和测试 MySQL 服务器,您要做的第一件事是从Docker Hub拉取 MySQL 官方镜像 。

Docker Hub 上的 MySQL

您可以下载特定版本,例如 8.0、5.7、5.6,或选择最新版本,如以下命令所示:

docker pull mysql:latest

如果您需要特定版本的 MySQL,请替换 latest 为版本号。

您可以运行该docker images 命令来查看从 Docker Hub 中提取的 Docker 镜像列表。

docker images
 
输出

REPOSITORY TAG IMAGE ID CREATED SIZE mysql latest 2fe463762680 13 hours ago 514MB

如您所见,MySQL 映像现在可用于我们本地安装的 Docker。

2. 设置 Docker 卷

如您所知,Docker 容器原则上是短暂的,如果容器被删除,任何数据或配置都可能会丢失。然而,Docker 卷提供了一种机制来保存在 Docker 容器内创建的数据。它们是 Docker 用于存储 Docker 容器持久数据的首选机制。

默认情况下,MySQL 将其数据文件存储在该 /var/lib/mysql 目录中。因此,在部署之前,您需要设置一个 Docker 卷来持久化您的数据库。否则,当容器重新启动时,您的数据将丢失。

让我们创建一个新卷并将其命名为mysql-data。这将用于存储您的所有数据库信息。

docker volume create mysql-data

您可以通过发出以下命令列出 Docker 已知的所有卷:

docker volume ls
 
输出

DRIVER VOLUME NAME local mysql-data

如您所见,我们新创建的名为 Docker 的卷mysql-data在这里并准备好提供数据。然后可以将其附加到新创建的 MySQL 容器。

3. 运行一个 MySQL Docker 容器

现在您的机器上有 MySQL Docker 映像和一个用于保存数据的卷,您可以部署一个容器。您还必须使用MYSQL_ROOT_PASSWORD环境变量为 MySQL root 用户设置密码。

现在,让我们运行容器:

docker run -d --name=mysql-server -p 3306:3306 -v mysql-data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=your_password mysql

就是这样。这将启动最新版本的 MySQL 实例,可以使用指定的 root 密码从任何地方远程访问它。 

为了让事情更清楚,让我们分解这个语法。以下是该命令中每个参数的含义:

  • -d 将以分离模式运行此容器,以便它在后台运行。
  • --name 将名称分配mysql-server给您的容器实例。如果不指定此项,Docker 将生成一个随机名称。
  • -p 将 MySQL 容器端口绑定3306到主机上的相同端口。您将能够 使用在您的主机上运行的MySQL 客户端 ( )连接到 127.0.0.1端口。3306mysql
  • -v 选项将容器卷 ( /var/lib/mysql)内的数据文件夹绑定到mysql-data您在上一步中创建的本地 Docker 卷 ( )。
  • -e 设置环境变量。在这种情况下,MySQL 根密码。
  • mysql 是我们用来创建容器的图像的名称。

您可以通过列出正在运行的容器来检查容器是否正在运行:

docker ps
 
输出

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 0fc229e3df77 mysql "docker-entrypoint.s…" 37 minutes ago Up 34 minutes 0.0.0.0:3306->3306/tcp,:::3306->3306/tcp,33060/tcp mysql-server

相关:MySQL:如何使用 mysqldump 备份(转储)和恢复数据库

4. 连接到 MySQL 容器

您可以通过附加到容器并运行mysql命令来获得交互式 MySQL shell 。这提供了完整的 MySQL 命令行界面,因此您可以使用所有熟悉的命令和标志。

docker exec -it mysql-server mysql -u root -p

附加到 MySQL Docker 容器

相关:如何使用命令行在 MySQL 中创建数据库

mysql 如果您的主机上预安装了它,您还可以使用客户端连接 MySQL Docker 实例 。

请注意,默认情况下,当您告诉 mysql 客户端连接到 localhost. 所以一定要使用 127.0.0.1 而不是 localhost

mysql -u root -h 127.0.0.1 -p

当然,您也可以使用基于 GUI 的客户端(例如 MySQL Workbench)来连接数据库。在 MySQL Workbench 中为“Hostname”指定启动 Docker 容器的机器的 IP 地址。

  • MySQL 工作台

  • MySQL 工作台

相关:如何使用 MySQL Workbench 在 MySQL 中创建数据库

当然,在上面显示的主机名示例中,您可以使用 MySQL docker 容器所在机器的 IP 地址而不是127.0.0.1您可以通过运行ifconfig不带任何参数的命令来找到该地址

使用机器的 IP 地址可以让您远程访问 MySQL 服务器。

5. 停止、启动和重启 MySQL 容器

此命令将暂时停止正在运行的 MySQL 容器(并且可以稍后恢复/重新启动):

docker stop mysql-server

要 启动MySQL 容器,请运行:

docker start mysql-server

下面的命令用于重启正在运行的 MySQL 容器:

docker restart mysql-server

结论

如您所见,在 Docker 中运行 MySQL 比在本地安装 MySQL Server 更快、更容易。如果您打算在 Docker 上使用 MySQL 进行测试以外的任何事情,还有很多事情需要考虑。有关更多信息,您可以查看Docker Hub 上的 MySQL 页面和有关该主题的官方 MySQL 手册

原文地址:https://blog.csdn.net/allway2

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


文章浏览阅读8.4k次,点赞8次,收藏7次。SourceCodester Online Tours & Travels Management System pay.php sql injectionLine 16 of pay.php invokes a SQL query built using unvalidated input. This call could allow an attacker to modify the statement’s meaning or to execute arbitrary SQL commands.SQL
文章浏览阅读3.4k次,点赞46次,收藏51次。本文为大家介绍在windwos系统搭建typecho博客+cpolar内网穿透工具将博客发布到公共网络环境,实现远程也可以访问和操作。_windows搭建typecho
文章浏览阅读1.1k次。- php是最优秀, 最原生的模板语言, 替代语法,让php更加的优雅的与html生活在一起 -->请放心, 最终生成的,或者说用户最终看到的,仍然是一个html文档, php代码中的内容不会被泄漏的。-- 将php与html代码混编的时候,大括号很容易造成配对错误,最好杜绝它 -->php标签内部代码由php.exe解释, php标签之外的代码原样输出,仍由web服务器解析。-- 所以php的流程控制语句, 都提供了替代语法,用冒号代替大括号 -->php echo '百变鹏仔'?_利用php将静态页面修改为动态页面
文章浏览阅读1.1k次,点赞18次,收藏15次。整理K8s网络相关笔记博文内容涉及 Linux network namespace 认知以及彼此通信Demo,实际中的应用理解不足小伙伴帮忙指正不必太纠结于当下,也不必太忧虑未来,当你经历过一些事情的时候,眼前的风景已经和从前不一样了。——村上春树。_linux network namespace 多端通信 模式认知
文章浏览阅读1.2k次,点赞22次,收藏19次。此网络模型提供了一个逻辑二层(L2)网络,该网络封装在跨 Kubernetes 集群节点的现有三层(L3)网络拓扑上。使用此模型,可以为容器提供一个隔离的 L2 网络,而无需分发路由。封装网络带来了少量的处理开销以及由于覆盖封装生成 IP header 造成的 IP 包大小增加。封装信息由 Kubernetes worker 之间的 UDP 端口分发,交换如何访问 MAC 地址的网络控制平面信息。此类网络模型中常用的封装是 VXLAN、Internet 协议安全性 (IPSec) 和 IP-in-IP。_k8s网络组件对比
文章浏览阅读1.1k次,点赞14次,收藏19次。当我们谈论网络安全时,我们正在讨论的是保护我们的在线空间,这是我们所有人的共享责任。网络安全涉及保护我们的信息,防止被未经授权的人访问、披露、破坏或修改。
文章浏览阅读1.3w次,点赞3次,收藏7次。尽管您可以通过 ping 命令解析出网站的 IP 地址,但是可能在浏览器中访问时仍然遇到问题,这可能是因为浏览器使用的 DNS 解析结果不同于 ping 命令使用的解析结果。可能是因为您的网络或设备上设置了防火墙,阻止了对特定网站的访问。有些国家或组织可能会对特定的域名进行屏蔽,从而阻止访问相关网站。如果您的网络使用代理服务器进行访问控制,可能会由于代理服务器的配置问题导致无法访问某些网站。即使您的网络和设备一切正常,目标网站本身可能也存在问题,例如服务器故障、维护或过载,导致无法访问。_能ping通打不开网页
文章浏览阅读839次,点赞22次,收藏19次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。
文章浏览阅读2.1k次,点赞31次,收藏22次。基于微信小程序奶茶点餐外卖系统设计与实现(PHP后台+Mysql)可行性分析毕设源代码毕业设计,数据安全和系统稳定性以及团队能力和资源配备方面都具备较好的条件。因此,该项目的可行性较高。:黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;微信小程序作为一种快捷、方便的移动应用形式,成为很多用户点餐外卖的首选。项目的界面和功能都可以定制,包安装运行!项目配有对应开发文档、开题报告、任务书、PPT、论文模版等。
文章浏览阅读1.8k次,点赞52次,收藏38次。本文主要通过对系统的前台系统和后台管理系统进行了功能性需求分析,对系统的安全性和可扩展性进行了非功能性需求分析。在详细的需求分析的基础上,根据系统的功能设计确定了数据库结构,实现完整的代码编写。Lucky+Baby母婴用品网站使用 Dreamweaver、HBuilder代码编辑器、Apache服务器等开发工具,完成了系统的主要模块的页面设计和功能实现。本文展示了首页页面的实现效果图,并通过代码和页面介绍了用户注册功能、商品搜索功能、生成订单和查看我的订单功能、在线付款功能功能的实现过程。
文章浏览阅读1.5k次,点赞45次,收藏40次。本设计主要实现集人性化、高效率、便捷等优点于一身的人事信息管理系统,完成首页、系统用户、通知公告、部门信息、员工薪资、考勤签到、员工请假、招聘信息、应聘信息等功能模块。
文章浏览阅读1k次。该错误通常出现在数据库读取结果集数据时,比如当我们写好SQL语句从数据库读取数据时,本身应该返回结果集,再给结果集中读取数据。解决思路:这种错误一般是因为echo后面输出了一个数组导致的,或者是数组作为字符串进行拼接运算时导致的。该错误直译为:警告:mysqli_fetch_assoc函数期望参数1是mysqli的结果集,但是给了一个布尔值。这种错误是PHP解析器在解析时遇到了语法错误,直译为:解析错误:语法错误,意料之外的...该错误直译为:提示:未定义的索引:username。_array to string conversion in
文章浏览阅读2.7w次。解决http请求报错context deadline exceeded (Client.Timeout exceeded while awaiting headers)_context deadline exceeded (client.timeout exceeded while awaiting headers)
文章浏览阅读1.3k次,点赞26次,收藏24次。复杂网络是一种由大量相互连接的元素(节点或顶点)组成的网络结构,这些连接通常是非常复杂和动态的。这些网络可以在各种领域中发现,包括社交网络、生物学系统、信息技术和交通系统等。_代理建模
文章浏览阅读2.6k次,点赞76次,收藏71次。epoll详解,事件模型,ET/LT模式,并通过三个示例进行代码实现。
文章浏览阅读3.3k次。罗拉ROLA-IP是一家来自纽约的代理IP提供商,由李嘉诚先生投资建设,韩国人工智能、自动驾驶、虚拟现实方面的领军企业World IT Show投资入股,由美国纽约大学IT管理教授团队研究开发,进入中国市场6年多,全世界设有多个分子公司。接下来,我们要检查代理和防火墙的设置,因为在绝大多数情况下,它们是导致这个错误的原因,尤其是当用户使用免费代理时。对网站的访问受阻实际上是一个非常常见的错误,它既可能是由于物理原因(硬件问题)造成的,也可能是由于软件错误引起的。检查代理设置,并确保其正确配置。_无法访问此网站,检查代理服务器和防火墙
文章浏览阅读1.1k次,点赞14次,收藏20次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。_php洗车服务预约管理系统php源码
文章浏览阅读1.1k次。桶排序是计数排序的升级版。它利用了函数的映射关系,高效与否的关键就在于这个映射函数的确定。同时,对于桶中元素的排序,选择何种比较排序算法对于性能的影响至关重要。
文章浏览阅读936次,点赞22次,收藏17次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。
文章浏览阅读822次,点赞15次,收藏14次。在整个设计过程中,要确定可能的具体解决方案,以实现每一个小的最终目标,对于每一个小目标,我们首先必须了解一些相关的需求分析信息。除了以上作品下面是2023-2024年最新100套计算机专业原创的毕业设计源码+数据库,是近期作品,如果你的题目刚好在下面可以文末领取java源码参考。springboot基于springboot的在线考试系统。springboot基于springboot的商城购物系统。springboot基于微信小程序的智慧校园设计与实现。springboot基于用户的协同过滤算法的话题推荐。