summaryrefslogtreecommitdiffstats
path: root/slackware/rc.rsyslogd
blob: 10a27911efefb33758fbd3c63e11ca1467ee51c9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#!/bin/sh
# Start/stop/restart the system logging daemons.
#
# Written for Slackware Linux by Patrick J. Volkerding <volkerdi@slackware.com>.
# Modded for rsyslogd by Chris Elvidge <chris@lowe.ae> Sept 2005
#

create_xconsole()
{
    if [ ! -e /dev/xconsole ]; then
      mknod -m 640 /dev/xconsole p
    else
      chmod 0640 /dev/xconsole
    fi
    chown 0:0 /dev/xconsole
}

rsyslogd_start() {
  if [ -x /usr/sbin/rsyslogd -a -x /usr/sbin/klogd ]; then
    echo "Starting rsyslogd / klogd daemons:  "
# this one listens on the "usual" socket /dev/log
    echo "/usr/sbin/rsyslogd -i $pidfile1"
    /usr/sbin/rsyslogd -i "$pidfile1"
# this one listens only to the UDP port
    sleep 1
    echo "/usr/sbin/rsyslogd -o -r 0 -f $confile2 -i $pidfile2"
    /usr/sbin/rsyslogd -o -r 0 -f "$confile2" -i "$pidfile2"
    sleep 1 # prevent syslogd/klogd race condition on SMP kernels
    echo "/usr/sbin/klogd -c 3 -x"
    # '-c 3' = display level 'error' or higher messages on console
    # '-x' = turn off broken EIP translation
    /usr/sbin/klogd -c 3 -x
  fi
}

rsyslogd_stop() {
  killall rsyslogd 2> /dev/null
  killall klogd 2> /dev/null
  /usr/bin/rm pidfile1 2> /dev/null
  /usr/bin/rm pidfile2 2> /dev/null
}

rsyslogd_restart() {
  rsyslogd_stop
  sleep 1
  rsyslogd_start
}

confile1=/etc/rsyslog.conf
pidfile1=/var/run/rsyslogd.pid

confile2=/etc/rsyslog.udp.conf
pidfile2=/var/run/rsyslogd.udp.pid

case "$1" in
'start')
  create_xconsole
  rsyslogd_start
  ;;
'stop')
  rsyslogd_stop
  ;;
'restart')
  rsyslogd_restart
  ;;
*)
  echo "usage $0 start|stop|restart"
esac