如何在Docker中安装MySQL数据库

Posted 程序猿老高

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在Docker中安装MySQL数据库相关的知识,希望对你有一定的参考价值。

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’;

以上是关于如何在Docker中安装MySQL数据库的主要内容,如果未能解决你的问题,请参考以下文章

如何在Docker中安装MySQL数据库

如何在Docker中安装MySQL

如何在Docker中安装MySQL

如何在Docker中安装MySQL

如何在ubunto中安装docker

如何在docker中安装vsftp