在 Ubuntu 下通过 Docker 部署 MySQL 服务器

embedded/2025/1/14 21:02:46/

引言

Docker 是一个开源的容器化平台,允许开发者将应用及其依赖打包成一个标准化的单元。MySQL 是一个广泛使用的关系型数据库管理系统,因其高性能、可靠性和易用性,成为许多应用的首选数据库。结合 Docker 和 MySQL,可以轻松地创建、管理和扩展数据库实例,提升开发效率。

在 Alpine Linux 下通过 Docker 部署 MySQL 服务器

步骤 1: 安装 Docker

首先,确保你的系统上已安装 Docker。可以使用以下命令安装 Docker:

bash

复制

sudo apt update
sudo apt install docker.io

启动 Docker 服务并设置为开机自启:

bash

复制

sudo systemctl start docker
sudo systemctl enable docker

步骤 2: 拉取 MySQL 镜像

接下来,拉取官方的 MySQL 镜像:

bash

复制

sudo docker pull mysql:latest

步骤 3: 创建 MySQL 配置文件

在本地创建一个目录来存放 MySQL 的配置文件和数据:

bash

复制

mkdir -p ~/mysql-data

然后,创建一个 my.cnf 配置文件:

nano ~/mysql-data/my.cnf

在文件中添加以下内容:

[mysqld]
bind-address = 0.0.0.0
character-set-server = utf8mb4

步骤 4: 启动 MySQL 容器

使用以下命令启动 MySQL 容器:

sudo docker run --name my-mysql -v ~/mysql-data:/var/lib/mysql -v ~/mysql-data/my.cnf:/etc/mysql/my.cnf -e MYSQL_ROOT_PASSWORD=yourpassword -d mysql:latest
参数说明:
  • --name my-mysql: 指定容器名称为 my-mysql
  • -v ~/mysql-data:/var/lib/mysql: 将本地目录挂载到容器的 MySQL 数据目录。
  • -v ~/mysql-data/my.cnf:/etc/mysql/my.cnf: 将本地配置文件挂载到容器中。
  • -e MYSQL_ROOT_PASSWORD=yourpassword: 设置 MySQL 的 root 用户密码。
  • -d: 以后台模式运行容器。

步骤 5: 验证安装

使用以下命令检查 MySQL 容器的状态:

sudo docker ps

如果容器正常运行,可以通过以下命令进入 MySQL:

sudo docker exec -it my-mysql mysql -u root -p

输入你在步骤 4 中设置的 root 密码。

结论

通过以上步骤,你已经成功在 Ubuntu 下通过 Docker 部署了 MySQL 服务器。现在,你可以开始使用 MySQL 数据库,尽情享受这个灵活、高效的数据库系统带来的便利。记得保持你的容器更新,保持安全!💻✨


http://www.ppmy.cn/embedded/153927.html

相关文章

论文阅读:Jailbreak Open-Sourced Large Language Models via Enforced Decoding

1.论文:通过强制解码破解开源大型语言模型【2024ACL】 1.提出问题: 安全对齐真的可以防止那些开源的大型语言模型被误用来成不希望的内容吗? 2.做出假设: 开源模型很容易被误导,在没有大量计算和精细 Prompt 下能够产生恶意内容…

【Vue + Antv X6】可拖拽流程图组件

使用事项&#xff1a; ❗先放个组件上来&#xff0c;使用手册有空会补全 ❗需要下载依赖 “antv/x6”: “^2.18.1”, “antv/x6-plugin-dnd”: “^2.1.1”, 组件&#xff1a; 组件使用&#xff1a; <flowChart :key"flowChartKey" ref"flowChart" lef…

Chromium 中libxml使用c++

Chromium中包含libxml 解析库 读取和写文件包含对应头文件即可。 1、读取xml third_party/libxml/chromium/xml_reader.h #include <map> #include <string>extern "C" { struct _xmlTextReader; }// XmlReader is a wrapper class around libxmls xm…

Ubuntu 24.04蓝牙失效之复活

Thinkpad E450 Ubuntu 24.04 蓝牙突然罢工&#xff0c;设置页面蓝牙无法激活(turn on失效&#xff09;。 网上搜索诸多帖子试了一遍都没有解决&#xff0c;直到拜读到这篇[Solved] Bluetooth down and hciconfig hci0 up timeout / Kernel & Hardware / Arch Linux Forums…

C++实现设计模式---代理模式 (Proxy)

代理模式 (Proxy) 代理模式 是一种结构型设计模式&#xff0c;它为其他对象提供一个代理以控制对该对象的访问。代理模式常用于延迟加载、访问控制、智能引用等场景。 意图 提供对某对象的控制。控制对目标对象的访问&#xff0c;通常用于在不改变目标对象的情况下&#xff0…

【PyQt】如何在mainwindow中添加菜单栏

[toc]如何在mainwindow中添加菜单栏 如何在mainwindow中添加菜单栏 主要有两种方法&#xff1a; 1.直接创建mainwindow进行添加 2.使用ui文件加载添加 第二种方法更为常见&#xff0c;可以应用到实际 1.直接创建mainwindow进行添加 import sysfrom PyQt5.QtWidgets import …

Spring Boot + MyBatis Plus 存储 JSON 或 List 列表全攻略

在现代的后端开发中&#xff0c;我们常常需要处理复杂的数据结构&#xff0c;JSON 数据以及列表&#xff08;List&#xff09;数据屡见不鲜。如何高效地使用 Spring Boot 和 MyBatis Plus 来存储这些复杂数据类型&#xff0c;是这篇博客要探讨的重点。 一、为什么要存储 JSON …

CentOS 和 Ubantu你该用哪个

文章目录 **一、CentOS 和 Ubuntu 的详细介绍****1. CentOS****1.1 基本信息****1.2 特点****1.3 缺点** **2. Ubuntu****2.1 基本信息****2.2 特点****2.3 缺点** **二、CentOS 和 Ubuntu 的异同****1. 相同点****2. 不同点****3. 使用体验对比** **三、总结和选择建议** Cent…