使用 Docker-compose 部署 MySQL

news/2025/2/22 3:13:00

使用 Docker Compose 部署 MySQL

本文将详细指导如何使用 docker-compose 部署 MySQL,包括基本配置、启动步骤、数据持久化以及一些高级选项。通过容器化部署 MySQL,你可以快速搭建一个隔离的数据库环境,适用于开发、测试或小型生产场景。


关键要点

  • 使用 docker-compose 部署 MySQL 需要创建一个 docker-compose.yml 文件,设置 MySQL 镜像、端口映射、环境变量和数据持久化。
  • 需要安装 Docker Engine、Docker Compose 和 MySQL 客户端。
  • 数据通过命名卷持久化,方便管理和备份。
  • 令人惊讶的是,你可以自动创建数据库和用户,只需在文件中添加额外的环境变量。

准备工作

在开始之前,请确保已安装以下工具:

  • Docker Engine容器运行环境,可从 官方文档 获取。
  • Docker Compose:管理多容器应用的工具,可从 官方文档 获取。
  • MySQL 客户端:用于连接和操作数据库,可参考 安装指南。

这些工具是部署的基础,确保你的环境已准备就绪。


创建和启动 MySQL

dockercomposeyml__29">1. 创建 docker-compose.yml 文件

创建一个名为 docker-compose.yml 的文件,内容如下:

version: '3.9'
services:
  mysql:
    image: mysql:8.0
    restart: always
    ports:
      - "3306:3306"
    environment:
      MYSQL_ROOT_PASSWORD: MYPASSWORD
    volumes:
      - mysql_data:/var/lib/mysql
volumes:
  mysql_data: 

说明:

version: '3.9':指定 Docker Compose 文件格式版本。
image: mysql:8.0:使用 MySQL 8.0 官方镜像。
restart: always容器在失败时自动重启。
ports: "3306:3306":将主机端口 3306 映射到容器内的 3306 端口。
environment:设置 MySQL 根密码(将 MYPASSWORD 替换为你的实际密码)。
volumes:使用命名卷 mysql_data 挂载到 /var/lib/mysql,实现数据持久化。

2.可选:自动创建数据库和用户

如果需要自动创建数据库和用户,可以在 environment 中添加以下内容:

environment:
  - MYSQL_ROOT_PASSWORD=MYPASSWORD
  - MYSQL_DATABASE=mydb
  - MYSQL_USER=myuser
  - MYSQL_PASSWORD=myuserpassword

说明:

MYSQL_DATABASE:创建名为 mydb 的数据库。
MYSQL_USER:创建用户 myuser。
MYSQL_PASSWORD:设置用户密码为 myuserpassword。
将上述值替换为你的实际需求,这一功能非常适合快速初始化。

3.启动服务

docker-compose.yml 文件所在目录,打开终端并运行:

docker compose up -d

-d 参数表示在后台运行,容器启动后不会阻塞终端。
首次运行可能需要下载 MySQL 镜像,请耐心等待。

4. 验证和连接

检查容器状态:

docker compose ps

输出应显示 mysql 服务状态为 Up,表示运行正常。

连接 MySQL,使用 MySQL 客户端:

mysql -h localhost -u root -p

输入之前设置的密码(如 MYPASSWORD),成功连接后即可看到 MySQL 提示符。

5. 停止和清理

使用完成后,运行以下命令停止并移除容器

docker compose down

这会停止并删除容器、网络和卷,但数据仍保存在 mysql_data 卷中,除非手动清理。

注意事项

数据持久化mysql_data 卷确保数据在容器删除后仍可访问,建议定期备份。
安全性:暴露 3306 端口可能存在风险,生产环境建议使用防火墙或 Docker 网络隔离。
调试
查看日志:

docker logs mysql

进入容器

docker exec -it mysql bash

结论

通过 docker-compose 部署 MySQL 是一种高效、灵活的方式,适合快速搭建开发或测试环境。本文提供了从基础配置到高级选项的完整指南,包括数据持久化、自动初始化和故障排查方法。你可以根据实际需求调整配置,例如更改端口、密码或添加初始化脚本。


http://www.niftyadmin.cn/n/5861549.html

相关文章

windows环境下用docker搭建php开发环境dnmp

安装WSL WSL即Linux子系统,比虚拟机占用资源少,安装的前提是系统必须是win10以上。 WSL的安装比较简单,网上有很多教程,例如:WSL简介与安装流程(Windows 下的 Linux 子系统)_wsl安装-CSDN博客&…

rtpengine and redis

redis 用来在不同 rtpengine 实例之间同步会话信息 回头做做测试,看下到底怎么用 这里有几个链接: https://github.com/sipwise/rtpengine/wiki/Redis-keyspace-notifications https://kamailio.org/events/2020-KamailioWorldOnline/KW2020-YufeiTa…

【C++】:奇异递归模板模式

一、基本概念 奇异递归模板模式(Curiously Recurring Template Pattern, CRTP)是一种C++模板元编程技术,核心特征是子类将自己作为模板参数传递给基类。这使得基类能够在编译时获得子类的具体类型信息,从而实现静态多态、接口注入等高级功能。 二、核心机制与典型示例 2…

Ubuntu如何利用.ibd文件恢复MySQL数据?

## 背景:服务器中,MySQL程序坏了,也没有做定时备份的操作。为了是数据库恢复到最新的。 ## 方法:可以使用MySQL的 .ibd 文件恢复。(需要原数据库的表结构) ## 文件位置:在Ubuntu系统中&#x…

第4章 信息系统架构(三)

4.3 应用架构 应用架构的主要内容是规划出目标应用分层分域架构,根据业务架构规划目标应用域、应用组和目标应用组件,形成目标应用架构逻辑视图和系统视图。从功能视角出发,阐述应用组件各自及应用架构整体上,如何实现组织的高阶…

Ubuntu 下 nginx-1.24.0 源码分析 - ngx_process_options

ngx_process_options 声明在 src\core\nginx.c static ngx_int_t ngx_process_options(ngx_cycle_t *cycle); 定义在 src\core\nginx.c static ngx_int_t ngx_process_options(ngx_cycle_t *cycle) {u_char *p;size_t len;if (ngx_prefix) {len ngx_strlen(ngx_prefix);p …

51单片机-按键

1、独立按键 1.1、按键介绍 轻触开关是一种电子开关,使用时,轻轻按开关按钮就可使开关接通,当松开手时,开关断开。 1.2、独立按键原理 按键在闭合和断开时,触点会存在抖动现象。P2\P3\P1都是准双向IO口,…

ssm121基于ssm的开放式教学评价管理系统+vue(源码+包运行+LW+技术指导)

项目描述 临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据疫情当下,你想解决的问…