mysql镜像创建docker容器,及其可能遇到的问题

前提,已经弄好基本的docker服务了。

一、基本流程

1、目录准备

我自己的资料喜欢放在 /data 目录下,所以老规矩:

先进入 /data 目录:

cd /data

创建 mysql 目录:

mkdir mysql

2、镜像查找

docker search hub.rat.dev/mysql:8.0.27

3、镜像拉取

docker pull hub.rat.dev/mysql:8.0.27

4、创建容器

docker run -id \
-p 3306:3306 \
--name=mysql \
-v $PWD/conf:/etc/mysql/conf.d \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=151128 \
hub.rat.dev/mysql:8.0.27

5、查看容器

docker ps

二、各类问题合集

1、【解决】mysql镜像拉取出现网络错误

镜像加速器参照(下面的连接会不断更新国内能够使用的Docker镜像源,可以自己看看,自己的服务器可以用哪一个或者哪几个):

国内能用的Docker镜像源【2025最新持续更新】_docker 镜像-CSDN博客

有哪些可以用的镜像加速器、具体怎么使用,参照上文即可。

2、【解决】caching sha2 password

(1)背景

docker容器使用的mysql镜像是9版本。

我电脑安装的navicat是16,同事应该是12及以下的版本。

我的电脑用navicat连接远程服务器的mysql,没有问题。但同事的不可以,会报错。

显示:Authentication plugin 'caching sha2 password' cannot be loaded

(2)原因

在使用 MySQL 8 及以上版本时,默认的加密方式是 caching_sha2_password,而在 MySQL 8 之前的版本中,默认的加密方式是 mysql_native_password。因此,当使用一些旧版本的客户端(如 Navicat Premium 12)连接 MySQL 数据库时,可能会出现 Authentication plugin 'caching_sha2_password' cannot be loaded 的错误。

(3)解决思路

更换一下加密方式,参照网络文档(直接走这个文档,mysql镜像版本太高的话,会报错):

navicat连接MySQL8.0提示caching_sha2_password问题解决方法-CSDN博客

报错信息:

ERROR 1524 (HY000): Plugin 'mysql_native_password' is not loaded

(4)【解决】mysql_native_password is not loaded

检查了一下,发现是mysql镜像太高了,到9了。

查看mysql镜像版本:打开与数据库的连接,不需要引用表,直接输入查询语句。

SELECT VERSION();

具体操作见 3。

3、更换mysql镜像

那么,现在需要把mysql镜像的版本降下来。

(1)备份数据!!!

(2)备份数据!!!

(3)备份数据!!!

把所有数据库表的转储成sql下来,转储的时候千万把数据一起转储出来,别只转储了表结构。

记录所有数据库表的名称、字符集、排序规则。等一下要还原回去的。

(4)停止mysql容器

docker stop mysql

(5)mysql数据文件夹

cd /data
mv mysql mysql.bak

将mysql对应的数据文件夹进行重命名,后期如果创建失败,能够把文件夹重新还原回去。

(6)创建mysql容器

参照一、基本流程进行

(7)进入mysql容器内部

docker exec -it mysql /bin/bash

需要注意:如果刚刚stop的容器叫mysql,又没有删除。那么这次创建的容器就不能够叫mysql,可以改成 mysql_3306 或者其他。

(8)打开mysql

mysql -uroot -p

回车后输入密码即可。

或者-p后面直接带上密码,然后回车。

(9)跟着文档走一次

navicat连接MySQL8.0提示caching_sha2_password问题解决方法-CSDN博客

(10)用navicat连接mysql

应该就可以了。

(11)数据还原

依次:建数据库 - 按照名称、字符集、排序进行回填 - 运行转储的sql文件

(12)碎碎念

本来不想这么麻烦的,有别的方式可以解决报错:

ERROR 1524 (HY000): Plugin 'mysql_native_password' is not loaded

参考文档(写得非常清晰,鼓掌):

ERROR 1524 (HY000): Plugin ‘mysql_native_password‘ is not loaded-CSDN博客

但是我弄的这个镜像,什么命令都没有:vim、yum、apk、apt-get、dnf、apt、wegt.......

倒是rpm、curl、mv可以用,通过curl下载下来的rpm包,rpm -ivh又一直报错。

查了一下 /etc/os-release,是Oracle Linux Server。

我直接访问:

Oracle Linux 7 (x86_64) Latest | Oracle, Software. Hardware. Complete.

一看,n个包,尝试手动下载,初略下载了几个,然后通过docker创建容器映射的目录方式,迁移到容器内部。然后开始摆烂。

你依赖我,我依赖它的,啊啊啊啊。不下载了。

想了想,也不是非要去改my.cnf。但是同事又连不上mysql,如果不通过升级navicat的版本的方式,就只能去降mysql镜像版本了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/75025.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

快速记忆法,提高知识点背诵效率

战国七雄:齐秦 韩赵魏 燕楚 谐音记忆:齐秦 喊赵薇 演出 五等爵位:公侯 伯子 男 记忆方法:公猴 脖子 蓝 安卓应用:记忆宫殿APP 记忆 脑力训练,中小学各学科知识点速记,单词趣味记忆&#xff0c…

从零开始学java--泛型(1)

泛型 学生成绩可能是数字类型,也可能是字符串类型,如何存放可能出现的两种类型呢: public class Score {String name;String id;Object value; //因为Object是所有类型的父类,因此既可以存放Integer也能存放Stringpublic Score…

pdf转latex

Doc2X(https://doc2x.noedgeai.com/) Doc2X 是一个由 NoEdgeAI 提供的在线工具,主要用于将 PDF 文件(尤其是学术论文、报告等文档)转换为 LaTeX 格式。LaTeX 是一种高质量排版系统,广泛应用于学术界和出版…

Visual Studio 2022 UI机器学习训练模块

VS你还是太超标了,现在机器学习都不用写代码了吗!! 右键项目解决方案,选择机器学习模型

无公网实体服务器加装多个操作系统供多个用户互不打扰使用_part1

背景介绍 因笔者业务需求,入手了一个实体服务器,但为了避免出现在一个操作系统中搭建编程环境后有许多相关的进程和服务,拖慢日常的使用,也能让其他人短期使用,更好的利用服务器的性能,让服务器专注于“什…

运动规划实战案例 | 基于四叉树分解的路径规划(附ROS C++/Python仿真)

目录 1 为什么需要四叉树?2 基于四叉树的路径规划2.1 分层抽象2.2 路图搜索2.3 动态剪枝 3 算法仿真3.1 ROS C算法仿真3.2 Python算法仿真 1 为什么需要四叉树? 路径规划的本质是在给定环境中寻找从起点到终点的最优或可行路径,其核心挑战在…

docker快捷打包脚本(ai版)

直接进入主题: 用这个脚本前提是你本地可以拉镜像仓库的镜像,并且在 本地有了,然后将所有的镜像tag写在一个文件中,和下面docker_tags.txt 对应,文件叫什么,脚本里对应改什么,给小白说的 #!/bi…

WinMerge下载及使用教程(附安装包)

文章目录 一、WinMerge安装步骤1.WinMerge下载:2.解压:3.启动: 二、WinMerge使用步骤1.添加文件或文件夹2.查看差异3.格式选择 WinMerge v2.16.36 是一款免费开源的文件与文件夹比较、合并工具,能帮您快速找出差异,提高…

Jmeter性能测试之生成测试报告

结构 测试计划 测试计划是顶级的层级⽬录的结构, 那么在这样的⽬录结构中,⾥⾯可以包含很多线程组 线程组 线程组我们可以简单的理解为postman测试⼯具⾥⾯的collection,那么在整体线程组⾥⾯,可以添加很多的测试 ⽤例 简单控…

CSS中的inline-flex与flex的区别

在CSS中,flex 和 inline-flex 都是用于实现弹性布局(Flexbox)的显示属性,但它们在布局行为上有所不同。 flex 属性会使元素表现为块级弹性容器,这意味着元素会在页面上占据一整行的空间,无论其内部内容的大…

Linux的那些基础常用命令汇总

目录 前言: 用户命令: 管理后台作业命令: 文件目录操作命令: 运维高频使用命令: 磁盘管理以及文件系统命令: 用户、组操作命令: 权限控制命令: 网络配置命令: 软件管理命令…

高效深度学习lecture03

lecture_03 **剪枝:**pruning basically turns a dense neural network into a sparse neural network. you can remove those redundant synapses, and also you can remove those redundant neurons. 剪枝的本质上是将稠密的神经网络转变成稀疏的神经网络&#…

Nextjs15 实战 - React Notes 项目初始化

current branch 对应如下文档 redis ioredis 本专栏内容均可在Github:notes_01 找到 一、效果 完整项目使用技术栈: Nextjs15 MySQL Redis Auth Prisma i18n strapi Docker vercel 二、修改根布局和其他页面 修改 app/page.tsx&#xff1a…

Flutter PopupMenuButton 深度解析:从入门到架构级实战

在移动应用交互设计中,上下文菜单如同隐形的魔法师,在有限屏幕空间中优雅地扩展操作维度。作为Flutter框架中的核心交互组件,PopupMenuButton绝非简单的菜单触发器,其背后蕴含着Material Design的交互哲学、声明式UI的架构智慧以及…

C++——清明

#include <iostream> #include <cstring> #include <cstdlib> #include <unistd.h> #include <sstream> #include <vector> #include <memory> #include <ctime>using namespace std;class Weapon; // 前置声明class Hero{ pr…

es --- 集群数据迁移

目录 1、需求2、工具elasticdump2.1 mac安装问题解决 2.2 elasticdump文档 3、迁移 1、需求 迁移部分新集群没有的索引和数据 2、工具elasticdump Elasticdump 的工作原理是将输入发送到输出 。两者都可以是 elasticsearch URL 或 File 2.1 mac安装 前置&#xff1a;已经安装…

鸿蒙开发_ARKTS快速入门_语法说明_组件声明_组件手册查看---纯血鸿蒙HarmonyOS5.0工作笔记010

然后我们来看如何使用组件 可以看到组件的组成 可以看到我们使用的组件 然后看一下组件的语法.组件中可以使用子组件. 然后组件中可以有参数,来修改组件的样式等 可以看到{},这种方式可以设置组件参数,当然在下面. 的方式也可以的 然后再来

【GEE学习笔记】报错解决:Sentinel-2 数据集分为 L1C(大气顶层)和 L2A(地表反射率),如何选择波段进行去云处理?

【GEE学习笔记】报错解决&#xff1a;Sentinel-2 数据集分为 L1C&#xff08;大气顶层&#xff09;和 L2A&#xff08;地表反射率&#xff09;&#xff0c;如何选择波段进行去云处理&#xff1f; 【GEE学习笔记】报错解决&#xff1a;Sentinel-2 数据集分为 L1C&#xff08;大…

OpenVLA-OFT——微调VLA时加快推理的三大关键设计:支持动作分块的并行解码、连续动作表示以及L1回归(含输入灵活化及对指令遵循的加强)

前言 25年3.26日&#xff0c;这是一个值得纪念的日子&#xff0c;这一天&#xff0c;我司「七月在线」的定位正式升级为了&#xff1a;具身智能的场景落地与定制开发商 &#xff0c;后续则从定制开发 逐步过渡到 标准产品化 比如25年q2起&#xff0c;在定制开发之外&#xff0…

IDEA 使用Maven打包时内存溢出

IDEA 使用Maven打包时内存溢出 解决办法&#xff1a; File -> settings -> Build,Excetion,Deployment-> Compiler 中添加配置“-Djps.track.ap.dependenciesfalse” 如图&#xff1a;