docker 安装mysql5.7+ 设置容器卷 + 修改初始密码


安装教程:

1.拉取mysql镜像

docker pull mysql:5.7

2.创建用于挂载的目录

mkdir -p /docker/mysql/logs /docker/mysql/conf /docker/mysql/data

3.使用镜像创建容器

将容器中MySQL的3306端口映射到本地的3307端口,并设置登录密码为:123456

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

命令解析
–name:容器名
–p:映射宿主主机端口
-v:挂载宿主目录到容器目录
-e:设置环境变量,此处指定root密码
-d:后台运行容器

4.进入容器

docker start 容器ID

docker exec -it 容器名字 /bin/bash

[root@dc01 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
96a49c6e7235 mysql:5.7 "docker-entrypoint.s…" 4 weeks ago Up 2 minutes 0.0.0.0:3306->3306/tcp mysql5.7
fa56f865bd26 nginx:latest "nginx -g 'daemon of…" 4 weeks ago Up 16 minutes 0.0.0.0:80->80/tcp vigilant_swirles

[root@dc01 ~]# docker exec -it 96a49c6e7235 /bin/bash
root@96a49c6e7235:/# mysql -uroot -p123456

首先按照上面安装完成否则目录无效

5.表名区分大小写

在宿主机上该目录下:/data/mysql/conf创建一个mysql.cnf
/data/mysql/conf/mysql.cnf添加如下内容

[mysqld]
lower_case_table_names=1

重启mysql

6.修改密码

在宿主机上该目录下:/data/mysql/conf创建一个mysql.cnf
/data/mysql/conf/mysql.cnf

6.1最后一行添加如下内容 增加“忘记密码启动”模式:skip-grant-tables

[mysqld]
lower_case_table_names=1
skip-grant-tables

6.2重启mysq5.7

docker restart mysql5.7

6.3进入容器 密码处直接回车即可

[root@localhost ~]# docker exec -it 03a /bin/bash
root@03a440ccb869:/# mysql -u root -p
Enter password:

6.4修改密码:

txmail换成你的密码

mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'txmail';
Query OK, 0 rows affected (0.00 sec)

6.5docker 重启mysql

6.6删除第6步的skip-grant-tables

6.7 docker 重启mysql


完成

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

怒放de生命2010

您的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值