美文网首页
Docker安装MySQL

Docker安装MySQL

作者: 枯萎天然呆 | 来源:发表于2023-06-19 11:30 被阅读0次

    一、拉取镜像

    # 拉取镜像
    docker pull mysql
     
    # 或者
    docker pull mysql:latest
     
    # 以上两个命令是一致的,默认拉取的就是 latest 版本的
     
    # 我们还可以用下面的命令来查看可用版本:
    docker search mysql
    

    二、查看镜像

    docker images
    
    2b52d28fc47b4933ecd4be6f45157b2a_13c13003f98b47a9b97c2fa2c5c504f8.png

    三、运行镜像

     -p 3306:3306:指定宿主机端口与容器端口映射关系
    --name mysql:创建的容器名称
    --restart=always:总是跟随docker启动
    --privileged=true:获取宿主机root权限
    -v /usr/local/mysql/log:/var/log/mysql:映射日志目录,宿主机:容器
    -v /usr/local/mysql/data:/var/lib/mysql:映射数据目录,宿主机:容器
    -v /usr/local/mysql/conf:/etc/mysql:映射配置目录,宿主机:容器
    -v /etc/localtime:/etc/localtime:ro:让容器的时钟与宿主机时钟同步,避免时区的问题,ro是read only的意思,就是只读。
    -e MYSQL_ROOT_PASSWORD=123456:指定mysql环境变量,root用户的密码为123456
    -d mysql:latest:后台运行mysql容器,版本是latest。
    

    四、查看正在运行的容器

    # 查看正在运行的容器
    docker ps
    # 查看所有的docker容器
    docker ps -a
    

    这个时候如果显示的是up状态,那就是启动成功了。如果是restarting,说明是有问题的。我们可以查看日志:

    docker logs -f mysql
    

    可能会发现:

    Failed to access directory for --secure-file-priv. Please make sure that dir
    

    此时如果我们执行第五步也会报错:

    Error response from daemon: Container xxx is restarting, wait until the cont。。。
    

    五、查看容器内部

    docker exec -it mysql /bin/bash
    

    六、修改mysql配置

    创建mysql配置文件:my.cnf

    cd /usr/local/mysql
    ll
    cd conf
    vi my.cnf
    

    在 my.cnf 文件中 写入如下内容:

    [client]
    default-character-set=utf8mb4
    [mysql]
    default-character-set=utf8mb4
    [mysqld]
    # 设置东八区时区
    default-time_zone = '+8:00'
    # 设置密码验证规则,default_authentication_plugin参数已被废弃
    # 改为authentication_policy
    #default_authentication_plugin=mysql_native_password
    authentication_policy=mysql_native_password
    
    # 限制导入和导出的数据目录
    # 为空,不限制导入到处的数据目录;
    # 指定目录,必须从该目录导入到处,且MySQL不会自动创建该目录;
    # 为NULL,禁止导入与导出功能
    #secure_file_priv=/var/lib/mysql
    secure_file_priv=
    init_connect='SET collation_connection = utf8mb4_0900_ai_ci'
    init_connect='SET NAMES utf8mb4'
    character-set-server=utf8mb4
    collation-server=utf8mb4_0900_ai_ci
    skip-character-set-client-handshake
    skip-name-resolve
    

    默认的鉴权方式,我们修改为mysql_native_password,不然的话连接会报错。因为在mysql8以后的默认加密方式改变了,由 mysql_native_password 改为了caching_sha2_password。这种加密凡是在客户端无法访问,客户端支持的是mysql_native_password 。我们先进行第七步。

    七、重启mysql服务,使其配置生效

    docker restart mysql
    

    八、设置docker启动时启动mysql

    docker update mysql --restart=always
    

    重启mysql

    docker restart mysql
    

    十、授权远程访问

    不进行授权直接登陆的话会报错的,如图:


    93a4dc59a1f78bc828eebbcf51725398_f58c1db8e9584a82ad33b4c813d986e7.png

    错误内容:

    Communications link failure
    The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received >any packets from the server.
    Connection refused: connect
    Connection refused: connect

    10.1 进入容器内部

    docker exec -it mysql /bin/bash
    

    10.2 登陆mysql

    mysql -u root -p
    

    此时我们使用mysql客户端连接服务器是失败的,因为默认的root不具有远程连接的权限。


    88e2a8bf6ea13e8d9e141e195b668951_f2053c84d035403aa2a6b060ae1992de.png

    上面的密码不要输入,直接回车进入。

    10.3 选择数据库

    show databases;
    use mysql;
    
    f65f9ba700b31f6c7c62e3d4bce1d0cb_af417d3b5e10479590cf8b23db4d1a01.png

    不要忘记最后的分号。

    10.4 查看用户连接情况

    select host, user, plugin,  authentication_string, password_expired from user;
    
    d4570c29a3240e021abc7ebae27c382e_ada21670fb1f4a2ebb97d1b31cb70b8a.png

    我们看到root用户只有localhost的连接权限。

    10.5 修改密码认证方式

    ALTER USER root@'%' IDENTIFIED WITH mysql_native_password BY '123456';
     
    ALTER USER root@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
     
    -- 刷新权限
    FLUSH PRIVILEGES;
    
    
    73215c103ba7ec2e80052bf6f426b974_9f48dae03dec4677b0a7924f88ccfdd2.png

    10.6 退出容器

    exit
    

    先输入exit退出mysql,再输入exit退出容器。

    此时,我们通过客户端工具就可以连接mysql了。

    相关文章

      网友评论

          本文标题:Docker安装MySQL

          本文链接:https://www.haomeiwen.com/subject/owkeydtx.html