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等)才能连接。

相关推荐
JH30735 分钟前
Oracle与MySQL中CONCAT()函数的使用差异
数据库·mysql·oracle
蓝染-惣右介7 分钟前
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
java·数据库·tomcat·mybatis
冷心笑看丽美人8 分钟前
Spring框架特性及包下载(Java EE 学习笔记04)
数据库
武子康1 小时前
Java-07 深入浅出 MyBatis - 一对多模型 SqlMapConfig 与 Mapper 详细讲解测试
java·开发语言·数据库·sql·mybatis·springboot
吴半杯1 小时前
gateway漏洞(CVE-2022-22947)
docker·kubernetes·gateway
今天我刷leetcode了吗1 小时前
docker 配置同宿主机共同网段的IP 同时通过通网段的另一个电脑实现远程连接docker
tcp/ip·docker·电脑
代码吐槽菌2 小时前
基于SSM的毕业论文管理系统【附源码】
java·开发语言·数据库·后端·ssm
路有瑶台2 小时前
MySQL数据库学习(持续更新ing)
数据库·学习·mysql
数字扫地僧2 小时前
WebLogic 版本升级的注意事项与流程
数据库
lwprain2 小时前
常用docker应用部署,wordpress、mysql、tomcat、nginx、redis
mysql·docker·tomcat