2 changed files with 222 additions and 0 deletions
@ -0,0 +1,160 @@
|
||||
## |
||||
## kafka.spec -- OpenPKG RPM Package Specification |
||||
## Copyright (c) 2000-2018 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_kafka 1.1.0 |
||||
%define V_scala 2.12 |
||||
|
||||
# package information |
||||
Name: kafka |
||||
Summary: Distributed Streaming Platform |
||||
URL: https://kafka.apache.org/ |
||||
Vendor: Apache Software Foundation |
||||
Packager: OpenPKG Project |
||||
Distribution: OpenPKG Community |
||||
Class: EVAL |
||||
Group: Networking |
||||
License: Apache |
||||
Version: %{V_kafka} |
||||
Release: 20180501 |
||||
|
||||
# list of sources |
||||
Source0: https://www.apache.org/dist/kafka/%{V_kafka}/kafka_%{V_scala}-%{V_kafka}.tgz |
||||
Source1: rc.kafka |
||||
|
||||
# build information |
||||
BuildPreReq: OpenPKG, openpkg >= 20160101 |
||||
PreReq: OpenPKG, openpkg >= 20160101, zookeeper |
||||
BuildPreReq: java, JAVA-JDK |
||||
PreReq: java, JAVA-JDK |
||||
|
||||
%description |
||||
Apache Kafka is used for building real-time data pipelines and |
||||
streaming apps. It is horizontally scalable, fault-tolerant, wicked |
||||
fast, and runs in production in thousands of companies. |
||||
|
||||
%track |
||||
prog kafka = { |
||||
version = %{V_scala}-%{V_kafka} |
||||
url = https://kafka.apache.org/downloads |
||||
regex = kafka_(__VER__-__VER__)\.tgz |
||||
} |
||||
|
||||
%prep |
||||
%setup -q -n kafka_%{V_scala}-%{V_kafka} |
||||
|
||||
%build |
||||
# adjust paths |
||||
%{l_shtool} subst \ |
||||
-e 's;/bin/bash;%{l_bash};g' \ |
||||
bin/*.sh |
||||
|
||||
%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/kafka \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/libexec/kafka/bin \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/libexec/kafka/libs \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/var/kafka/run \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/var/kafka/log |
||||
|
||||
# install program |
||||
%{l_shtool} install -c -m 755 \ |
||||
bin/* \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/libexec/kafka/bin/ |
||||
%{l_shtool} install -c -m 644 \ |
||||
libs/* \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/libexec/kafka/libs/ |
||||
|
||||
# install configuration |
||||
%{l_shtool} install -c -m 644 \ |
||||
-e 's;/tmp/kafka-logs;%{l_prefix}/var/kafka/log;g' \ |
||||
config/* \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/etc/kafka/ |
||||
ln -s ../../etc/kafka \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/libexec/kafka/config |
||||
ln -s ../../var/kafka/log \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/libexec/kafka/logs |
||||
|
||||
# provide wrapper scripts for CLI tools |
||||
for prog in \ |
||||
kafka-acls \ |
||||
kafka-broker-api-versions \ |
||||
kafka-configs \ |
||||
kafka-console-consumer \ |
||||
kafka-console-producer \ |
||||
kafka-consumer-groups \ |
||||
kafka-consumer-perf-test \ |
||||
kafka-delegation-tokens \ |
||||
kafka-delete-records \ |
||||
kafka-mirror-maker \ |
||||
kafka-preferred-replica-election \ |
||||
kafka-producer-perf-test \ |
||||
kafka-reassign-partitions \ |
||||
kafka-replay-log-producer \ |
||||
kafka-replica-verification \ |
||||
kafka-simple-consumer-shell \ |
||||
kafka-streams-application-reset \ |
||||
kafka-topics \ |
||||
kafka-verifiable-consumer \ |
||||
kafka-verifiable-producer; do |
||||
( echo "#!/bin/sh" |
||||
echo "exec %{l_prefix}/libexec/kafka/bin/$prog.sh \${1+\"\$@\"}" |
||||
) >$RPM_BUILD_ROOT%{l_prefix}/bin/$prog |
||||
chmod 755 $RPM_BUILD_ROOT%{l_prefix}/bin/$prog |
||||
done |
||||
|
||||
# install run-command script |
||||
%{l_shtool} install -c -m 755 %{l_value -s -a} \ |
||||
%{SOURCE rc.kafka} \ |
||||
$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/kafka/*' \ |
||||
'%attr(-,%{l_rusr},%{l_rgrp}) %{l_prefix}/var/kafka/*' |
||||
|
||||
%files -f files |
||||
|
||||
%clean |
||||
|
||||
%post |
||||
if [ $1 -eq 2 ]; then |
||||
# after upgrade, restart service |
||||
eval `%{l_rc} kafka status 2>/dev/null` |
||||
[ ".$kafka_active" = .yes ] && %{l_rc} kafka restart |
||||
fi |
||||
exit 0 |
||||
|
||||
%preun |
||||
# before erase, stop service and remove log files |
||||
if [ $1 -eq 0 ]; then |
||||
%{l_rc} jocko stop 2>/dev/null |
||||
rm -f $RPM_INSTALL_PREFIX/var/kafka/log/* >/dev/null 2>&1 || true |
||||
rm -f $RPM_INSTALL_PREFIX/var/kafka/run/* >/dev/null 2>&1 || true |
||||
fi |
||||
exit 0 |
||||
|
@ -0,0 +1,62 @@
|
||||
#!@l_prefix@/bin/openpkg rc |
||||
## |
||||
## rc.kafka -- Run-Commands |
||||
## |
||||
|
||||
%config |
||||
kafka_enable="$openpkg_rc_def" |
||||
kafka_flags="-server -Xms1G -Xmx1G" |
||||
kafka_log_prolog="true" |
||||
kafka_log_epilog="true" |
||||
kafka_log_numfiles="10" |
||||
kafka_log_minsize="1M" |
||||
kafka_log_complevel="9" |
||||
|
||||
%common |
||||
kafka_pidfile="@l_prefix@/var/kafka/run/kafka.pid" |
||||
kafka_logfile="@l_prefix@/var/kafka/log/kafka.log" |
||||
kafka_signal () { |
||||
[ -f $kafka_pidfile ] && kill -$1 `cat $kafka_pidfile` |
||||
} |
||||
|
||||
%status -u @l_rusr@ -o |
||||
kafka_usable="unknown" |
||||
kafka_active="no" |
||||
rcService kafka enable yes && \ |
||||
kafka_signal 0 && kafka_active="yes" |
||||
echo "kafka_enable=\"$kafka_enable\"" |
||||
echo "kafka_usable=\"$kafka_usable\"" |
||||
echo "kafka_active=\"$kafka_active\"" |
||||
|
||||
%start -u @l_rusr@ |
||||
rcService kafka enable yes || exit 0 |
||||
rcService kafka active yes && exit 0 |
||||
( eval `JAVA_PLATFORM="sun-jdk" @l_prefix@/bin/java-toolkit -e` |
||||
cmd="@l_prefix@/libexec/kafka/bin/kafka-server-start.sh" |
||||
cmd="$cmd @l_prefix@/etc/kafka/server.properties" |
||||
eval "nohup $cmd </dev/null >>$kafka_logfile 2>&1 &" |
||||
echo $! >$kafka_pidfile |
||||
) >/dev/null 2>&1 |
||||
|
||||
%stop -u @l_rusr@ |
||||
rcService kafka enable yes || exit 0 |
||||
rcService kafka active no && exit 0 |
||||
kafka_signal TERM |
||||
sleep 2 |
||||
rm -f $kafka_pidfile 2>/dev/null || true |
||||
|
||||
%restart -u @l_rusr@ |
||||
rcService kafka enable yes || exit 0 |
||||
rcService kafka active no && exit 0 |
||||
rc kafka stop |
||||
rc kafka start |
||||
|
||||
%daily -u @l_rusr@ |
||||
rcService kafka enable yes || exit 0 |
||||
shtool rotate -f \ |
||||
-n $kafka_log_numfiles -s $kafka_log_minsize -d \ |
||||
-z $kafka_log_complevel -o @l_rusr@ -g @l_rgrp@ -m 644 \ |
||||
-P "$kafka_log_prolog" \ |
||||
-E "$kafka_log_epilog; rc kafka restart" \ |
||||
$kafka_logfile |
||||
|
Loading…
Reference in new issue