PDA

Archiv verlassen und diese Seite im Standarddesign anzeigen : mlnet als runlevel



mase-faq
08.01.04, 08:10
Hallo!
Wie kann ich bestimmte Programme (mlnet) in einem bestimmten
Arbeitsverzeichnis (/mldonkey) als runlevel (3,5) starten?
Ich habe versucht, ein Startscript zu erstellen und habe es ausführbar gemacht:

cd /mldonkey
./mlnet

Aber dieses Script lässt sich im Runlevel-Editor nicht aktivieren.
Manuell lässt es sich starten und funktioniert auch.
Ich verwende SuSe 9.0.

HirschHeisseIch
08.01.04, 08:19
ln -s /etc/init.d/<scriptname> /etc/init.d/rc5.d/S99<scriptname>
ln -s /etc/init.d/<scriptname> /etc/init.d/rc3.d/S99<scriptname>

Vorausgesetzt, du hast das script nach /etc/init.d kopiert.
Wenns dann noch nicht geht, hast du vielleicht vergessen, die rechte richtig zu setzen. (chmod +x <scriptname>)

mase-faq
10.01.04, 14:41
Danke, das hat ja mal soweit funktioniert!
Doch da treff ich schon auf das nächste Problem.
Der ml-core (mlnet) beendet seine Ausgabe auf die Konsole ja nicht,
bis mlnet beendet wird.
Der Rechner bootet an dieser Stelle also nicht weiter.
Er startet den core und das war's dann.
Mein Script sieht folgendermassen aus:

#! /bin/sh
cd /data1/mldonkey/
./mlnet

fs111
10.01.04, 16:46
Du musst mlnet auch in den Hintergrund schicken mit ./mlnet &, damit init weiter machen kann, außerdem empfiehlt sich nice -n 19 ./mlnet -run_as_user <NAME> & damit er erstens nicht zu viel Last erzeugt und zweitens nicht als root läuft.

fs111

xeroc
10.01.04, 18:45
im forum von mldonkey.org/portal gibts auch sonen thread im FAQ-Board .. schau da mal rein ...

Thallez
10.01.04, 19:16
so sollte es gehen

#! /bin/sh
cd /data1/mldonkey/
./mlnet 2>&1 > /dev/null &

mase-faq
11.01.04, 17:47
Also ich hab mal folgendes versucht und mlnet startet auch.
Allerdings nicht im Arbeitsverzeichnis /data1/mldonkey/
Wie kann ich mlnet dazu bewegen, im Arbeitsverzeichnis zu starten?


#! /bin/sh
# /etc/init.d/mlnet
#
# System startup script for the mlnet Daemon
#
### BEGIN INIT INFO
# Provides: mlnet
# Default-Start: 2 3 5
# Default-Stop: 0 1 6
# Description: Start mlnet.
### END INIT INFO

MLNET_BIN=/data1/mldonkey/mlnet
test -x $MLNET_BIN || exit 5

# 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 mlnet"
## Start daemon with startproc(8). If this fails
## the echo return value is set appropriate.

# NOTE: startproc return 0, even if service is
# already running to match LSB spec.
startproc .MLNET_BIN > /dev/null 2>&1

# Remember status and be verbose
rc_status -v
;;
stop)
echo -n "Shutting down mlnet"
## Stop daemon with killproc(8) and if this fails
## set echo the echo return value.

killproc -TERM $MLNET_BIN

# Remember status and be verbose
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 service mlnet"
killproc -HUP $MLNET_BIN
rc_status -v
;;
reload)
## Like force-reload, but if daemon does not support
## signalling, do nothing (!)

# If it supports signalling:
echo -n "Reload service mlnet"
killproc -HUP $MLNET_BIN
rc_status -v
;;
status)
echo -n "Checking for mlnet: "
## 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.
checkproc $MLNET_BIN
rc_status -v
;;
*)
echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|reload}"
exit 1
;;
esac
rc_exit