Question

I have installed a program called node.js on my server to listen on port 8088

My server is a VPS package level 3 from hostgator.

Now i m trying to create a init.d script so that node.js runs automatically with system and can restart if crashed autimatically.

After a bit googling on it, i came across some resources and mashed up a init.d script. Its more of a copy pasting job as u can see :) I got quite some problem, which most probably includes the init.d script having wrong sysntax.

#! /bin/sh
#
# Copyright (c) 2011 Anjan Bhowmik
# All rights reserved.

# Author: Anjan Bhowmik, 2011
#
# /etc/init.d/nodejs
#   and its symbolic link
# /usr/sbin/rcnodejs

### BEGIN INIT INFO
# Provides:          nodejs
# Required-Start:    $network
# Required-Stop:
# Default-Start:     3 5
# Default-Stop:      0 1 2 6
# Short-Description: Node.js daemon
# Description:       NOde.js server that listens to port 8088
### END INIT INFO

$NODEJS_BIN = $(which node)
$NODEJS_JS_FILE = /home/anjan/server.js

# Load the rc.status script for this service.
. /etc/rc.status

# Reset status of this service
rc_reset

case "$1" in
    start)
        echo -n "Starting node.js "
        ## Start daemon with startproc(8). If this fails
        ## the return value is set appropriately by startproc.
        startproc $NODEJS_BIN $NODEJS_JS_FILE

        # Remember status and be verbose
        rc_status -v
        ;;
    stop)
        echo -n "Shutting down node.js "
        ## Stop daemon with killproc(8) and if this fails
        ## killproc sets the return value according to LSB.

        killproc -TERM $NODEJS_BIN

        # Remember status and be verbose
        rc_status -v
        ;;
    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
        ;;
    reload)
        # If it supports signaling:
        echo -n "Reload service node.js "
        killproc -HUP $NODEJS_BIN
        #touch /var/run/BAR.pid
        rc_status -v

        ## Otherwise if it does not support reload:
        #rc_failed 3
        #rc_status -v
        ;;
    status)
        echo -n "Checking for service node.js "
        ## Check status with checkproc(8), if process is running
        ## checkproc will return with exit status 0.

        # Return value is slightly different for the status command:
        # 0 - service up and running
        # 1 - service dead, but /var/run/  pid  file exists
        # 2 - service dead, but /var/lock/ lock file exists
        # 3 - service not running (unused)
        # 4 - service status unknown :-(
        # 5--199 reserved (5--99 LSB, 100--149 distro, 150--199 appl.)

        # NOTE: checkproc returns LSB compliant status values.
        checkproc $NODEJS_BIN
        # NOTE: rc_status knows that we called this init script with
        # "status" option and adapts its messages accordingly.
        rc_status -v
        ;;
    *)
        ## If no parameters are given, print which are avaiable.
        echo "Usage: $0 {start|stop|status|restart|reload}"
        exit 1
        ;;
esac

rc_exit

I really get confused as different systems use different approaches. My local ubuntu uses something called upstart, but my server doesn't seem to have upstart and uses init.d scripts only.

If I issue a "uname -a" I get this:

Linux onl.onlyfreelancer.com 2.6.18-028stab070.14 #1 SMP 
Thu Nov 18 16:04:02 MSK 2010 x86_64 x86_64 x86_64 GNU/Linux

Also, I can't seem to find utils like "insserv" to enable this init.d script. So, if my init.s script is correct, how can I set it up correctly?

Any help is much appreciated, I've been battling this thing for 2 days with no luck yet.

Was it helpful?

Solution

less /usr/share/doc/initscripts-*/sysvinitfiles
man 8 chkconfig
man 8 service

OTHER TIPS

For critical apps you might also consider the "don't start services, run them" approach. supervisord and daemontools might help here.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top