docker 的mysql容器中没有mysqlbinlog

news2024/10/10 10:26:22

docker 的mysql容器中没有mysqlbinlog

  • bug信息
  • 原因:阉割版mysql容器,构建者没有把mysqlbinlog当成必需工具,去掉了
  • 解决方法:
  • 验证成功
  • 删除无用的文件
  • 5.7开启binlog,(8 的默认开启了)
  • 5.7版本的mysqlbinlog复制后可能出现的bug
    • 原因:libatomic命令有问题,版本冲突或者没安装,环境变量设置之类的问题
    • 解决方法:
      • 一:降低mysqlbinlog版本(强烈推荐)
      • 二:安装libatomic(头铁是吧)

bug信息

没有 mysqlbinlog 命令

sh: mysqlbinlog: command not found

(tips: MySQL的工具在/usr/bin下)

ls -l /usr/bin/my*




原因:阉割版mysql容器,构建者没有把mysqlbinlog当成必需工具,去掉了

解决方法:

思路:

  1. 从官方版没有阉割的容器中将mysqlbinlog工具复制过来
  2. 利用docker的cp,将容器文件经过本机中转到其他容器

(可以省略第一步、第二步,直接下载我复制存储在gitee的mysqlbinlog文件,点击跳转)

tips:mysql一些容器版本有自带mysqlbinlog ,一些没有,随手测试了一些版本,如下:
mysql 5.7
	有的:
		mysql:5.7.10(强烈推荐),mysql:5.7.31,mysql:5.7.32
	没有的:
		mysql:5.7.38,mysql:5.7.40,mysql:5.7.42

mysql 8 的好像要debian后缀的才有mysqlbinlog 
只测试了一个 mysql:8.0.32-debian(有的)
### 第一步
# 5.7版本 
docker run -d --name=del_mysql -e MYSQL_ROOT_PASSWORD=123 mysql:5.7.10
# 8.0版本
docker run d --name=del_mysql -e MYSQL_ROOT_PASSWORD=123 mysql:8.0.32-debian

### 第二步
# 随便找个本机地址存放,这里写 / (linux)或者 C:\(windows)
docker cp del_mysql:/usr/bin/mysqlbinlog  C:\
# or
docker cp del_mysql:/usr/bin/mysqlbinlog  /

### 第三步
#复制到你的mysql容器
docker cp c:\mysqlbinlog 你的mysql容器id或者名字:/usr/bin/
# or
docker cp /mysqlbinlog 你的mysql容器id或者名字:/usr/bin/

验证成功

# 进入你的容器
docker exec -it 你的容器名 /bin/bash
# 调用mysqlbinlog
mysqlbinlog

#或者不进入,单纯验证
docker exec -it 你的容器名 mysqlbinlog

成功的显示信息:

mysqlbinlog  Ver 8.0.30 for Linux on x86_64 (MySQL Community Server - GPL)
Copyright (c) 2000, 2022, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Dumps a MySQL binary log in a format usable for viewing or for piping to
the mysql command line client.

Usage: mysqlbinlog [options] log-files
  -?, --help          Display this help and exit.
....(略)

删除无用的文件

# 删除没必要的容器
docker rm -f del_mysql
#删除没必要的镜像
docker rmi mysql:5.7.10
# or 
docker rmi mysql:8.0.32-debian

#之后删除本机的文件即可
rm -f /mysqlbinlog
#或者windows(慎重,最好窗口手动删除,而不是命令行,可以两次ctrl c取消执行中的命令)
del C:\mysqlbinlog
# 坑!!! windows的del 
# del C:\mysqlbinlog 和del C:/mysqlbinlog完全不同!
#
# 坑1:del 找不到文件有一定可能会推荐你删除其他文件!!!不细看就会误删
#
# 神坑2:特别是正反斜杠!!!正确的是反斜杠(\)
# 正确:del C:\mysqlbinlog
# 错误,神坑: del C:/mysqlbinlog 只要是正斜杠(/),他直接识别为*,即是目录下全删除,这时会有个是否全删除的提示:
#				C:\*, 是否确认(Y/N)?




5.7开启binlog,(8 的默认开启了)

# 编辑配置文件
vim /etc/my.cnf
# 如果没有vim,直接docker cp出来改,再cp回去
# 添加下面几行,(我按照mysql 8的默认配置写的,开启binlog,路径,文件名,索引文件名)
server-id=1		# mysql集群分辨服务的id,必须集群内唯一
log-bin=/var/lib/mysql/binlog 	#如果你不是/var/lib/mysql/文件夹下的,你得确保你的文件夹是mysql群组,mysql用户具有必要的权限(chown chmod)

# 重启mysql容器

验证是否开启

# sql语句
show variables like '%log_bin%';

在这里插入图片描述
log_bin=ON :打开binlog日志
log_bin_basename=/var/lib/mysql/binlog : binlog日志的文件名前缀
log_bin_index=/var/lib/mysql/binlog.index; binlog文件的索引文件

容器内查看文件

ls -l /var/lib/mysql/bin*

在这里插入图片描述

关于mysql 5.7的binlog自定义文件夹位置(即自定义log-bin=/var/lib/mysql/binlog ),可以参考下这篇博客:开启mysql 5.7的binlog




5.7版本的mysqlbinlog复制后可能出现的bug

mysqlbinlog: error while loading shared libraries: libatomic.so.1: cannot open shared object file: No such file or directory

原因:libatomic命令有问题,版本冲突或者没安装,环境变量设置之类的问题

!!!:但是,最大的可能是你找的mysqlbinlog版本过高!

解决方法:

一:降低mysqlbinlog版本(强烈推荐)

#选择更低版本的mysql容器:如 mysql:5.7.10,之前选择mysql:5.7.31,导致出现libatomic版本和后续的glibc问题
docker run -d --name=del_mysql -e MYSQL_ROOT_PASSWORD=123 mysql:5.7.10
# 降低版本后,cp ,运行mysqlbinlog,完全无问题

二:安装libatomic(头铁是吧)

yum install libautomic

在这里插入图片描述
你有一定几率获取 新bug: 容器的glibc版本过低

sh-4.2# mysqlbinlog       
mysqlbinlog: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by mysqlbinlog)
mysqlbinlog: /lib64/libc.so.6: version `GLIBC_2.28' not found (required by mysqlbinlog)
mysqlbinlog: /lib64/libc.so.6: version `GLIBC_2.25' not found (required by mysqlbinlog)

在这里插入图片描述
此时你可以尝试以下2种方案:

  1. 包管理器更新glibc(推荐,但基本无效)
  2. 手动更新glibc(慎重,有惨烈案列,更新了,但是有一定几率再也启动不了容器)

包管理器更新glibc

yum update glibc
#查看更新后的glibc版本,第一次使用会下载点东西(60M左右)
yum info glibc

# 如果你发现版本没变,还是glibc 2.17,你可以再次挣扎下,更新yum的源缓存(基本无卵用),第一次使用会下载点东西(100M左右)
yum makecache

#再次更新,查看(基本可以恭喜你浪费了生命,喜提 2.17 版本信息),如果你升级到2.28以上,那么你没白费功夫
yum update glibc
yum info glibc | grep Version

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述



手动更新glibc(头铁圣体)
请查看这篇文章,祝你好运,尝试解决Linux提示:/lib64/libc.so.6: version GLIBC_2.XX’ not found
看之前先过眼下惨烈案列,慎重
在这里插入图片描述

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

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

相关文章

【论文阅读】ELA: Efficient Local Attention for Deep Convolutional Neural Networks

(ELA)Efficient Local Attention for Deep Convolutional Neural Networks 论文链接:ELA: Efficient Local Attention for Deep Convolutional Neural Networks (arxiv.org) 作者:Wei Xu, Yi Wan 单位:兰州大学信息…

高效测量“芯”搭档 | ACM32激光测距仪应用方案

激光测距仪概述 激光测距仪是利用激光对目标的距离进行准确测定的仪器。激光测距仪在工作时向目标射出一束很细的激光,由光电元件接收目标反射的激光束,计时器测定激光束从发射到接收的时间,计算出从观测者到目标的距离。激光测距仪分为手持激…

4核8G服务器租用优惠价格418元一年,可买3年

京东云4C8G云服务器优惠价格418元1年、1899元三年,配置为:轻量云主机4C8G-180G SSD系统盘-5M带宽-500G月流量,京东云主机优惠活动 atengyun.com/go/jd 可以查看京东云服务器详细配置和精准报价单,活动打开如下图: 京东…

【MySQL探索之旅】MySQL数据表的增删查改——约束

📚博客主页:爱敲代码的小杨. ✨专栏:《Java SE语法》 | 《数据结构与算法》 | 《C生万物》 《MySQL探索之旅》 |《Web世界探险家》 ❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更…

魔众众包系统——革命性的在线任务接单平台

魔众众包系统,一个革命性的在线任务接单平台,最新版本为v1.9.0,发布日期为2024年3月10日。这个平台不仅提供了一个高效的任务分配和管理环境,还通过其先进的技术架构,确保了系统的稳定性和可靠性。无论是对于企业还是个…

金蝶云星空和旺店通·旗舰奇门接口打通对接实战

金蝶云星空和旺店通旗舰奇门接口打通对接实战 对接源平台:金蝶云星空 金蝶K/3Cloud(金蝶云星空)是移动互联网时代的新型ERP,是基于WEB2.0与云技术的新时代企业管理服务平台。金蝶K/3Cloud围绕着“生态、人人、体验”,旨在帮助企业…

『大模型笔记』提示工程、微调和RAG之间对比

提示工程、微调和RAG之间对比 文章目录 一. 提示工程、微调和RAG之间对比二. 参考文章文章:Prompt Engineering vs Finetuning vs RAG一. 提示工程、微调和RAG之间对比 Prompt EngineeringFinetuning

2024年MathorCup数学建模思路B题思路分享

文章目录 1 赛题思路2 比赛日期和时间3 组织机构4 建模常见问题类型4.1 分类问题4.2 优化问题4.3 预测问题4.4 评价问题 5 建模资料 1 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 2 比赛日期和时间 报名截止时间:2024…

综合实验1

一、配置IP地址 [AR1]int g0/0/0 [AR1-GigabitEthernet0/0/0]ip add 192.168.1.254 24 [AR1-GigabitEthernet0/0/0]int se4/0/0 [AR1-Serial4/0/0]ip add 15.1.1.1 24 [AR1-Serial4/0/0] [AR2]int g0/0/0 [AR2-GigabitEthernet0/0/0]ip add 192.168.2.254 24 [AR2-Giga…

阿里云2核4G云服务器165元一年,ECS u1优惠价格199元一年

阿里云2核4G服务器租用优惠价格,轻量2核4G服务器165元一年、u1服务器2核4G5M带宽199元一年、云服务器e实例30元3个月,活动链接 aliyunfuwuqi.com/go/aliyun 活动链接如下图: 阿里云2核4G服务器优惠价格 轻量应用服务器2核2G4M带宽、60GB高效…

【python】深入探讨flask是如何预防CSRF攻击的

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…

【八大排序】一篇文章搞定所有排序

文章目录 1.排序的概念2.常见排序算法的实现2.1 插入排序2.1.1直接插入排序2.1.2希尔排序 2.2选择排序2.2.1直接选择排序:2.2.2堆排序 2.3交换排序2.3.1冒泡排序2.3.2快速排序Hoare法前后指针法挖坑法非递归版本 2.4归并排序递归版本非递归版本 2.5计数排序3.排序的比较 1.排序…

这款3D的小米su7的网页体验,你一定要进来看看

这款3D的小米su7的网页体验,你一定要进来看看 一、背景介绍二、技术介绍三、网站演示四、总结 大家好,这里是程序猿代码之路。今天主要给大家介绍一款3D的小米su7的网页体验背后的技术。随着互联网技术的不断进步,3D可视化已经成为在线展示和…

蓝桥杯基础练习汇总详细解析(一)——数列排序、十六进制转八进制、十六进制转十进制、十进制转十六进制、特殊回文数(代码实现、解题思路、Python)

试题 基础练习 数列排序 资源限制 内存限制&#xff1a;512.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述 给定一个长度为n的数列&#xff0c;将这个数列按从小到大的顺序排列。1<n<200 输入格式 第…

FalconHound:一款专为蓝队设计的BloodHound增强与自动化测试工具

关于FalconHound FalconHound是一款专为蓝队研究人员设计的多功能安全测试工具&#xff0c;该工具允许广大研究人员以更加自动化的形式增强BloodHound的能力&#xff0c;并将其整合进渗透测试活动中。除此之外&#xff0c;该工具还可以跟SIEM或其他日志聚合工具一起使用。 Fal…

【滑动窗口】Leetcode 将 x 减到 0 的最小操作数

题目解析 1658. 将 x 减到 0 的最小操作数 算法讲解 这道题按照题目要求的话会变得很难&#xff0c;因为不仅需要考虑数字减到0&#xff0c;还需要考虑最小的操作数。正难则反&#xff0c;按照这个思路&#xff0c;我们来解析题目 这道题本质上无非就是在左边寻找一段区间&a…

Flink CDC 同步数据到Doris

Flink CDC 同步数据到Doris Flink CDC 是基于数据库日志 CDC(Change Data Capture)技术的实时数据集成框架,支持了全增量一体化、无锁读取、并行读取、表结构变更自动同步、分布式架构等高级特性。配合 Flink 优秀的管道能力和丰富的上下游生态,Flink CDC 可以高效实现海量…

翔云身份证实名认证接口-PHP调用方法

网络平台集成实名认证接口&#xff0c;是顺应当下网络实名制规定&#xff0c;有效规避法律风险。互联网平台若没有实名认证功能&#xff0c;那么便无法保证网民用户身份的真实性&#xff0c;很有可能被虚假用户攻击&#xff0c;特别是在当网络平台产生垃圾信息乃至是违法信息时…

【JavaSE】java刷题——基础语法熟练应用

前言 通过本篇题目&#xff0c;可以让初学Java的小伙伴们更加熟练Java的基础语法~ 欢迎关注个人主页&#xff1a;逸狼 创造不易&#xff0c;可以点点赞吗~ 如有错误&#xff0c;欢迎指出~ 题1&#xff1a;数字9 出现的次数 题述&#xff1a;编写程序数一下 1到 100 的所有整数中…

芒果YOLOv8改进145:全新风格原创YOLOv8网络结构解析图

&#x1f4a1;本篇分享一下个人绘制的原创全新风格 YOLOv8网络结构图 感觉搭配还行&#xff0c;看着比较直观。 该专栏完整目录链接&#xff1a; 芒果YOLOv8深度改进教程 订阅了专栏的读者 可以获取一份 <可以自行修改 / 编辑> 的 YOLOv8结构图修改源文件 YOLOv8结构图…