patrickt

PhantomJS service init

Jun 17th, 2013
408
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Bash 4.78 KB | None | 0 0
  1. #! /bin/sh
  2. ### BEGIN INIT INFO
  3. # Provides:          phantomjs
  4. # Required-Start:    $local_fs $remote_fs $network $syslog $named
  5. # Required-Stop:     $local_fs $remote_fs $network $syslog $named
  6. # Default-Start:     2 3 4 5
  7. # Default-Stop:      0 1 6
  8. # Short-Description: Start/Stop PhantomJS headless browser
  9. # Description:       This file should be used to construct scripts to be
  10. #                    placed in /etc/init.d.
  11. ### END INIT INFO
  12.  
  13. # Author: Patrick Thurmond <[email protected]>
  14. #
  15. # Setup Instructions: Copy this file to "/etc/init.d" and make sure that the
  16. #   owner and group for the file is root.
  17. #
  18. # Manual Run Instructions: To run manually you need to just call it like this:
  19. #   sudo /etc/init.d/phantomjs start
  20. #
  21. # Automatic Run Istructions:
  22. #   To set it up run: "sudo update-rc.d phantomjs defaults"
  23. #   To enable it run: "sudo update-rc.d phantomjs enable"
  24. #
  25.  
  26. # Do NOT "set -e"
  27.  
  28. # PATH should only include /usr/* if it runs after the mountnfs.sh script
  29. PATH=/sbin:/usr/sbin:/bin:/usr/bin
  30. DESC="Start/Stop PhantomJS headless browser"
  31. NAME=phantomjs
  32. DAEMON=/virtualhosts/automated-testing/behat/ecash/bin/$NAME
  33. DAEMON_ARGS="--webdriver=8643"
  34. PIDFILE=/var/run/$NAME.pid
  35. SCRIPTNAME=/etc/init.d/$NAME
  36.  
  37. # Exit if the package is not installed
  38. [ -x "$DAEMON" ] || exit 0
  39.  
  40. # Read configuration variable file if it is present
  41. #[ -r /etc/default/$NAME ] && . /etc/default/$NAME
  42.  
  43. # Load the VERBOSE setting and other rcS variables
  44. . /lib/init/vars.sh
  45.  
  46. # Define LSB log_* functions.
  47. # Depend on lsb-base (>= 3.2-14) to ensure that this file is present
  48. # and status_of_proc is working.
  49. . /lib/lsb/init-functions
  50.  
  51. #
  52. # Function that starts the daemon/service
  53. #
  54. do_start()
  55. {
  56.     # Return
  57.     #   0 if daemon has been started
  58.     #   1 if daemon was already running
  59.     #   2 if daemon could not be started
  60.     start-stop-daemon --background --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
  61.         || return 1
  62.     start-stop-daemon --background --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \
  63.         $DAEMON_ARGS \
  64.         || return 2
  65.     # Add code here, if necessary, that waits for the process to be ready
  66.     # to handle requests from services started subsequently which depend
  67.     # on this one.  As a last resort, sleep for some time.
  68. }
  69.  
  70. #
  71. # Function that stops the daemon/service
  72. #
  73. do_stop()
  74. {
  75.     # Return
  76.     #   0 if daemon has been stopped
  77.     #   1 if daemon was already stopped
  78.     #   2 if daemon could not be stopped
  79.     #   other if a failure occurred
  80.     start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
  81.     RETVAL="$?"
  82.     [ "$RETVAL" = 2 ] && return 2
  83.     # Wait for children to finish too if this is a daemon that forks
  84.     # and if the daemon is only ever run from this initscript.
  85.     # If the above conditions are not satisfied then add some other code
  86.     # that waits for the process to drop all resources that could be
  87.     # needed by services started subsequently.  A last resort is to
  88.     # sleep for some time.
  89.     start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
  90.     [ "$?" = 2 ] && return 2
  91.     # Many daemons don't delete their pidfiles when they exit.
  92.     rm -f $PIDFILE
  93.     return "$RETVAL"
  94. }
  95.  
  96. #
  97. # Function that sends a SIGHUP to the daemon/service
  98. #
  99. do_reload() {
  100.     #
  101.     # If the daemon can reload its configuration without
  102.     # restarting (for example, when it is sent a SIGHUP),
  103.     # then implement that here.
  104.     #
  105.     start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
  106.     return 0
  107. }
  108.  
  109. case "$1" in
  110.   start)
  111.     [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
  112.     do_start
  113.     case "$?" in
  114.         0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
  115.         2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
  116.     esac
  117.     ;;
  118.   stop)
  119.     [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
  120.     do_stop
  121.     case "$?" in
  122.         0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
  123.         2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
  124.     esac
  125.     ;;
  126.   status)
  127.        status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
  128.        ;;
  129.   #reload|force-reload)
  130.     #
  131.     # If do_reload() is not implemented then leave this commented out
  132.     # and leave 'force-reload' as an alias for 'restart'.
  133.     #
  134.     #log_daemon_msg "Reloading $DESC" "$NAME"
  135.     #do_reload
  136.     #log_end_msg $?
  137.     #;;
  138.   restart|force-reload)
  139.     #
  140.     # If the "reload" option is implemented then remove the
  141.     # 'force-reload' alias
  142.     #
  143.     log_daemon_msg "Restarting $DESC" "$NAME"
  144.     do_stop
  145.     case "$?" in
  146.       0|1)
  147.         do_start
  148.         case "$?" in
  149.             0) log_end_msg 0 ;;
  150.             1) log_end_msg 1 ;; # Old process is still running
  151.             *) log_end_msg 1 ;; # Failed to start
  152.         esac
  153.         ;;
  154.       *)
  155.         # Failed to stop
  156.         log_end_msg 1
  157.         ;;
  158.     esac
  159.     ;;
  160.   *)
  161.     #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
  162.     echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2
  163.     exit 3
  164.     ;;
  165. esac
  166.  
  167. :
Advertisement
Add Comment
Please, Sign In to add comment