文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Docker安装MySQL教程

2023-08-30 23:08

关注

前言
虽然 docker 安装 mysql 不是一个很好的方案,但是为了个人使用方便,使用 docker 安装 mysql 还是没什么问题的。

本文为了方便,我们直接通过yum方式安装。所以,我们在安装之前需要电脑可以联网,不然我们这种方式是安装不了的。

当然,你也可以自行下载mysql镜像,然后再通过 docker 安装,不过这不在本文的讨论范围。

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

使用以下命令来查看是否已安装了 mysql镜像

docker images
docker run -p 3306:3306 --name mysql --restart=always --privileged=true \-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 \-e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest

命令解决:

 -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配置文件: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_passwordauthentication_policy=mysql_native_password# 限制导入和导出的数据目录# 为空,不限制导入到处的数据目录;# 指定目录,必须从该目录导入到处,且MySQL不会自动创建该目录;# 为NULL,禁止导入与导出功能#secure_file_priv=/var/lib/mysqlsecure_file_priv=init_connect='SET collation_connection = utf8mb4_0900_ai_ci'init_connect='SET NAMES utf8mb4'character-set-server=utf8mb4collation-server=utf8mb4_0900_ai_ciskip-character-set-client-handshakeskip-name-resolve默认的鉴权方式,我们修改为mysql_native_password,不然的话连接会报错。因为在mysql8以后的默认加密方式改变了,由 mysql_native_password 改为了caching_sha2_password。这种加密凡是在客户端无法访问,客户端支持的是mysql_native_password 。我们先进行第七步。
docker restart mysql
docker update mysql --restart=always
docker restart mysql

不进行授权直接登陆的话会报错的,如图:
在这里插入图片描述
错误内容:
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

docker exec -it mysql /bin/bash
mysql -u root -p

此时我们使用mysql客户端连接服务器是失败的,因为默认的root不具有远程连接的权限。
在这里插入图片描述
上面的密码不要输入,直接回车进入。
#

show databases;use mysql;

不要忘记最后的分号。

select host, user, plugin,  authentication_string, password_expired from user;

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

ALTER USER root@'%' IDENTIFIED WITH mysql_native_password BY '123456';

注意:此处如果报错:ERROR 1410 (42000): You are not allowed to create a user with GRANT
请先创建用户和授权:
产生用户不能授权的原因是mysql 数据库中user 表中的特定用户(root) 的host 的属性值为localhost.
解决办法如下:

# 使用mysql 数据库mysql > use mysql;# 特定用户的host 修改mysql > update user set host='%' where user='root';# 指定用户的授权mysql > grant all privileges on test.* to root@'%'

– 刷新权限

FLUSH PRIVILEGES;

6 退出容器

exit

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

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

参考链接:https://blog.csdn.net/qq_42971035/article/details/127831101

来源地址:https://blog.csdn.net/m0_63364103/article/details/131243025

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯