ho installato stunnel nella mia macchina CentOS come di seguito:come creare un servizio per STUNNEL installato su CentOS 5,10
yum install stunnel -y
openssl genrsa -out privkey.pem 2048
openssl req -new -x509 -key privkey.pem -out cacert.pem -days 1095
cat privkey.pem cacert.pem >> /etc/stunnel/stunnel.pem
chmod 600 /etc/stunnel/stunnel.pem
chown nobody.nobody /var/run/stunnel
nano -K /etc/stunnel/stunnel.conf
cert = /etc/stunnel/stunnel.pem
chroot = /var/run/stunnel/
pid = /stunnel.pid
setuid = nobody
setgid = nobody
output = stunnel.log
[squid]
# Ensure the ‘connect’ line matches your squid port. Default is 3128
accept = 8088
connect = 127.0.0.1:1945
mia il problema è dopo l'installazione di stunnel non è disponibile il servizio per stunnel installato.
Così ho scritto questo:
nano -K /etc/init.d/stunnel
#!/bin/bash
# /etc/rc.d/init.d/stunnel
#
# Starts the stunnel daemon
#
# chkconfig: 345 70 30
# description: Stunnel Server is a ...
# processname: stunnel
# config: /etc/stunnel/stunnel.conf
# Source function library.
. /etc/init.d/functions
test -x /usr/sbin/stunnel || exit 0
RETVAL=0
#
# See how we were called.
#
prog="stunnel"
start() {
# Check if stunnel is already running
if [ ! -f /var/lock/subsys/stunnel ];
then
echo -n $"Starting $prog: "
daemon /usr/sbin/stunnel
RETVAL=$?
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/stunnel
echo
fi
return $RETVAL
}
stop() {
echo -n $"Stopping $prog: "
killproc /usr/sbin/stunnel
RETVAL=$?
[ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/stunnel
echo
return $RETVAL
}
restart() {
stop
start
}
reload() {
restart
}
status() {
status /usr/sbin/stunnel
}
case "$1" in
start)
start
;;
stop)
stop
;;
reload|restart)
restart
;;
status)
status
;;
*)
echo $"Usage: $0 {start|stop|restart|reload|status}"
exit 1
esac
exit $?
exit $RETVAL
chmod +x /etc/init.d/stunnel
chkconfig --add stunnel
il comando di avvio per il servizio scritto funziona bene: servizio stunnel start: OK.
ma ho errore durante il comando di arresto: servizio stunnel interrompere: FAILED
e devo errore durante comando di stato: servizio stato stunnel:
/sbin/servizio: linea 66: 7456 Segmentazione difetto env -i LANG = "$ LANG" PATH = TERMINE "$ PATH" = "$ TERM" "$ {} SERVICEDIR/$ {} SERVIZIO" $ {} OPZIONI
cosa ho fatto di sbagliato e come posso risolvere il problema?
c'è un modo migliore per ottenere quel servizio?
grazie in anticipo
ecco la mia versione stunnel: stunnel.i386 4.15-2.el5.1 installato – MoonLight
sono disponibili due linee di uscita nella parte inferiore della quella sceneggiatura. Non può funzionare come vuoi tu. Scopri quale di quelli desideri e risolvi il problema e vedi se questo aiuta il caso 'stop'. Cosa ottieni se esegui 'sh -x/sbin/service stunnel status' (probabilmente ci sarà un sacco di output)? –
caro @Etan Reisner: davvero grazie per l'attenzione. alla fine ho trovato il mio file obiettivo e l'ho messo come risposta. – MoonLight