百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

mysql源码编译所需的gcc版本与官方说明的不一致

itomcoil 2025-09-11 21:04 5 浏览

这段时间为了解决mysql的2038年问题可真是操碎了心,原来使用的mysql属于低版本,只要系统时间调整超过2038年1月19日就会自动停止mysql服务,为了解决问题,只能使用不低于v8.0.28的高版本mysql(详见之前的文章《MySQL彻底解决2038年问题》)。

一、 使用高版本mysql的困境

要使用高版本mysql,参考官方源码包中的cmake/os/Linux.cmake说明文件,只能使用高版本gcc进行编译,经过下载多个不同高版本的mysql源码包,查看编译mysql所需的gcc版本分别如下:

(1)v8.0.40版本mysql,需要gcc 7.1或者更高版本

# We require at least GCC 7.1 Clang 5

IF(NOT FORCE_UNSUPPORTED_COMPILER)

IF(MY_COMPILER_IS_GNU)

IF(CMAKE_CXX_COMPILER_VERSION VERSION_LESS 7.1)

MESSAGE(FATAL_ERROR "GCC 7.1 or newer is required")

ENDIF()

(2)v8.4.2版本mysql,需要gcc 10或者更高版本

# We require at least GCC 10 Clang 12

IF(NOT FORCE_UNSUPPORTED_COMPILER)

IF(MY_COMPILER_IS_GNU)

# gcc9 is known to fail

IF(CMAKE_CXX_COMPILER_VERSION VERSION_LESS 10)

MESSAGE(FATAL_ERROR "GCC 10 or newer is required")

ENDIF()

(3)v9.0.1版本mysql,需要gcc 10或者更高版本

# We require at least GCC 10 Clang 12

IF(NOT FORCE_UNSUPPORTED_COMPILER)

IF(MY_COMPILER_IS_GNU)

# gcc9 is known to fail

IF(CMAKE_CXX_COMPILER_VERSION VERSION_LESS 10)

MESSAGE(FATAL_ERROR "GCC 10 or newer is required")

ENDIF()

(4)v9.4.0版本mysql,需要gcc 11或者更高版本(不知道你注意到没有,说明文件中的注释说明和cmake代码对gcc的版本要求说明还不一致,算是一个小BUG吧^_^)

# We require at least GCC 10 Clang 14

IF(NOT FORCE_UNSUPPORTED_COMPILER)

IF(MY_COMPILER_IS_GNU)

# gcc10 is known to fail

IF(CMAKE_CXX_COMPILER_VERSION VERSION_LESS 11)

MESSAGE(FATAL_ERROR "GCC 11 or newer is required")

ENDIF()

抛开通用环境,对于一些已经使用多年的自定义环境,因为一些原因,升级高版本gcc意味着文件系统也要顺势升级,对应的libc库会进行更改,必然会带来整个系统从底层到上层的巨大变化,代价不可谓不高。

后面考虑使用独立高版本gcc环境编译程序,然后把编译好的程序放到低版本gcc环境运行,但是因为双方libc库版本的不一致,高版本gcc对应系统的libc库版本也同样高于低版本gcc对应系统的libc库,所以又是此路不通。

二、低版本gcc编译高版本mysql

抛开自定义环境,虽然mysql源码包中的说明明确了源码编译所需的gcc版本,但是抱着实践测试验证的想法,在通用环境使用v7.3版本的gcc进行了v8.0.40版本mysql的编译操作,按照v8.0.40版本mysql源码包中的说明,应该是能够编译通过。但是很可惜,结果是相反的。编译失败了, 原因是v8.0.40版本mysql自带了高版本的protobuf代码,代码中的部分语法在v7.3版本的gcc中编译失败。但是换成10版本的gcc后编译正常,mysql能够正常运行。将系统时间调整到大于2038年的时间,mysql服务依然正常运行。

基于前述过程使用v7.3和v10版本的gcc再次编译v8.4.2版本mysql,结果与v8.0.40版本mysql的编译结果一致,v7.3版本gcc编译失败的位置与之前一模一样。按照这个结果来看,v8.4.2版本mysql源码包中的gcc编译版本说明又是对的。

对于强迫症的我来说,反正也到这个点了,顺便就使用v9.3.1版本gcc对v9.0.1和v9.4.0版本mysql进行了源码编译,结果又是大出意料,两个版本的mysql版本都编译成功。而按照对应版本mysql源码包中的编译说明文件,v9.0.1版本mysql编译需要v10或者更高版本gcc,v9.4.0版本mysql编译需要v11或者更高版本gcc,而当前gcc是v9.3.1版本,分别垮了1个大版本号和2个大版本号,真是奇了怪哉!

至此,总结前述4个版本mysql源码编译所需的实际gcc版本与说明要求是否准确结果如下:

(1)v8.0.40版本mysql,需要gcc 7.1或者更高版本(不准确,gcc 7.3编译失败,gcc 10编译成功)

(2)v8.4.2版本mysql,需要gcc 10或者更高版本(准确,gcc 7.编译失败,gcc 10编译成功)

(3)v9.0.1版本mysql,需要gcc 10或者更高版本(不准确,gcc 9.3.1编译成功)

(4)v9.4.0版本mysql,需要gcc 11或者更高版本(不准确,gcc 9.3.1编译成功)

三、结语

mysql的源码编译存在实际情况与官方说明不一致的地方,肯定就有在其它我们不知道的地方,也存在类似情况。举一反三,我们参与或者接触的其它事项,是不是也存在类似情况?所以说,学习学习,真的不能书本上说什么就完全相信,还是需要结合实践。尽信书不如无书,可能也是想表达这个意思吧。儒家说学习就是博学、审问、慎思、明辨、笃行,最终还是要落到实践(即笃行)上,古人诚不欺我啊!

四、联系

如果有任何疑问欢迎随时交流。学无止境,实事求是,每天进步一点点!

相关推荐

python数据分析中你必须知道的陷阱和技巧

数据分析是一门既有趣又有挑战的技能,它可以帮助我们从海量的数据中提取有价值的信息,为决策提供支持。但是,数据分析也不是一件轻松的事情,它需要我们掌握一定的编程、统计、可视化等知识,同时也要注意避免一些...

python常见五大坑及避坑指南_python解决什么问题

python是一门非常流行和强大的编程语言,但是也有一些容易让初学者或者不熟悉的人掉入的坑。这里列举了一些python常见五大坑,以及如何避免或者解决它们。缩进问题。python使用缩进来表示代码块,...

收藏!2022年国家职业资格考试时间表公布

人社部14日公布2022年度专业技术人员职业资格考试工作计划,包括中小学生教师资格、会计师、精算师、建造师等各项考试日期。其中,证券期货基金业从业人员资格各次考试地点不同,具体安排以相关行业协会考试公...

苹果mac系统必须安装python3_macbook安装python3.7

苹果mac系统必须安装python3苹果mac系统口碑很好,但不能像linux系统一样同时提供python2和python3环境,对程序员来说是非常不友善的。资深程序员都知道,Python3才是P...

通过python实现猴子吃桃问题_python小猴子吃桃的问题

1、问题描述:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个,第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,就只剩...

python 中的第一个 hello world 程序输出

程序运行:print("helloworld")我使用的是Python程序3.7.0版本介绍下print概念print字面意思打印,将文本输出内容打印出来输入:print(&...

持久化 Python 会话:实现数据持久化和可重用性

Midjourney生成R语言会话持久化熟悉或常用R语言进行数据分析/数据挖掘/数据建模的数据工作者可能对R语言的会话保存和会话恢复印象比较深刻,它可以将当前session会话持久化保存,以便分...

如何将Python算法模型注册成Spark UDF函数实现全景模型部署

背景Background对于算法业务团队来说,将训练好的模型部署成服务的业务场景是非常常见的。通常会应用于三个场景:部署到流式程序里,比如风控需要通过流式处理来实时监控。部署到批任务中部署成API服...

Python 字典l转换成 JSON_python转化字典

本文需要5分钟。如果对您有用可以点赞评论关注.Python字典到JSONJSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,它基于ECMAScrip...

[python] 基于PyOD库实现数据异常检测

PyOD是一个全面且易于使用的Python库,专门用于检测多变量数据中的异常点或离群点。异常点是指那些与大多数数据点显著不同的数据,它们可能表示错误、噪声或潜在的有趣现象。无论是处理小规模项目还是大型...

总结90条写Python程序的建议_python写程序的步骤

  1.首先  建议1、理解Pythonic概念—-详见Python中的《Python之禅》  建议2、编写Pythonic代码  (1)避免不规范代码,比如只用大小写区分变量、使用容易...

ptrade系列第六天:持久化处理2_持久化的三种状态

前一次跟大家分享了利用pickle进行策略数据的持久化。但是这种方式有个问题,就是保存下来的数据无法很直观的看到,比较不方便,所以今天给大家带来另一种方式,将数据通过json保存。importjso...

Python数据持久化:JSON_python的json用法

编程派微信号:codingpy上周更新的《ThinkPython2e》第14章讲述了几种数据持久化的方式,包括dbm、pickle等,但是考虑到篇幅和读者等因素,并没有将各种方式都列全。本文将介绍...

干货 | 如何利用Python处理JSON格式的数据,建议收藏

作者:俊欣来源:关于数据分析与可视化JSON数据格式在我们的日常工作中经常会接触到,无论是做爬虫开发还是一般的数据分析处理,今天,小编就来分享一下当数据接口是JSON格式时,如何进行数据处理进行详...

Python中Pyyaml模块的使用_python模块介绍

一、YAML是什么YAML是专门用来写配置文件的语言,远比JSON格式方便。YAML语言的设计目标,就是方便人类读写。YAML是一种比XML和JSON更轻的文件格式,也更简单更强大,它可以通过缩进来表...