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

时间:2019-05-12 05:22:17

标签: linux centos rpm rpmbuild rpm-spec

我试图基于Jenkins的RPM软件包来构建和部署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 "\033]0;<mock-chroot>\007" --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

我尝试在执行模拟时设置--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

如果能获得解决此问题的帮助,我将非常感激。 预先非常感谢。

2 个答案:

答案 0 :(得分:0)

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

因此,您认为您复制了某些内容,但实际情况有所不同。

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

答案 1 :(得分:-1)

我非常感谢@msuchy对这个问题的帮助。他的建议帮助我迅速找到了根本原因。

问题是/var/文件从git repo中排除了%files的{​​{1}}部分中指定的目录之一spec file。从.gitignore文件中删除目录可以解决此问题

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