搜索
首页数据库mysql教程在 Docker 容器中为您的项目使用 MySQL

Using MySQL in a Docker Container for your Projects

我坚信保持主机系统清洁。 Docker 容器是解决这个问题的完美解决方案。假设您正在开发一个带有 Node / Express 后端和 MySQL 服务器的 React 应用程序来满足您的数据库需求。通常,您会在主机系统中安装 mysql、创建数据库、创建具有密码的用户并授予用户使用该数据库的权限。

我不再浪费时间为每个项目进行每次配置,而是使用 Docker 映像来创建我的 MySQL 数据库服务器,只需几秒钟即可准备好、启动并运行,并完成所有必要的设置永远需要。

相信我,一旦你使用这条路线弄清楚了你的工作流程,你将永远不会回到旧的方式。所以,这就是我的做法,而且是一种非常简单、基本的方式。

如果您有一些 Docker 经验并希望跳过本教程并直接使用 TLDR 版本,那么这个 Gist 会快得多。

我们需要什么?

要使用 Docker,我们需要 Docker,呃!这里不再赘述安装Docker的细节。如果您不习惯 CLI 或者您使用的是 Windows/MacOS,请使用 Docker Desktop,它将在幕后为您完成所有繁重的工作。

如果您不喜欢,Linux 用户也可以使用 Docker Compose 插件或 Docker Desktop 安装 Docker Engine。

您通常不需要 Docker Hub 上的帐户来下载公共映像,例如我们将使用的 MySQL 官方映像。

好吧,现在怎么办?

有两种方法可以实现此目的。

使用 Docker Run(不推荐)

为了能够使用 docker run 命令直接运行容器,您必须首先在系统上下载 MySQL 映像。要将映像拉取到您的系统,只需使用以下命令:

docker pull mysql

注意:如果您不需要特定版本的 MySQL,那么此命令将下载最新版本(带有最新标签的版本)。如果需要,您可以从 Docker Hub 探索更多标签和版本。

Docker 下载完成后,您可以看到下载的镜像,如下所示:

docker image ls

现在,要运行容器,您必须使用 docker run 命令添加许多标志。您可以访问此链接来检查您拥有的所有选项。您还需要记住需要添加的所有标志,因为缺少一些标志可能会引发错误或启动无法运行的容器。

此外,每次您希望运行容器时,您都必须从终端历史记录中找出这个长命令,或者再次输入它。这样做毫无意义。

这就是我不推荐这种方法的原因。有更好的方法。

Docker 组合

我们将创建一个 Docker Compose 文件,该文件将告诉 Docker 在启动容器时我们需要什么。一旦所有内容都布置在文件中,启动容器就变得小菜一碟。

注意:您可以使用任何名称创建撰写文件。如果您使用自己的名称或将撰写文件存储在其他文件夹中,则必须提供标志 -f 才能使其正常工作。或者,如果您从文件所在的同一文件夹运行命令,则可以将文件命名为 docker-compose.yaml。

Docker Compose 文件是一个 YAML 文件。我们的看起来像这样:

# This Docker Compose YAML deploys a MySQL database
services:
  container-name:

    image: mysql # Official MySQL image from Docker Hub
    restart: always

    environment:
      # Note - Root password is mandatory for the container to run and grant privileges to our User.
      MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}

      MYSQL_DATABASE: ${MYSQL_DATABASE} # Same name as used in your project

      # DB User Details
      MYSQL_USER: ${MYSQL_USER}
      MYSQL_PASSWORD: ${MYSQL_PASSWORD}

    ports:
      # Adjust this port as per your needs -> <hostport>:<containerport>
      - 3308:3306 # DB is available at localhost:3308 on the host.

    volumes:
      - ./volumes/db-mnt:/var/lib/mysql
</containerport></hostport>

这个文件也可以在开头提到的 Gist 上找到。

重要须知

  1. 端口映射:第一个端口是主机端口(您的系统),它映射到第二个端口(docker 容器内的端口)。这意味着,在上面的示例中,您可以访问 localhost:3308 处的数据库。除非你知道自己在做什么,否则请将第二个端口保留为 3306。这是 MySQL 的默认端口。
  2. 卷绑定挂载:我们将本地卷挂载到容器中以将数据保存在数据库中。这使得在需要时可以轻松备份和移动。您还可以让 Docker 管理它自己的卷并在主机系统上创建定期备份。 #### 环境文件 为了在创建容器时向 Docker 提供必要的凭据,我们将创建一个 .env 文件,就像我们在 React 或后端应用程序中所做的那样。

您可以在 compose 文件所在的同一文件夹中创建此文件,也可以在任何您喜欢的位置创建它,但需要在调用 docker-compose 时提供路径。

# Content of the Environment Variables file
MYSQL_ROOT_PASSWORD=rootpassword
MYSQL_DATABASE=nameofdatabase
MYSQL_USER=dbusername
MYSQL_PASSWORD=dbuserpassword

一旦我们完成了所有这些,我们只需使用一个小命令,我们的数据库就会启动并准备好等待我们。

docker-compose up -d

您现在已准备好使用您喜欢的方式连接到数据库。

由于我们已将容器配置为从 compose 文件运行,因此您可以安全地将其备份到存储库中的 git 系统中。只需确保您 .git 忽略 .env 文件即可。

以上是在 Docker 容器中为您的项目使用 MySQL的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
解释InnoDB缓冲池及其对性能的重要性。解释InnoDB缓冲池及其对性能的重要性。Apr 19, 2025 am 12:24 AM

InnoDBBufferPool通过缓存数据和索引页来减少磁盘I/O,提升数据库性能。其工作原理包括:1.数据读取:从BufferPool中读取数据;2.数据写入:修改数据后写入BufferPool并定期刷新到磁盘;3.缓存管理:使用LRU算法管理缓存页;4.预读机制:提前加载相邻数据页。通过调整BufferPool大小和使用多个实例,可以优化数据库性能。

MySQL与其他编程语言:一种比较MySQL与其他编程语言:一种比较Apr 19, 2025 am 12:22 AM

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

学习MySQL:新用户的分步指南学习MySQL:新用户的分步指南Apr 19, 2025 am 12:19 AM

MySQL值得学习,因为它是强大的开源数据库管理系统,适用于数据存储、管理和分析。1)MySQL是关系型数据库,使用SQL操作数据,适合结构化数据管理。2)SQL语言是与MySQL交互的关键,支持CRUD操作。3)MySQL的工作原理包括客户端/服务器架构、存储引擎和查询优化器。4)基本用法包括创建数据库和表,高级用法涉及使用JOIN连接表。5)常见错误包括语法错误和权限问题,调试技巧包括检查语法和使用EXPLAIN命令。6)性能优化涉及使用索引、优化SQL语句和定期维护数据库。

MySQL:初学者的基本技能MySQL:初学者的基本技能Apr 18, 2025 am 12:24 AM

MySQL适合初学者学习数据库技能。1.安装MySQL服务器和客户端工具。2.理解基本SQL查询,如SELECT。3.掌握数据操作:创建表、插入、更新、删除数据。4.学习高级技巧:子查询和窗口函数。5.调试和优化:检查语法、使用索引、避免SELECT*,并使用LIMIT。

MySQL:结构化数据和关系数据库MySQL:结构化数据和关系数据库Apr 18, 2025 am 12:22 AM

MySQL通过表结构和SQL查询高效管理结构化数据,并通过外键实现表间关系。1.创建表时定义数据格式和类型。2.使用外键建立表间关系。3.通过索引和查询优化提高性能。4.定期备份和监控数据库确保数据安全和性能优化。

MySQL:解释的关键功能和功能MySQL:解释的关键功能和功能Apr 18, 2025 am 12:17 AM

MySQL是一个开源的关系型数据库管理系统,广泛应用于Web开发。它的关键特性包括:1.支持多种存储引擎,如InnoDB和MyISAM,适用于不同场景;2.提供主从复制功能,利于负载均衡和数据备份;3.通过查询优化和索引使用提高查询效率。

SQL的目的:与MySQL数据库进行交互SQL的目的:与MySQL数据库进行交互Apr 18, 2025 am 12:12 AM

SQL用于与MySQL数据库交互,实现数据的增、删、改、查及数据库设计。1)SQL通过SELECT、INSERT、UPDATE、DELETE语句进行数据操作;2)使用CREATE、ALTER、DROP语句进行数据库设计和管理;3)复杂查询和数据分析通过SQL实现,提升业务决策效率。

初学者的MySQL:开始数据库管理初学者的MySQL:开始数据库管理Apr 18, 2025 am 12:10 AM

MySQL的基本操作包括创建数据库、表格,及使用SQL进行数据的CRUD操作。1.创建数据库:CREATEDATABASEmy_first_db;2.创建表格:CREATETABLEbooks(idINTAUTO_INCREMENTPRIMARYKEY,titleVARCHAR(100)NOTNULL,authorVARCHAR(100)NOTNULL,published_yearINT);3.插入数据:INSERTINTObooks(title,author,published_year)VA

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境