# Ssh can be used for remote login, remote file copying, TCP port \
# forwarding etc. Ssh offers strong encryption and authentication.
+SSHD_OOM_ADJUST=-17
# Source function library
. /etc/rc.d/init.d/functions
exit 0
fi
+adjust_oom() {
+ if [ -e /var/run/sshd.pid ]; then
+ for pid in $(cat /var/run/sshd.pid); do
+ if [ -w "/proc/$pid/oom_adj" ]; then
+ echo "$SSHD_OOM_ADJUST" > "/proc/$pid/oom_adj" 2> /dev/null || :
+ fi
+ done
+ fi
+}
+
checkconfig() {
/usr/sbin/sshd -t || exit 1
}
-RETVAL=0
-# See how we were called.
-case "$1" in
- start)
+start() {
# generate new keys with empty passwords if they do not exist
if [ ! -f /etc/ssh/ssh_host_key -o ! -s /etc/ssh/ssh_host_key ]; then
/usr/bin/ssh-keygen -t rsa1 -f /etc/ssh/ssh_host_key -N '' 1>&2
# Check if the service is already running?
if [ ! -f /var/lock/subsys/sshd ]; then
msg_starting OpenSSH
- daemon /usr/sbin/sshd
+ daemon --pidfile /var/run/sshd.pid /usr/sbin/sshd
RETVAL=$?
+ adjust_oom
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/sshd
else
msg_already_running OpenSSH
fi
- ;;
- stop)
+}
+
+stop() {
if [ -f /var/lock/subsys/sshd ]; then
msg_stopping OpenSSH
# we use start-stop-daemon to stop sshd, as it is unacceptable for such
else
msg_not_running OpenSSH
fi
+}
+
+RETVAL=0
+# See how we were called.
+case "$1" in
+ start)
+ start
+ ;;
+ stop)
+ stop
;;
restart)
checkconfig
- $0 stop
- $0 start
- exit $?
+ stop
+ start
;;
status)
status sshd
;;
reload|force-reload)
if [ -f /var/lock/subsys/sshd ]; then
+ checkconfig
msg_reloading OpenSSH
killproc sshd -HUP
RETVAL=$?