MySQL容器部署步骤

1、拉取MySQL镜像

bash 复制代码
docker pull mysql # 默认拉取最新版本

docker pull mysql:5.7 # 拉取5.7版本

docker pull mysql:8.0 # 拉取8.0版本

2、创建挂载目录

bash 复制代码
# 创建挂载目录  
mkdir -p /home/mysql/conf/  # -p: 多级创建

mkdir -p /home/mysql/log/

mkdir -p /home/mysql/data/

3、创建配置文件

bash 复制代码
vim -p /home/mysql/conf/my.cnf  # my.cnf为MySQL配置文件

# 配置文件内容如下:

[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
init_connect='SET collation_connection = utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
default-time_zone='+8:00'
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
skip-name-resolve

4、启动容器

bash 复制代码
# MySQL5.7的容器启动方式

docker run \
--name my-mysql \
--restart=always \
-e MYSQL_ROOT_PASSWORD=123456 \
-p 3306:3306 \
-v /home/mysql/conf/my.cnf:/etc/mysql/my.cnf \
-v /home/mysql/log/:/var/log/ \
-v /home/mysql/data/:/var/lib/mysql/ \
-d \
mysql:5.7 \

# MySQL8.0的容器启动方式:

docker run \
--name my-mysql \
--restart=always \
-e MYSQL_ROOT_PASSWORD=123456 \
-p 3306:3306 \
-v /home/mysql/conf/my.cnf:/etc/mysql/my.cnf \
-v /home/mysql/log/:/var/log/ \
-v /home/mysql/data/:/var/lib/mysql/ \
-d \
mysql:8.0 \
--default-authentication-plugin=mysql_native_password
  • --name my-mysql:容器名称,指定容器的名称为my-mysql
  • --restart=always:设置该容器开机自启
  • -e MYSQL_ROOT_PASSWORD=123456:环境配置,指定root用户密码为123456
  • -p 3306:3306:端口映射,第一个3306指的是宿主机端口,第一个3306指的是容器端口
  • -v:数据卷挂载,将mysql内部文件同步到Linux的文件中
  • -d:后台运行
  • mysql:5.7:镜像名,基于镜像常见容器

注意:MySQL 5.7和MySQL 8的容器部署步骤差不多,但要注意MySQL 8在启动容器时的密码加密方式的修改,即添加:--default-authentication-plugin=mysql_native_password。这样用远程工具(如FinalShell等)才能连接。

相关推荐
全栈小5几秒前
【数据库】浙人医携手金仓数据库,打造全国首个多院区异构多活容灾架构
数据库·1024程序员节·金仓
studytosky31 分钟前
Linux 基础开发工具(3):Git 控制与 GDB 调试实用指南
linux·运维·服务器·网络·数据库·git
凌睿马36 分钟前
关于复杂数据结构从MySQL迁移到PostgreSQL的可行性
数据结构·数据库·mysql
pblh12340 分钟前
基于Docker部署测试PySpark
运维·docker·容器
是一个Bug1 小时前
声明式事务:深度解析与实战指南
数据库·oracle
yBmZlQzJ1 小时前
财运到内网穿透-群晖NAS安装(docker版本)
运维·经验分享·网络协议·docker·容器
星光一影1 小时前
美容/心理咨询/问诊/法律咨询/牙医预约/线上线下预约/牙医行业通用医疗预约咨询小程序
mysql·小程序·vue·php·uniapp
laocooon5238578861 小时前
C#二次开发中简单块的定义与应用
android·数据库·c#
不穿格子的程序员1 小时前
Redis篇4——Redis深度剖析:内存淘汰策略与缓存的三大“天坑”
数据库·redis·缓存·雪崩·内存淘汰策略
IT枫斗者1 小时前
Netty的原理和springboot项目整合
java·spring boot·后端·sql·科技·mysql·spring