[packages/ejabberd] systemd service and stuff
jajcus
jajcus at pld-linux.org
Fri Nov 15 20:55:04 CET 2013
commit 672716271ca346d2e5655b5df7c9066fc0edb8d0
Author: Jacek Konieczny <jajcus at jajcus.net>
Date: Fri Nov 15 20:08:50 2013 +0100
systemd service and stuff
– systemd service added
– %%triggerprein added to work-around bug in old init script
and make sure the service is properly restarted
ejabberd.service | 16 ++++++++++++++++
ejabberd.spec | 38 ++++++++++++++++++++++++++++++++------
2 files changed, 48 insertions(+), 6 deletions(-)
---
diff --git a/ejabberd.spec b/ejabberd.spec
index f3087de..44194bc 100644
--- a/ejabberd.spec
+++ b/ejabberd.spec
@@ -1,6 +1,3 @@
-#
-# TODO:
-# - add systemd unit
# Conditional build:
%bcond_with pam # PAM authentication support
@@ -20,6 +17,7 @@ Source0: http://www.process-one.net/downloads/ejabberd/%{version}/%{realname}-%{
# Source0-md5: 94ce4fe244ee72771eeafe27209d6d3c
Source1: %{realname}.init
Source2: %{realname}.sysconfig
+Source3: %{realname}.service
#
# Archives created with the ejabberd-pack_deps.sh script (in this repo)
Source10: ejabberd-goldrush-20131108.tar.gz
@@ -68,7 +66,7 @@ BuildRequires: openssl-devel
%if %{with pam}
BuildRequires: pam-devel
%endif
-BuildRequires: rpmbuild(macros) >= 1.268
+BuildRequires: rpmbuild(macros) >= 1.671
BuildRequires: yaml-devel
BuildRequires: zlib-devel
BuildRequires: git-core
@@ -77,9 +75,11 @@ Requires(post): jabber-common
Requires(post): sed >= 4.0
Requires(post): textutils
Requires(post,preun): /sbin/chkconfig
+Requires(post,preun,postun): systemd-units >= 38
Requires: erlang
Requires: expat >= 1.95
Requires: rc-scripts
+Requires: systemd-units >= 38
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
%define _noautoprovfiles %{_libdir}/%{name}/priv/lib/
@@ -168,7 +168,8 @@ cd ../..
%install
rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT{/var/lib/%{realname},/etc/{sysconfig,rc.d/init.d},%{_sbindir}}
+install -d $RPM_BUILD_ROOT{/var/lib/%{realname},/etc/{sysconfig,rc.d/init.d}} \
+ $RPM_BUILD_ROOT{%{systemdunitdir},%{_sbindir}}
unset GIT_DIR GIT_WORK_TREE
@@ -180,6 +181,7 @@ unset GIT_DIR GIT_WORK_TREE
sed -e's, at libdir@,%{_libdir},g' -e 's, at EJABBERD_DOC_PATH@,%{_docdir}/%{name}-%{version}/doc,g' %{SOURCE1} > $RPM_BUILD_ROOT/etc/rc.d/init.d/%{realname}
install %{SOURCE2} $RPM_BUILD_ROOT/etc/sysconfig/%{realname}
+install %{SOURCE3} $RPM_BUILD_ROOT%{systemdunitdir}/%{name}.service
chmod u+rw $RPM_BUILD_ROOT%{_sbindir}/%{realname}*
@@ -196,7 +198,7 @@ rm -rf $RPM_BUILD_ROOT
%pre
if [ -e /etc/jabber/ejabberd.cfg ] ; then
- if grep -Eq '^[^#]*access_get' ; then
+ if grep -Eq '^[^#]*access_get' /etc/jabber/ejabberd.cfg ; then
echo "Your 'ejabberd.cfg' config file seems to use 'access_get' option of mod_vcard" >&2
echo "this is not supported by this ejabberd version in PLD" >&2
exit 1
@@ -221,11 +223,33 @@ fi
/sbin/chkconfig --add ejabberd
%service ejabberd restart "ejabberd server"
+%systemd_post %{name}.service
+
%preun
if [ "$1" = "0" ]; then
%service ejabberd stop
/sbin/chkconfig --del ejabberd
fi
+%systemd_preun %{name}.service
+
+%postun
+%systemd_reload
+
+%triggerprein -- %{name} < 13.10
+# only if started and we know upgrade won't be aborted in %%pre
+if [ -e /var/lock/subsys/ejabberd ] && ! grep -Eq '^[^#]*access_get' /etc/jabber/ejabberd.cfg 2>/dev/null ; then
+ # old init script won't stop ejabberd correctly
+ # stop it's all processes here
+ # we assume any 'epmd', 'beam', 'beam.smp' or 'heart' process
+ # running with uid of jabber is ejabberd process
+ pids="$(ps -C "epmd beam beam.smp heart" -o pid=,user= | awk '/jabber/ { print $1 }')" || :
+ if [ -n "$pids" ] ; then
+ %banner -e %{name} <<'EOF'
+Killing all 'epmd, beam, beam.smp, heart' processed owned by the 'jabber' user to make sure old ejabberd is down.
+EOF
+ kill $pids || :
+ fi
+fi
%triggerpostun -- %{name} < 13.10
# convert old 'NODENAME' in /etc/sysconfig/ejabberd
@@ -248,6 +272,7 @@ if [ -e /etc/sysconfig/ejabberd ] ; then
/etc/sysconfig/ejabberd || :
fi
cp %{_sysconfdir}/jabber/cookie /var/lib/ejabberd/.erlang.cookie || :
+%systemd_trigger %{name}.service
%files
%defattr(644,root,root,755)
@@ -267,6 +292,7 @@ cp %{_sysconfdir}/jabber/cookie /var/lib/ejabberd/.erlang.cookie || :
%ghost %attr(400,jabber,jabber) %ghost %config(noreplace) %verify(not md5 mtime size) /var/lib/ejabberd/.erlang.cookie
%attr(754,root,root) /etc/rc.d/init.d/%{realname}
%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/%{realname}
+%{systemdunitdir}/%{name}.service
%if %{with logdb}
%files logdb
diff --git a/ejabberd.service b/ejabberd.service
new file mode 100644
index 0000000..bddf659
--- /dev/null
+++ b/ejabberd.service
@@ -0,0 +1,16 @@
+[Unit]
+Description=Fault-tolerant distributed Jabber/XMPP server
+After=network.target
+
+[Service]
+Type=forking
+Environment=EJABBERD_PID_PATH=/var/run/jabber/ejabberd.pid
+ExecStart=/usr/sbin/ejabberdctl start
+ExecStartPost=/usr/sbin/ejabberdctl started
+ExecStop=/usr/sbin/ejabberdctl stop
+ExecStopPost=/usr/sbin/ejabberdctl stopped
+PIDFile=/var/run/jabber/ejabberd.pid
+User=jabber
+
+[Install]
+WantedBy=multi-user.target
================================================================
---- gitweb:
http://git.pld-linux.org/gitweb.cgi/packages/ejabberd.git/commitdiff/9a105ba4017a8b53a31f1402aa2f14ffe466f915
More information about the pld-cvs-commit
mailing list