You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

135 lines
4.5 KiB

##
## hadoop.spec -- OpenPKG RPM Package Specification
## Copyright (c) 2000-2020 OpenPKG Project <http://openpkg.org/>
##
## Permission to use, copy, modify, and distribute this software for
## any purpose with or without fee is hereby granted, provided that
## the above copyright notice and this permission notice appear in all
## copies.
##
## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
## SUCH DAMAGE.
##
# package version
%define V_opkg 3.2.1
%define V_dist 3.2.1
# package information
Name: hadoop
Summary: Distributed Storage Engine
URL: http://hadoop.apache.org/
Vendor: Apache Software Foundation
Packager: OpenPKG Project
Distribution: OpenPKG Community
Class: EVAL
Group: Filesystem
License: Apache
Version: %{V_opkg}
Release: 20190923
# list of sources
Source0: http://www.apache.org/dist/hadoop/common/hadoop-%{V_dist}/hadoop-%{V_dist}.tar.gz
Source1: rc.hadoop
Source2: hadoop.sh
# build information
BuildPreReq: OpenPKG, openpkg >= 20160101
PreReq: OpenPKG, openpkg >= 20160101, java
%description
The Apache Hadoop software library is a framework that allows for
the distributed processing of large data sets across clusters of
computers using a simple programming model. It is designed to scale
up from single servers to thousands of machines, each offering
local computation and storage. Rather than rely on hardware to
deliver high-avaiability, the library itself is designed to detect
and handle failures at the application layer, so delivering a
highly-availabile service on top of a cluster of computers, each of
which may be prone to failures.
%track
prog hadoop = {
version = %{V_dist}
url = http://www.apache.org/dist/hadoop/common/
regex = hadoop-(\d+\.\d+\.\d+)/
}
%prep
%setup -q -n hadoop-%{V_dist}
%build
rm -rf "c++"
rm -rf lib/native
rm -rf src
rm -f *.txt
rm -f *.xml
rm -f "share/hadoop/yarn/webapps/ui2/assets/images/datatables/Sorting icons.psd"
%install
# create installation hierarchy
%{l_shtool} mkdir -f -p -m 755 \
$RPM_BUILD_ROOT%{l_prefix}/bin \
$RPM_BUILD_ROOT%{l_prefix}/etc/rc.d \
$RPM_BUILD_ROOT%{l_prefix}/etc/hadoop \
$RPM_BUILD_ROOT%{l_prefix}/libexec/hadoop \
$RPM_BUILD_ROOT%{l_prefix}/var/hadoop/run \
$RPM_BUILD_ROOT%{l_prefix}/var/hadoop/log \
$RPM_BUILD_ROOT%{l_prefix}/var/hadoop/data
# install configuration
cp -r etc/hadoop/* $RPM_BUILD_ROOT%{l_prefix}/etc/hadoop/
# strip down installation
rm -rf etc
rm -rf share/doc
# install program
cp -r * $RPM_BUILD_ROOT%{l_prefix}/libexec/hadoop/
# install wrapper startup script
%{l_shtool} install -c -m 755 %{l_value -s -a} \
%{SOURCE hadoop.sh} $RPM_BUILD_ROOT%{l_prefix}/bin/hadoop
# install run-command script
%{l_shtool} install -c -m 755 %{l_value -s -a} \
%{SOURCE rc.hadoop} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/
# determine installation files
%{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
%{l_files_std} \
'%config %{l_prefix}/etc/hadoop/*' \
'%attr(-,%{l_rusr},%{l_rgrp}) %{l_prefix}/var/hadoop/*'
%files -f files
%clean
%post
# after upgrade, restart service
if [ $1 -eq 2 ]; then
eval `%{l_rc} hadoop status 2>/dev/null`
[ ".$hadoop_active" = .yes ] && %{l_rc} hadoop restart
fi
exit 0
%preun
if [ $1 -eq 0 ]; then
# before erase, stop service and remove log files
%{l_rc} hadoop stop 2>/dev/null
rm -f $RPM_INSTALL_PREFIX/var/hadoop/log/* >/dev/null 2>&1 || true
rm -f $RPM_INSTALL_PREFIX/var/hadoop/run/* >/dev/null 2>&1 || true
rm -rf $RPM_INSTALL_PREFIX/var/hadoop/data/* >/dev/null 2>&1 || true
fi
exit 0