在docker中运行mysql容器

今天打算在一台新机器上安装mysql,一时想不起来安装步骤,同时又觉得查看文档很麻烦。

正好之前自学了docker容器相关的内容,就想在容器中安装mysql。

在容器中安装mysql,要解决一下几个问题:

  1. 需要配置宿主机中的端口到mysql容器中的3306端口
  2. 需要设置mysql的密码环境变量
  3. 需要用docker中的卷来挂载相关内容,例如数据、日志和配置文件。因为如果不用卷来存储数据的话,容器停止运行后,mysql中存储的数据都会丢失。

首先拉取mysql的docker镜像:

bash 复制代码
docker pull mysql

然后在命令行执行下面的语句:

bash 复制代码
docker run --name mysql-container -e MYSQL_ROOT_PASSWORD=xxx -d \
-p 3306:3306 \
-v data_path:/var/lib/mysql \
-v logs_path:/var/log/mysql \
-v conf_path:/etc/mysql/conf.d \
mysql

--name 指定容器名。

-e 设置环境变量(具体的环境变量名可以看对应容器github上的说明),这里指定了root密码。

-d 在后台运行,也是docker的基本指令之一。

-p 设置端口映射。这里前一个3306是宿主机的端口。

-v 设置卷,将宿主机中对应的path挂载到容器中,这样容器中存储的数据会显示到卷的路径中。这里我在本地创建了3个空文件夹。

这样一个mysql就安装完成了,如何后面想要卸载mysql,直接删除容器即可,比安装在本地再删除的麻烦步骤比起来方便多了。

执行下面的命令就能进入创建的mysql容器,它会进入容器并启动base shell,就相当于我们在本地命令行中一样操作mysql就行。

bash 复制代码
docker exec -it mysql-container /bin/bash
相关推荐
唐青枫1 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
小满8781 天前
5.Mysql事务隔离级别与锁机制
mysql
元Y亨H2 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
这个DBA有点耶3 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵3 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
SamDeepThinking3 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
Patrick_Wilson4 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
Suroy4 天前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭4 天前
运行你的第一个Docker容器
后端·docker·容器
李白客5 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库