Docker安装MySQL5.7

Docker安装MySQL5.7

一、拉取MySQL5.7镜像

bash 复制代码
$ docker pull mysql:5.7
# 等待镜像拉取完成
$ docker images
REPOSITORY   TAG       IMAGE ID       CREATED        SIZE
mysql        5.7       5107333e08a8   5 months ago   501MB

二、快速启动一个MySQL容器

bash 复制代码
$ docker run -itd --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7

$ docker ps

CONTAINER ID   IMAGE       COMMAND                  CREATED        STATUS         PORTS                                                  NAMES
812f56f8f239   mysql:5.7   "docker-entrypoint.s..."   4 seconds ago   Up 4 seconds   33060/tcp, 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp   mysql

参数解析:

  • -i:以交互模式运行容器,并保持终端激活。
  • -t(--tty):为容器分配一个伪终端。
  • -d(--detach):以后台模式运行容器,并返回容器ID
  • -p(--publish):发布容器端口到主机端口。常用:端口映射到宿主机
  • --name:为容器指定一个名称。

三、挂载数据卷方式启动MySQL容器

1.创建数据挂载目录

bash 复制代码
$ mkdir -p /opt/software/mysql/mysql-01/conf
$ touch /opt/software/mysql/mysql-01/conf/my.cnf
$ mkdir -p /opt/software/mysql/mysql-01/data
$ mkdir -p /opt/software/mysql/mysql-01/logs

2.编写my.cnf配置文件

mysqld

skip-host-cache

skip-name-resolve

datadir=/var/lib/mysql

socket=/var/run/mysqld/mysqld.sock

secure-file-priv=/var/lib/mysql-files

user=mysql

symbolic-links=0

pid-file=/var/run/mysqld/mysqld.pid

client

socket=/var/run/mysqld/mysqld.sock

!includedir /etc/mysql/conf.d/

!includedir /etc/mysql/mysql.conf.d/

3.挂载启动容器

bash 复制代码
$ docker run -p 3306:3306 --name mysql-01 --restart=always --privileged=true \
-v /opt/software/mysql/mysql-01/logs:/var/log/mysql \
-v /opt/software/mysql/mysql-01/data:/var/lib/mysql \
-v /opt/software/mysql/mysql-01/conf/my.cnf:/etc/my.cnf \
-v /etc/localtime:/etc/localtime:ro \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

参数解析:

  • --restart=always:总是跟随docker启动
  • --privileged=true:获取宿主机root权限
  • -e MYSQL_ROOT_PASSWORD=123456:指定mysql环境变量,root用户的密码为123456
  • -v /usr/local/mysql/data:/var/lib/mysql:映射数据目录,宿主机:容器

4.查看容器状态,测试链接

bash 复制代码
$ docker ps

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

9416e7e20cde mysql:5.7 "docker-entrypoint.s..." 13 minutes ago Up 3 minutes 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql-01

bash 复制代码
$ docker logs mysql-01

2024-05-23T09:02:28.555882Z 0 Note Event Scheduler: Loaded 0 events

2024-05-23T09:02:28.556181Z 0 Note mysqld: ready for connections.

Version: '5.7.44' socket: '/var/run/mysqld/mysqld.sock' port: 3306 MySQL Community Server (GPL)

bash 复制代码
$ docker exec -it mysql-01 mysql -uroot -p123456

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> exit

Bye

相关推荐
Solis程序员5 分钟前
长会话状态治理(下):数据更新机制、并发保护与可复用设计原则
运维·服务器
是个西兰花23 分钟前
linux:命名管道与共享内存
linux·运维·服务器·网络·c++
Snasph28 分钟前
Linux 日志流水线深度解析:syslog() → journald → rsyslog → /var/log/syslog
linux·syslog·rsyslog
凡人叶枫34 分钟前
Effective C++ 条款08:别让异常逃离析构函数
java·linux·数据库·c++·嵌入式开发
新时代牛马39 分钟前
内核调试方法
linux·学习
MXsoft61840 分钟前
**智慧校园运维实践:多校区、老旧设备的统一监控方案**
运维·自动化
Sean‘1 小时前
在隔离内网机器上使用 Filebeat 全量采集日志并推送到 ELK 的实战
运维·服务器·elk
Promise微笑1 小时前
精准微阻测量:微欧计的分类、场景应用与高效选型决策指南
大数据·运维·网络·人工智能
MageGojo1 小时前
R-Shell开源项目实战解析:用Rust打造命令行SSH工具,支持连接管理、远程执行、SFTP与MCP
运维·rust·开源项目·命令行工具·ssh客户端·mcp
云飞云共享云桌面1 小时前
非标设计工厂8-10个SolidWorks研发共享一台高性能工作站
运维·服务器·自动化·电脑·制造