Docker安装MySql 5.7

本文详细介绍了如何使用Docker安装MySQL 5.7版本,包括拉取镜像、配置数据文件夹、设置密码及权限等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为什么安装MySql 5.7?因为。。那个。。。

默认已创建数据文件夹 /data/mysql

1、拉取镜像

docker pull mysql:5.7

2、执行安装

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

-p 3306:3306 端口映射:前表示主机部分,:后表示容器部分

--name 指定该容器名称

-v 挂载目录,规则与端口映射相同

-e 传递环境变量,这里设置mysql密码是123456

-d mysql:5.7后台运行,因为拉取的镜像是5.7版本,这里mysql后必须加:5.7指定版本,不指定则会运行latest版本(这里没拉取,会报找不到镜像)

3、进入容器

docker exec -it  mysql bash

登录MySql

mysql -uroot -p123456

如果出现

 

 mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

需要做如下配置

进入挂载目录 /data/mysql/conf.d,并创建文件my.cnf

cd /data/mysql/conf.d
touch my.cnf

文件中添加

[mysqld]
skip-grant-tables

重启mysql,并进入容器内部

docker restart mysql
docker exec -it mysql bash

登录mysql,设置root密码为空 

mysql -uroot -p
update user set authentication_string='' where user='root';
flush privileges;

清空my.cnf中的内容,并重启mysql

再次进入容器内部,用root登录

mysql -uroot

 设置密码为123456 

alter user 'root'@'localhost' IDENTIFIED BY '123456';
alter user 'root'@'%' IDENTIFIED BY '123456';
flush privileges;

添加授权

GRANT all ON . TO 'root'@'%' IDENTIFIED BY '123456';
flush privileges;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值