1、Docker环境
视频教程:https://www.bilibili.com/video/BV1xv4y1S7kA
2、搜索镜像
https://hub.docker.com/网站搜索MySQL,确定其安装版本,这里安装8.0.31版;
3、拉取镜像
[root@localhost ~]# docker pull mysql:8.0.31
8.0.31: Pulling from library/mysql
feec22b5b798: Pull complete
...省略...
e0ead729abd9: Pull complete
Digest: sha256:717e6f25ed8997b7ecb0408e063c4dcba202a68b341ebac4c4d97f51439b87ee
Status: Downloaded newer image for mysql:8.0.31
docker.io/library/mysql:8.0.31
[root@localhost ~]#
4、镜像列表
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mysql 8.0.31 2a04bf34fdf0 6 days ago 535MB
[root@localhost ~]#
5、创建并运行容器
语法:docker run [–name containerName**]** ‐d ‐p 3307:3306 [–restart=always**]** imageName[:tag],其中containerName表示自定义容器名;-d表示后台运行;-p用于将Linux操作系统端口映射到容器内部端口;–restart=always设置当前容器随docker重启而自动启动,省略该参数,则该容器不会随docker重启而自行启动,即不会随Linux系统重启而启动;imageName表示镜像名称;tag表示镜像版本
例子:
[root@bogon ~]# docker run --name mysql -d -p 3307:3306 --restart=always -e MYSQL_ROOT_PASSWORD=123456 mysql:8.0.31
da6878836176a0a9bf3f9c8a93ce1a5685c5037d0100c72a57befb394521d005
注意:
a、通过镜像创建容器后该镜像不允许删除,必须先删除容器;
b、运行中容器不允许被删除,必须先停止容器运行;
c、-e MYSQL_ROOT_PASSWORD=123456用于设置初识密码,否则提示如下错误:
2020-12-20 15:29:03+00:00 [ERROR] [Entrypoint]: Database is uninitialized and password option is not specified
You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD
6、查看容器
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
da6878836176 mysql:8.0.31 "docker-entrypoint.s…" a minute ago Up About a minute 33060/tcp, 0.0.0.0:3307->3306/tcp, :::3307->3306/tcp mysql
[root@localhost ~]#
7、开放端口
[root@localhost docker]# firewall-cmd --zone=public --add-port=3307/tcp --permanent
[root@localhost docker]# firewall-cmd --reload
8、问题
SQLyog远程连接MySQL,提示如下错误:
方案:
a、进入容器内部:docker exec -it 容器ID /bin/bash
b、登录MySQL: mysql -uroot -p
c、修改配置:alter user ‘root’@‘%’ identified with mysql_native_password by ‘123456’;