项目打包rpm包(rpmbuild)

article/2025/10/16 9:00:22

这里以python项目为例,通过rpmbuild工具打包成rpm包,并进行安装验证

rpmbuild打包 rpm流程

  • 构建rpmbuild打包目录

  • rpmbuild 默认变量配置文件

  • 将我们的python项目和依赖包压缩成xx.tar.gz格式,并copy到SOURCE目录

我们这里以datalake-demo-2.0项目为例,将其移到/root/rpmbuild/SOURCE即可

  •  编写rpmbuild核心 spec 文件【datalake.spec】

        spec里面很多字段网上都有说明,这里只介绍几个关键参数

  • rpmbuild  spec 文件示例
Name:     datalake-demo
Version:  2.0
Release:  1%{?dist}
Summary:  The "Datalake" program from Bigtera
Summary(zh_CN):  GNU "Qin datalake" 程序
License:  GPLv3+
URL:      http://172.17.37.131/datalake
Source0:  /root/rpmbuild/SOURCES/%{name}-%{version}.tar.gz
Packager: project from qin-mis
BuildRoot: /root/rpmbuild/BUILDROOT%description
The "Bigtera Datalake" program, done with all bells and whistles of a proper FOSS
project, including configuration, build, internationalization, help files, etc.%description -l zh_CN
"Bigtera Datalake" 程序, include http_server, archive_agent ...%define _topdir /root/rpmbuild
%define _buildroot %{topdir}/BUILDROOT%prep
%setup -q%build
# echo "bbbbbbbbbbbbbbbbbbbbbuild done  ~~~~ "
# make %{?_smp_mflags}echo "starting install action ..."
%install
echo %{buildroot}
echo $RPM_BUILD_ROOT
# install -d $RPM_BUILD_ROOT/
mkdir -p $RPM_BUILD_ROOT/home/datalake-demo-2.0
cp -ar ./* $RPM_BUILD_ROOT/home/datalake-demo-2.0
# make install DESTDIR=%{buildroot}
echo `pwd`%post
if [ $1 == 1 ];thenecho `pwd`echo `ls`if [ -f "/home/datalake-demo-2.0/driver/datalake-formation.service" ]; then# cp -rp "/home/datalake-demo-2.0/driver/datalake-formation.service" "/lib/systemd/system/datalake-formation.service"echo "copy formation service file"fiif [ -f "/home/datalake-demo-2.0/driver/datalake-rock.service" ]; then# cp -rp "/home/datalake-demo-2.0/driver/datalake-rock.service" "/lib/systemd/system/datalake-rock.service"echo "copy rock service file"fiif [ -f "/home/datalake-demo-2.0/driver/datalake-reporter.service" ]; then# cp -rp "/home/datalake-demo-2.0/driver/datalake-reporter.service" "/lib/systemd/system/datalake-reporter.service"echo "copy reporter service file"fiecho "Starting install datalake dependent packages ... "cd "/home/datalake-demo-2.0/"tar -xvzf "datalake_packages.tar.gz"if [ -d "/home/datalake-demo-2.0/datalake_packages" ];thencd "/home/datalake-demo-2.0/datalake_packages"echo "I am done tar action ..."echo `pwd`/bin/bash "build_script.sh"if [ -f "/home/datalake-demo-2.0/datalake_packages.tar.gz" ]; thenecho "Will delete atalake_packages.tar.gz"rm -rf "/home/datalake-demo-2.0/datalake_packages.tar.gz"fifiecho "install packages done ~~~~ "
fi%files
%defattr(-,root,root,0755)
/home# %doc%changelog
* Sun Dec 4 2016 ZHUZHU <396625689@qq.com> - 2.10-1
- Update to 2.10
* Sat Dec 3 2016 ZHUZHU <396625689@qq.com> - 2.9-1
- Update to 2.9
  • rpmbuild spec参数说明 
Name项目名称
Version项目版本 
Summary项目概述
%define定义spec全局变量
%pre

预处理脚本(rpm安装前执行操作)

%setup -q 通常是从SOURCES目录里的包解压到BUILD/%{name}-%{version}中
%build开始构建包,我们这里不需要
%install

开始把软件安装到虚拟的根目录,这里我们是将解压后的代码copy到$RPM_BUILD_ROOT/home/datalake-demo-2.0

这里说明一下/home/datalake-demo-2.0是以后rpm包的安装路径,也就是你想要把你的包装在哪个目录,就把你的源码包copy到哪里即可,安装的时候$RPM_BUILD_ROOT可以理解为根目录 /

%post

rpm安装后执行的脚本,

这里我做的操作是将service file拷贝到/lib/systemd/system目录,然后将项目依赖包解压并进行安装,最后将安装包删除

%file

定义那些文件或目录会放入rpm中,我们这里指定/home

设置文件属性 %defattr(-,root,root)  %attr(644,root,root) etc/conf/nginx.conf

%changelog本次rpm包说明
%preun和 postun分别表示卸载rpm包前后卸载后要做的事
  •  开始rpmbuild rpd 【rpmbuild -ba datalake.spec】

  • 查看rpm包【/root/rpmbuild/RPMS/x86_64】

  • 尝试安装rpm包 【rpm -ivh datalake-demo-2.0-1.el7.x86_64.rpm】

 可以看到连同我们的python项目依赖包都安装好了 

  • 卸载包 【rpm -e atalake-demo-2.0-1.el7.x86_64】 

 rpmbuild rpm包完成~


补充:

        在使用rpmbuild构建rpm包时,往往能够自动打出debuginfo包。如果不想要,可以echo "%debug_package %{nil}" >> ~/.rpmmacros 如果不想拆分出debuginfo包,让binary包里就是带调试符号的,可以在spec文件头加上%global debug_package %{nil}

        如果想打出debuginfo包,而默认却打不出来,可以检查机器是否安装了redhat-rpm-config包,如果没有,就会因为缺少brp-compress工具而打不出debuginfo包


http://chatgpt.dhexx.cn/article/PUP6dP4S.shtml

相关文章

前向星和链式前向星

链接&#xff1a;https://blog.csdn.net/ACdreamers/article/details/16902023 我们首先来看一下什么是前向星. 前向星是一种特殊的边集数组,我们把边集数组中的每一条边按照起点从小到大排序,如果起点相同就按照终点从小到大排序, 并记录下以某个点为起点的所有边在数组中的…

关于链式前向星

最近看了许多题目都用了比较奇怪的东西… 后面才发现是神奇的链式前向星….. 听名字就觉得很牛啊&#xff01; 然而其实很简单…… 组成:begin,next,to,w,与一个用来标记的e begin[n]数组&#xff1a;代表编号为n的点,最后一条边的储存位置 next[n]:是用来保存从同一个点…

链式前向星(加快图的搜索)

存储一个图通常有两种方式&#xff1a;邻接矩阵和邻接表。如果一个图中的边非常少&#xff0c;那么邻接矩阵就比较稀疏&#xff0c;浪费空间&#xff0c;如果点非常多&#xff0c;则矩阵的内存有可能会爆掉。用向量实现的邻接表在点非常多的时候同样比较慢&#xff0c;在一些题…

链式前向星存储图

第七天链式前向星存图 图片如下所示 本代码存的是有向图&#xff0c;图示为无向图。 #include<iostream> using namespace std; const int maxn 100; struct node//to 边的终点编号&#xff0c;w 权值&#xff0c; next 以 x 为起点的上一条边的编号 {int to,w,next;…

链式前向星存图 详细解析

文章目录 链式前向星完整代码 链式前向星 链式前向星是一种图的存储方式&#xff0c;相比于 邻接矩阵和邻接表 &#xff0c;链式前向星是一种静态链表存储&#xff0c;用边集数组和邻接表相结合&#xff0c;可以快速访问一个顶点的所有邻接点。 在某些算法题中使用还很频繁&a…

C++之链式前向星

链式前向星 基本定义以及实现链式前向星实现DFSBFS 基本定义以及实现 (若果有一定了解&#xff0c;可以跳过第一部分&#xff0c;直接看第二部分) 我们首先来看一下什么是前向星. 前向星是一种特殊的边集数组,我们把边集数组中的每一条边按照起点从小到大排序,如果起点相同就按…

图的存储 —— 链式前向星

图的存储 —— 链式前向星 链式前向星采用了一种静态链表存储方式&#xff0c;将边集数组和邻接表相结合&#xff0c;可以快速访问一个节点的所有邻接点&#xff0c;在算法竞赛中被广泛应用。 链式前向星有如下两种存储结构。 边集数组&#xff1a;edge[]&#xff0c;edge[i…

简述链式前向星

一、前言 我们常见的存图数据结构有两种&#xff0c;一种是邻接矩阵&#xff0c;另一种是邻接表。而在邻接矩阵中&#xff0c;空间复杂度为 O ( n 2 ) O(n^2) O(n2)&#xff0c;在稀疏图的情况下&#xff0c;相较于邻接表浪费了许多空间。而常规的邻接表是用链表进行操作&…

链式前向星 详解

链式前向星 链式前向星是一种类似于邻接表的存图方式&#xff0c;同样适用于有向 图和无向图。 他建立的是边与边之间的联系 它将边里的所有边都进行编号 int cnt; //边的编号 struct edge{ //边的结构体int from,to,w,next; //from是边的起点&#xff08;这个可有可无&a…

用链式前向星存储图

图最常用的存储结构主要是邻接矩阵和邻接表。当顶点数太大时&#xff0c;用二维数组表示的邻接矩阵可能超内存&#xff08;MLE&#xff09;&#xff0c;而用邻接表的编码工作量较大&#xff0c;此时&#xff0c;使用vector数组或链式前向星模拟邻接表是不错的选择。因vector数组…

链表、链式前向星

讲链表的时候就卡在这里了&#xff0c;最短路又卡在链式前向星上了&#xff0c;毕竟是图论基础&#xff0c;觉得还是有必要写一写防止下次再懵。 链表都是头插法&#xff01;&#xff01;即每次我们给他插一个头。 普通链表 先初始化令head-1,idx-1. void add_tohead(int x…

链式前向星(详细讲述)

在dalao的压迫下本蒟蒻发个博客&#xff0c;给大家讲一下链式前向星&#xff08;新手&#xff0c;写错了轻喷&#xff09; 首先说明一点链式前向星适合于稀疏图&#xff0c;而邻接矩阵则更适合稠密图&#xff0c;所以最好看好数据范围再决策使用哪个方法&#xff0c;当然有些题…

链式前向星与邻接表对比

本文图片及数据 对于这样一张有向图&#xff1a; 输入边的顺序如下&#xff1a; 1 2 2 3 3 4 1 3 4 1 1 5 4 5 对于邻接表来说是这样的&#xff1a; 1 -> 2 -> 3 -> 5 2 -> 3 3 -> 4 4 -> 1 -> 5 5 ->^ 对于链式前向星来说是这样的&…

链式前向星存图(有图详解)

链式前向星:既然是链式那么肯定和链表相关,前向星是每次指向都向前 链式前向星存图是以边为中心,并不是以结点为中心,它记录的是边的一些属性,包括边边的id、头节点、尾结点、权值、边的指向! 边的指向是遍历图的时候需要按照一定顺序去遍历,而不能胡乱的去遍历,那么就需要这些…

链式前向星的详解

目录 1&#xff1a;链式前向星的概念解释 2&#xff1a;代码展现 链式前向星是一种非常好用的有向图存储方式&#xff0c;但是它的代码难度却有点大。作者在这上面花了很长的时间才弄懂。虽然有其他的博客大佬写的很好&#xff0c;但总感觉不太适合小白选手&#xff08;比如说…

链式前向星基本原理

一、概述 我们在学习图论的时候学习了一种图的存储结构--二维数组邻接矩阵储存&#xff0c;他虽然可以表达直观&#xff0c;快速访问连接两点的边&#xff0c;但是它占用空间大&#xff0c;只适用于点少的图&#xff0c;所以我们需要一种能够可以存储大型图的东西--链式前向星…

链式前向星的原理图解

笔者写下这篇文章的契机是&#xff0c;前两天在上机课用纯链式存储写题&#xff0c;累的够呛。于是痛定思痛&#xff0c;在此梳理一遍链式前向星&#xff0c;也希望能给有同样困扰的同学们提供一点帮助。 在进入正题之前&#xff0c;我们先用邻接矩阵和邻接表引入。 邻接矩阵表…

【链式前向星+存图】讲解

大佬的链式前向星:https://blog.csdn.net/acdreamers/article/details/16902023 【前向星】&#xff1a; 解释一下&#xff1a; 【前向星和链式前向星的不同】&#xff1a; 【给出链式前向星的代码实现】&#xff1a; #include<bits/stdc.h> using namespace std; #def…

链式前向星——最完美图解

图的存储方法很多,最常见的除了邻接矩阵、邻接表和边集数组外,还有链式前向星。链式前向星是一种静态链表存储,用边集数组和邻接表相结合,可以快速访问一个顶点的所有邻接点,在算法竞赛中广泛应用。 链式前向星存储包括两种结构: 边集数组:edge[ ],edge[i]表示第i条边…

链式前向星(详解)

链式前向星&#xff08;详解&#xff09; 转自&#xff1a;传送门 我们首先来看一下什么是前向星. 前向星是一种特殊的边集数组,我们把边集数组中的每一条边按照起点从小到大排序,如果起点相同就按照终点从小到大排序, 并记录下以某个点为起点的所有边在数组中的起始位置和…