我正在添加一些资源到一个现有的rpm .spec文件,并没有被下载。有没有办法让rpmbuild下载源代码,而不是手动下载呢?
发布于 2015-10-16 18:41:43
来自spectool包的rpmdevtools实用程序可以做到这一点。只需安装rpmdevtools并将spectools指向.spec,如下所示:
spectool -g -R SPECS/nginx.spec它将把所有缺少的源代码下载到rpm的%{_sourcedir} (通常是SOURCES)目录中。
发布于 2017-09-11 10:49:38
对于后代来说,还有另一种方法,即不需要任何额外的工具或下载:
rpmbuild --undefine=_disable_source_fetch -ba /path/to/your.spec默认情况下,自动下载源代码是被禁止的,因为RPM缺乏对源档案的内置完整性检查。网络必须是可信的,任何校验和签名都必须检查。这个限制对于包维护人员来说是有意义的,因为他们负责传送受信任的代码。
然而,当你知道你在做什么并理解风险时,你可能会强行取消限制。
发布于 2018-01-13 11:48:17
在规范文件中,可以将%undefine _disable_source_fetch放置在源URL之前的任何位置。
出于安全考虑,您还应该指定sha256sum,并在安装之前在%prep部分中检查它。
下面是一个有用的例子:
Name: monit
Version: 5.25.1
Release: 1%{?dist}
Summary: Monitoring utility for unix systems
Group: Applications/System
License: GNU AFFERO GENERAL PUBLIC LICENSE version 3
URL: https://mmonit.com/monit/
%undefine _disable_source_fetch
Source0: https://mmonit.com/monit/dist/%name-%version.tar.gz
%define SHA256SUM0 4b5c25ceb10825f1e5404f1d8a7b21507716b82bc20c3586f86603691c3b81bc
%define debug_package %nil
BuildRequires: coreutils
%description
Monit is a small Open Source utility for managing and monitoring Unix systems. Monit conducts automatic maintenance
and repair and can execute meaningful causal actions in error situations.
%prep
echo "%SHA256SUM0 %SOURCE0" | sha256sum -c -
%setup -q
...学分
@YaroslavFedevych用于未定义的_disable_source_fetch。
https://stackoverflow.com/questions/33177450
复制相似问题