为什么安装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;