我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Docker安装MySQL教程

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Docker安装MySQL教程

前言
虽然 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配置

创建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 。我们先进行第七步。

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

docker restart mysql

八、设置docker启动时启动mysql

docker update mysql --restart=always

九、重启mysql

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

10.1 进入容器内部

docker exec -it mysql /bin/bash

10.2 登陆mysql

mysql -u root -p

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

10.3 选择数据库

show databases;use mysql;

不要忘记最后的分号。

10.4 查看用户连接情况

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

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

10.5 修改密码认证方式

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

Docker安装MySQL教程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

centos7 docker 安装教程

本文教你如何在 CentOS 7 及以上版本进行 docker 安装。第一步,确定是centos7及以上版本
2023-06-05

docker安装mysql完美教程(建议收藏!)

最近使用docker,故将数据库和程序都用docker来一遍,下面这篇文章主要给大家介绍了关于docker安装mysql完美教程的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
2023-03-10

Linux安装Docker详细教程

目录介绍安装条件卸载旧版本安装方法常用命令卸载docker Compose编排安装卸载docker compose介绍 Docker利用linux核心中的javascript资源分脱机制,例如cgroups,以及Linux核心名字空间(na
2022-07-06

linux中docker的安装教程

Docker 软件包已经包括在默认的 CentOS-Extras 软件源里。因此想要安装 docker,只需要运行下面的 yum 命令:[root@localhost ~]# yum install docker启动 Docker 服务 安
2022-06-03

docker安装nacos的详细教程

这篇文章主要介绍了docker安装nacos,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-11-13

Docker安装Kafka教程(超详细)

首先创建一个网络 app-tier:网络名称 –driver:网络类型为bridge docker network create app-tier --driver bridge 1、安装zookeeper Kafka依赖zook
2023-08-19

docker安装postgresql的图文教程

目录1.查询PostgreSQL镜像 docker search postgres2.拉去镜像文件 docker pull postgres:14.23.镜像文件是否成功拉取 docker images4.创建挂载文件夹6.启动docker
2022-07-25

mysql安装使用教程 绿色版的mysql安装教程

本教程将详细介绍如何安装和使用 mysql 绿色版,一种无需安装即可运行的便携式数据库。mysql 是一种广泛使用的关系型数据库管理系统,因其速度、可靠性和可扩展性而闻名。本教程旨在帮助初学者和有经验的用户快速上手 mysql 绿色版,并可
mysql安装使用教程 绿色版的mysql安装教程
2024-10-17

mysql-5.7.42 安装教程

1.官网下载资源包 https://dev.mysql.com/downloads/mysql/5.7.html 2. 配置环境变量 找到 path 定位到bin文件夹下 3.mysql 安装目录下新增my.ini文件 复制内容:[my
2023-08-24

Docker 理论简介及安装教程

基于Linux而言,docker是在其中运行应用的一款开源工具,可以认为是一种轻量级的虚拟机。docker的logo是一条载着集装箱的鲸鱼(旧版的logo),新版的logo则是直接简化了细节,更改了颜色,如下图。从图片中就可以看出来,doc
2023-06-04

编程热搜

目录