在 Jenkins 上构建的 RPM 在更新的模拟版本上失败,而不是在成功的工作站上模拟

RPM build on Jenkins fails on a more recent mock version than mock on workstation that succeeds

我正在尝试根据另一个比我早编写的项目的一些规范文件样板,从 Jenkins 构建和部署 RPM 包。由于某些原因,当我尝试从 Jenkins 中构建或发布此包时遇到构建错误。

+ rm -rf /builddir/build/BUILDROOT/component-prefix-blah-api-proxy-0.1.0.16-1.bbc.el7.x86_64
BUILDSTDERR: ++ dirname /builddir/build/BUILDROOT/component-prefix-blah-api-proxy-0.1.0.16-1.bbc.el7.x86_64
RPM build errors:
BUILDSTDERR: error: File not found by glob: /builddir/build/BUILDROOT/component-prefix-blah-api-proxy-0.1.0.16-1.bbc.el7.x86_64/var/www/cgi-bin/*
BUILDSTDERR:     File not found by glob: /builddir/build/BUILDROOT/component-prefix-blah-api-proxy-0.1.0.16-1.bbc.el7.x86_64/var/www/cgi-bin/*
Child return code was: 1
EXCEPTION: [Error()]
Traceback (most recent call last):
  File "/usr/lib/python2.7/site-packages/mockbuild/trace_decorator.py", line 96, in trace
    result = func(*args, **kw)
  File "/usr/lib/python2.7/site-packages/mockbuild/util.py", line 734, in do_with_status
    raise exception.Error("Command failed: \n # %s\n%s" % (command, output), child.returncode)
Error: Command failed: 
 # /usr/bin/systemd-nspawn -q -M b88888b933974fe283e8497d165b5369 -D /var/lib/mock/epel-7-x86_64-9876/root --capability=cap_ipc_lock --bind=/tmp/mock-resolv.kXeD1i:/etc/resolv.conf --setenv=LANG=en_GB.UTF-8 --setenv=TERM=vt100 --setenv=SHELL=/bin/bash --setenv=HOSTNAME=mock --setenv=PROMPT_COMMAND=printf "3]0;<mock-chroot>[=10=]7" --setenv=HOME=/builddir --setenv=PATH=/usr/bin:/bin:/usr/sbin:/sbin --setenv=PS1=<mock-chroot> \s-\v$  -u mockbuild bash --login -c /usr/bin/rpmbuild -bb --target x86_64 --nodeps /builddir/build/SPECS/blah-api-proxy.spec

在 RPM build.log 文件中还有一个早于上述错误出现的错误,我认为这不是主要错误,因为我之前在其他运行良好的构建中看到过这种情况

BUILDSTDERR: Failed to create directory /var/lib/mock/epel-7-x86_64-9876/root//sys/fs/selinux: Read-only file system

我尝试在执行 mock 时设置 --old-chroot 标志。但是,我开始收到两个错误 -

ERROR: Exception(/var/lib/jenkins/workspace/component-prefix-blah-api-proxy/blah-api-proxy/SRPMS/component-prefix-blah-api-proxy-0.1.0.15-1.bbc.el7.src.rpm) Config(epel-7-x86_64) 0 minutes 11 seconds

 # bash --login -c /usr/bin/rpmbuild -bb --target x86_64 --nodeps /builddir/build/SPECS/blah-api-proxy.spec
Version: 0.1.0%{?BUILD_NUMBER:.%{BUILD_NUMBER}}
Release: 1%{?dist}
Group: System Environment/Daemons
License: Internal COY use only
Summary: BLAH API Proxy
Source0: src.tar.gz
Requires: blah-blah-ssl-services-blah-staff jq
BuildRoot: %(mktemp -ud %{_tmppath}/%{name}-%{version}-%{release}-XXXXXX)
BuildArch: x86_64

%description
BLAH API Proxy

%prep
%setup -q -n src

%build

%install
mkdir -p %{buildroot}
cp -r * %{buildroot}/

%clean
rm -rf %{buildroot}

%pre

%files
%defattr(0755, root, root, 0755)
/var/www/cgi-bin/*

%defattr(-, root, root, 0755)
/etc/bake-scripts/*

%defattr(0755, root, root, 0755)
/etc/bake-scripts/blah-api-proxy

N.B: blah-api-proxy 是包含 Apache 代理服务器配置的目录。

src文件夹结构如下:

src/
├── etc
│   └── bake-scripts
│       ├── blah-api-proxy
│       └── public-endpoints
└── var
    └── www
        └── cgi-bin

如果我能得到帮助解决这个问题,我将不胜感激。 非常感谢您。

%{buildroot}/var/www/cgi-bin/ 的错误状态(在处理 %files 部分期间) 不存在。

所以你认为你复制了一些东西,但实际情况不同。

%install 部分的末尾添加:find %{buildroot}/ 和 运行 再次构建,您将看到 cp 实际放在那里的内容。

非常感谢@msuchy 帮助解决了这个问题。他的建议帮助我快速确定了根本原因。

问题是 spec file%files 部分指定的目录之一 /var/ 被 git 存储库排除在外13=] 文件。从 .gitignore 文件中删除目录解决了这个问题

我们做的另一件事是在我们的发布系统(不是 Jenkins)中指定我们的规范文件所依赖的 rpm 存储库。