On Friday 11 June 2004 18.54, jsaville@kaleidoscopesystems.com wrote:
What I need assistance on is creating a working startup script for the
second instance. I have tried to copy the existing postfix startup
script
and make appropriate edits without success. How do I create a working
startup script for the second instance of postfix?
What does your edited script look like, and how does it fail?
Here is my most current attempt with the script:
#! /bin/sh
# Copyright (c) 2000-2001 SuSE GmbH Nuernberg, Germany.
# Copyright (c) 2002 SuSE Linux AG
#
# Author: Carsten Hoeger
#
# /etc/init.d/postfix-2
#
# modified for second instance by ksc/jsc/6/5/04
#
### BEGIN INIT INFO
# Provides: sendmail-2 postfix-2
# Required-Start: $network $named $syslog
# X-UnitedLinux-Should-Start: cyrus ldap ypbind openslp
# Required-Stop:
# Default-Start: 3 5
# Default-Stop:
# Description: start the second instance of the Postfix MTA
### END INIT INFO
# Determine the base and follow a runlevel link name.
base=${0##*/}
link=${base#*[SK][0-9][0-9]}
MASTER_BIN=/usr/lib/postfix/master
POSTFIX_BIN=/usr/sbin/postfix
OPENSLP_BIN=/usr/bin/slptool
test -x $POSTFIX_BIN || exit 5
test -x $MASTER_BIN || exit 5
cond_slp() {
cmd=$1
PIFACES=$(postconf -h inet_interfaces|sed -e 's/127.0.0.1//')
PSERVICES=$(grep -E '^smtp.*smtpd' /etc/postfix-2/master.cf| cut -d" "
-f1)
if [ -x $OPENSLP_BIN -a -n "$PIFACES" ]; then
FQHN=$(postconf -h myhostname)
for srv in $PSERVICES; do
sport=$(sed -ne
"/^$srv/Is/^$srv[[:space:]]\+\([0-9]\+\)\/tcp.*/\1/gp" /etc/services)
if [ -n "$sport" ]; then
$OPENSLP_BIN $cmd service:$srv://$FQHN:$sport > /dev/null 2>&1
fi
done
fi
}
# Shell functions sourced from /etc/rc.status:
# rc_check check and set local and overall rc status
# rc_status check and set local and overall rc status
# rc_status -v ditto but be verbose in local rc status
# rc_status -v -r ditto and clear the local rc status
# rc_failed set local and overall rc status to failed
# rc_failed <num> set local and overall rc status to <num><num> #
rc_reset clear local rc status (overall remains)
# rc_exit exit appropriate to overall rc status
. /etc/rc.status
# First reset status of this service
rc_reset
# Return values acc. to LSB for all commands but status:
# 0 - success
# 1 - generic or unspecified error
# 2 - invalid or excess argument(s)
# 3 - unimplemented feature (e.g. "reload")
# 4 - insufficient privilege
# 5 - program is not installed
# 6 - program is not configured
# 7 - program is not running
#
# Note that starting an already running service, stopping
# or restarting a not-running service as well as the restart
# with force-reload (in case signalling is not supported) are
# considered a success.
case "$1" in
start)
echo -n "Starting mail service (Postfix-2)"
## Start daemon with startproc(8). If this fails
## the echo return value is set appropriate.
if ! /sbin/checkproc -p /var/spool/postfix-2/pid/master.pid $MASTER_BIN;
then
$POSTFIX_BIN -c /etc/postfix-2 start > /dev/null 2>&1
else
rc_reset
fi
# Remember status and be verbose
rc_status -v
( i=60
# waiting for qmgr
while [ -z "$(pidof qmgr)" -a $i -gt 0 ]; do
i=$(( $i - 1 ))
sleep 1
done
/usr/sbin/postfix flush ) > /dev/null 2>&1 &
cond_slp "register" &
;;
stop)
echo -n "Shutting down mail service (Postfix-2)"
## Stop daemon with killproc(8) and if this fails
## set echo the echo return value.
/sbin/killproc -p /var/spool/postfix-2/pid/master.pid -TERM $MASTER_BIN
# Remember status and be verbose
cond_slp "deregister" &
rc_status -v
;;
try-restart)
## Stop the service and if this succeeds (i.e. the
## service was running before), start it again.
## Note: try-restart is not (yet) part of LSB (as of 0.7.5)
$0 status >/dev/null && $0 restart
# Remember status and be quiet
rc_status
;;
restart)
## Stop the service and regardless of whether it was
## running or not, start it again.
$0 stop
$0 start
# Remember status and be quiet
rc_status
;;
force-reload)
## Signal the daemon to reload its config. Most daemons
## do this on signal 1 (SIGHUP).
## If it does not support it, restart.
echo -n "Reload mail service (Postfix-2)"
# if it supports it:
/sbin/killproc -p /var/spool/postfix-2/pid/master.pid -HUP $MASTER_BIN
#touch /var/run/FOO.pid
rc_status -v
/usr/sbin/postfix flush > /dev/null 2>&1
## Otherwise:
#$0 stop && $0 start
#rc_status
;;
reload)
echo -n "Reload mail service (Postfix-2)"
# If it supports signalling:
/sbin/killproc -p /var/spool/postfix-2/pid/master.pid -HUP $MASTER_BIN
#touch /var/run/FOO.pid
rc_status -v
/usr/sbin/postfix flush > /dev/null 2>&1
## Otherwise if it does not support reload:
#rc_failed 3
#rc_status -v
;;
status)
echo -n "Checking for service Postfix-2: "
## Check status with checkproc(8), if process is running
## checkproc will return with exit status 0.
# Status has a slightly different for the status command:
# 0 - service running
# 1 - service dead, but /var/run/ pid file exists
# 2 - service dead, but /var/lock/ lock file exists
# 3 - service not running
# NOTE: checkproc returns LSB compliant status values.
/sbin/checkproc -p /var/spool/postfix-2/pid/master.pid $MASTER_BIN
rc_status -v
;;
*)
echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|reload}"
exit 1
;;
esac
rc_exit
Failure Symptoms:
-does not appear to be reading the second config dir
-smtpd not running on second nic (as per main.cf settings)
-if used to stop service, script stops first instance
-first instance is running fine
I can provide more data if/as needed.
Thanks
--
Check the headers for your unsubscription address
For additional commands send e-mail to suse-linux-e-help@suse.com
Also check the archives at http://lists.suse.com
Please read the FAQs: suse-linux-e-faq@suse.com