MySQL 5.7源码编译后制作RPM包

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 源码编译后,打包成RPM包,yum install 大规模部署RPM,更适合自动化运维部署。

1、打包/压缩
mkdir -p /backup
chown -R apps:apps /backup
chmod -R 755 /backup
su - apps
cd /backup/
tar -czvf mysql57-x86_64.tar.gz /apps

tar -xzvf mysql57-x86_64.tar.gz .

2、安装rpm-build
yum install rpm-build
su - apps
mkdir -pv rpmbuild/{BUILD,SOURCES,SPECS,RPMS,SRPMS}

tree /home/apps/rpmbuild/

vim ~/.rpmmacros
%_topdir /home/apps/rpmbuild
%_prefix /apps
%debug_package %{nil}

3、拷贝二进制文件
cd /root/rpmbuild/SOURCES
cp /backup/mysql57-x86_64.tar.gz .

4.配置spec
cd /home/apps/rpmbuild/SPECS
vim yunbee-mysql57-suite-v2.0.spec

chmod 755 yunbee-mysql57-suite-v2.0.spec

5.构建rpm包
su - apps
rpmbuild -bb yunbee-mysql57-suite-v2.0.spec #用bb参数生成rpm包
rpmbuild -bc yunbee-mysql57-suite-v2.0.spec #bc只是部分执行,不能生成rpm包的。
rpmbuild --showrc
rpmbuild --showrc |grep _topdir
rpmbuild --showrc |grep _tmppath
rpmbuild --showrc|grep _prefix

编译命令说明:
rpmbuild
-ba 既生成src.rpm又生成二进制rpm
-bs 只生成src的rpm
-bb 只生二进制的rpm
-bp 执行到pre
-bc 执行到 build段
-bi 执行install段
-bl 检测有文件没包含

spec配制文件

1、%setup -q -n
tar解压出来的顶级目录如果和tar包名不同,一定要在%setup -q -n
【这里写解压后生成的目录】这里指定,原则就是这样,你的具体环境我也看不到,哪里有错得自己看看。

1、普通用户可以打包,但需要配置一个~/..rpmmacros

内容类似:
%_topdir /home/apps/rpmbuild
%_prefix /apps
%debug_package %{nil}

这里都改成普通用户可写的目录

2、如果解压目录覆盖了mysql运行目录,肯定要关闭。
但正常来说不会覆盖的,都在那个BUILDROOT下进行文件复制。

3、把带 SOURCE1的地方去掉
这就是你%install里的cp -rv那部分。

4、这个命名:vipshop-mysqlpay56-suite-1.0.3-1.x86_64是哪个变量过来的?
这个是spec文件里的name version之类变量组合起来的。

5.去掉:/apps/conf/mysql/.cnf相关的行

5.error: File not found by glob: /root/rpmbuild/BUILDROOT/yunbee-mysql57-suite-2.1.0-1.x86_64/usr/logs/

执行如下:
echo "%_prefix /apps" > ~/.rpmmacros

6.error: File not found by glob: /root/rpmbuild/BUILDROOT/yunbee-mysql57-suite-2.1.0-1.x86_64/apps/dbdat/

一个道理,那两个目录下没有东西
那两个在%files下声明要打包的安装目录,实际在BUILDROOT临时安装目录下不存在。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
安全 关系型数据库 MySQL
Linux下安装mysql8.0(以tar.xz包安装--编译安装)
通过上述步骤,您完成了从下载、编译、安装到配置MySQL 8.0的全过程。此过程虽然较为复杂,但提供了对MySQL安装环境的完全控制,有助于满足特定的部署需求。在实际操作中,根据具体的系统环境,可能还需调整部分步骤或解决未预见的依赖问题。始终参考官方文档和社区资源,保持安装过程与最新版本的兼容性。
1223 67
|
28天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
2月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
128 3
|
2月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
122 2
|
2月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
185 2
|
3月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置服务等,并与使用 RPM 包安装进行了对比,帮助读者根据需求选择合适的方法。编译源码安装虽然复杂,但提供了更高的定制性和灵活性。
300 2
|
3月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤
【10月更文挑战第7天】本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据自身需求选择合适的方法。
74 3
|
3月前
|
前端开发 Java 数据库连接
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
本文是一份全面的表白墙/留言墙项目教程,使用SpringBoot + MyBatis技术栈和MySQL数据库开发,涵盖了项目前后端开发、数据库配置、代码实现和运行的详细步骤。
86 0
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
5月前
|
存储 自然语言处理 关系型数据库
MySQL全文索引源码剖析之Insert语句执行过程
【8月更文挑战第17天】在MySQL中,处理含全文索引的`INSERT`语句涉及多步骤。首先进行语法解析确认语句结构无误;接着语义分析检查数据是否符合表结构及约束。随后存储引擎执行插入操作,若涉及全文索引则进行分词处理,并更新倒排索引结构。此外,事务管理确保了操作的完整性和一致性。通过示例创建含全文索引的表并插入数据,可见MySQL如何高效地处理此类操作,有助于优化数据库性能和提升全文搜索效果。
|
5月前
|
NoSQL 关系型数据库 MySQL
SpringBoot 集成 SpringSecurity + MySQL + JWT 附源码,废话不多直接盘
SpringBoot 集成 SpringSecurity + MySQL + JWT 附源码,废话不多直接盘
183 2

推荐镜像

更多