• 如何在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 ~]# 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    4、镜像列表
    [root@localhost ~]# docker images
    REPOSITORY   TAG       IMAGE ID       CREATED      SIZE
    mysql        8.0.31    2a04bf34fdf0   6 days ago   535MB
    [root@localhost ~]# 
    
    • 1
    • 2
    • 3
    • 4
    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
    
    • 1
    • 2

    ​ 注意:

    ​ 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
    
    • 1
    • 2
    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 ~]#
    
    • 1
    • 2
    • 3
    • 4
    7、开放端口
    [root@localhost docker]# firewall-cmd --zone=public --add-port=3307/tcp --permanent
    [root@localhost docker]# firewall-cmd --reload
    
    • 1
    • 2
    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’;

  • 相关阅读:
    计算机结构体系:主存例题(存储器组织技术)
    【广度优先搜索】leetcode 542. 01 矩阵
    RequestContextHolder
    字节一面:HTTPS 会加密 URL 吗?
    什么时候去检测大数据信用风险比较合适?
    Nginx负载均衡和动静分离实例
    为什么mac上有的软件删除不掉?
    O-RAN学习笔记之O-RAN、OpenRAN、C-RAN、vRAN、xRAN
    基于MATLAB的一级倒立摆控制仿真,带GUI界面操作显示倒立摆动画,控制器控制输出
    VIAVI唯亚威FI-10/-11 光纤识别仪
  • 原文地址:https://blog.csdn.net/wangshuxuncom/article/details/127890857