stop/restart servoy server by terminal

Hi,

how can I stop/restart the Servoy App server by Terminal?
I couldn’t find any function in the wiki.

Regards,

On Linux you have to create a init.d script for that, on MacOS you can use Lingon.
Which platform are you using?

Hi Nicola,

I would like to have it for both, Mac OS X and Linux.

Does the init.d script for Linux than work like: ```
./etc/init.d/servoy_server start/stop/restart


A script example would be very appreciate.

Regards,

Here’s the init.d script for Ubuntu/Debian, you just need to define the USER and HOME variables in the beginning of the script and install it for the desired runlevels:

#! /bin/sh
### BEGIN INIT INFO
# Provides:          Servoy Server
# Required-Start:    $local_fs $remote_fs
# Required-Stop:     $local_fs $remote_fs
# Default-Start:     2 3 4 5
# Default-Stop:      S 0 1 6
# Short-Description: Servoy Server Startup Script
# Description:       This file starts the Servoy Server
### END INIT INFO

# Author: Nicola Gervasi <nick@sintpro.com>

# Do NOT "set -e"

# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/usr/sbin:/usr/bin:/sbin:/bin
DESC="Servoy Server"
USER=servoy
HOME=/home/servoy/servoy/application_server
NAME=servoy_server.sh
DAEMON=$HOME/$NAME
DAEMON_ARGS=""
PIDFILE=$HOME/servoy.pid
SCRIPTNAME=/etc/init.d/servoy

# Exit if the package is not installed
[ -x "$DAEMON" ] || exit 0

# Read configuration variable file if it is present
[ -r /etc/default/$NAME ] && . /etc/default/$NAME

# Load the VERBOSE setting and other rcS variables
[ -f /etc/default/rcS ] && . /etc/default/rcS

# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions

#
# Function that starts the daemon/service
#
do_start()
{
	# Return
	#   0 if daemon has been started
	#   1 if daemon was already running
	#   2 if daemon could not be started
	start-stop-daemon --start --quiet  --pidfile $PIDFILE --chuid $USER --chdir $HOME \
		--make-pidfile --background --exec $DAEMON --$DAEMON_ARGS
	
	# Add code here, if necessary, that waits for the process to be ready
	# to handle requests from services started subsequently which depend
	# on this one.  As a last resort, sleep for some time.
}

#
# Function that stops the daemon/service
#
do_stop()
{
	# Return
	#   0 if daemon has been stopped
	#   1 if daemon was already stopped
	#   2 if daemon could not be stopped
	#   other if a failure occurred
	start-stop-daemon --stop --quiet --retry=TERM/5/KILL/5 \
		--user $USER --name "java" --oknodo
	RETVAL="$?"
	[ "$RETVAL" = 2 ] && return 2
	# Many daemons don't delete their pidfiles when they exit.
	rm -f $PIDFILE
	return "$RETVAL"
}

#
# Function that sends a SIGHUP to the daemon/service
#
do_reload() {
	#
	# If the daemon can reload its configuration without
	# restarting (for example, when it is sent a SIGHUP),
	# then implement that here.
	#
	start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
	return 0
}

case "$1" in
  start)
	[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
	do_start
	case "$?" in
		0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
		2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
	esac
	;;
  stop)
	[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
	do_stop
	case "$?" in
		0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
		2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
	esac
	;;
  #reload|force-reload)
	#
	# If do_reload() is not implemented then leave this commented out
	# and leave 'force-reload' as an alias for 'restart'.
	#
	#log_daemon_msg "Reloading $DESC" "$NAME"
	#do_reload
	#log_end_msg $?
	#;;
  restart|force-reload)
	#
	# If the "reload" option is implemented then remove the
	# 'force-reload' alias
	#
	log_daemon_msg "Restarting $DESC" "$NAME"
	do_stop
	case "$?" in
	  0|1)
		do_start
		case "$?" in
			0) log_end_msg 0 ;;
			1) log_end_msg 1 ;; # Old process is still running
			*) log_end_msg 1 ;; # Failed to start
		esac
		;;
	  *)
	  	# Failed to stop
		log_end_msg 1
		;;
	esac
	;;
  *)
	#echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
	echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
	exit 3
	;;
esac

:

For MacOS download Lingon, it’s pretty straight forward.

Cool! Thank you very much Nicola!

Hi Nicola,

I have created the script file “servoy” in the directory /etc/init.d on my Debian 6 system like your example.
I also defined the variables USER and HOME and set the permissions to executable, but it doesn’t work.
If I make a restart of the Server, Servoy App Server doesn’t start by init.d (note: The PostgreSQL Server is starting/stopping/restarting by its init.d script). In the logfiles I couldn’t find anything about.

Do you have any idea what could be wrong?

Regards,

Did you run the “update-rc.d” command to install the script in the desired runlevels? Check update-rc.d man page for details.
If that doesn’t fix it let me know which error you get when you run sudo /etc/init.d/servoy start.

I have tied to install the script into the runlevels by “update-rc.d” and I get:

administrator@debian-6-server:/etc/init.d$ sudo update-rc.d servoy defaults
[sudo] password for administrator: 
update-rc.d: using dependency based boot sequencing
update-rc.d: warning: servoy start runlevel arguments (2 3 4 5) do not match LSB Default-Start values (     2 3 4 5)
update-rc.d: warning: servoy stop runlevel arguments (0 1 6) do not match LSB Default-Stop values (      S 0 1 6)
insserv: Script servoy is broken: incomplete LSB comment.
insserv: missing valid name for `Provides:' please add.

I can set the startup item to enabled with “rcconf”. But this is what I get in the Terminal if I try to start the Servoy server:

administrator@debian-6-server:~$ sudo /etc/init.d/servoy start
/etc/init.d/servoy: 71: Syntax error: Unterminated quoted string

And if I check if the startup item is installed by “sudo ls -l /etc/rc?.d/servoy” I get that it is not found.

It works in Ubuntu just fine, probably your Debian expects a slightly different syntax when installing.
Just change the following lines (6 and 7) with the runlevels that update-rc.d expects:

# Default-Start:     2 3 4 5
# Default-Stop:      S 0 1 6

I checked line 71 and it’s just a plain comment:

# Many daemons don't delete their pidfiles when they exit.

I checked around that line and I don’t see any “Unterminated quoted string”, Can you double check the code? Maybe some quotes got corrupted from copy paste?

Hi Nicola,

I have formatted the script in the Terminal editor (nano) because of possible errors occurred by copy/paste, and now I get no more errors about this.
The startup item should now set correctly because there are entries of “servoy” in the /etc/rc*.d/. But now it comes:

administrator@debian-6-server:~$ sudo /etc/init.d/servoy start
start-stop-daemon: unrecognized option '--quiet '
Try 'start-stop-daemon --help' for more information.
/etc/init.d/servoy: 141:  : not found

Ok, the daemon don’t like the “–quiet” option and I have removed it in the codelines. Now the finally error is “/etc/init.d/servoy: 141: : not found” (line 141 is now the last of the script!).
Here is my modified script:

#! /bin/sh
### BEGIN INIT INFO
# Provides:Servoy Server
# Required-Start:$local_fs $remote_fs
# Required-Stop:$local_fs $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Servoy Server Startup Script
# Description: This file starts the Servoy Server
### END INIT INFO

# Author: Nicola Gervasi <nick@sintpro.com>

# Do NOT "set -e"

# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/usr/sbin:/usr/bin:/sbin:/bin
DESC="Servoy Server"
USER=administrator
HOME=/home/administrator/servoy6/application_server
NAME=servoy_server.sh
DAEMON=$HOME/$NAME
DAEMON_ARGS=""
PIDFILE=$HOME/servoy.pid
SCRIPTNAME=/etc/init.d/servoy

# Exit if the package is not installed
[ -x "$DAEMON" ] || exit 0

# Read configuration variable file if it is present
[ -r /etc/default/$NAME ] && . /etc/default/$NAME

# Load the VERBOSE setting and other rcS variables
[ -f /etc/default/rcS ] && . /etc/default/rcS

# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions

#
# Function that starts the daemon/service
#
do_start()
{
        # Return
        #   0 if daemon has been started
        #   1 if daemon was already running
        #   2 if daemon could not be started
        start-stop-daemon --start --pidfile $PIDFILE --chuid $USER --chdir $HOME \ --make-pidfile --background --exec $
   
        # Add code here, if necessary, that waits for the process to be ready
        # to handle requests from services started subsequently which depend
        # on this one.  As a last resort, sleep for some time.
}

#
# Function that stops the daemon/service
#
do_stop()
{
        # Return
        #   0 if daemon has been stopped
        #   1 if daemon was already stopped
        #   2 if daemon could not be stopped
        #   other if a failure occurred
        start-stop-daemon --stop --retry=TERM/5/KILL/5 \ --user $USER --name "java" --oknodo
        RETVAL="$?"
        [ "$RETVAL" = 2 ] && return 2
        # Many daemons do not delete their pidfiles when they exit.
        rm -f $PIDFILE
        return "$RETVAL"
}

#
# Function that sends a SIGHUP to the daemon/service
#
do_reload()
{
        #
        # If the daemon can reload its configuration without
        # restarting for example, when it is sent a SIGHUP,
        # then implement that here.
        #
        start-stop-daemon --stop --signal 1 --pidfile $PIDFILE --name $NAME
        return 0
}

case "$1" in
        start)
        [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
        do_start
        case "$?" in
                0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
                2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
        esac
        ;;
        stop)
        [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
        do_stop
        case "$?" in
                0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
                2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
        esac
        ;;
        #reload|force-reload)
        #
        # If do_reload is not implemented then leave this commented out
        # and leave 'force-reload' as an alias for 'restart'.
        #
        #log_daemon_msg "Reloading $DESC" "$NAME"
        #do_reload
        #log_end_msg $?
        #;;
        restart|force-reload)
        #
        # If the "reload" option is implemented then remove the
        # 'force-reload' alias
        #
        log_daemon_msg "Restarting $DESC" "$NAME"
        do_stop
        case "$?" in
                0|1)
                do_start
        case "$?" in
                0) log_end_msg 0 ;;
                1) log_end_msg 1 ;; # Old process is still running
                *) log_end_msg 1 ;; # Failed to start
        esac
        ;;
        *)
                # Failed to stop
                log_end_msg 1
        ;;
        esac
        ;;
        *)
        #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
        echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
        exit 3
        ;;
esac

EDIT
The Servoy App Server is now starting automatically on reboot of the Debian server, but the manual restart/stop function will not work.

sudo /etc/init.d/servoy restart
Restarting Servoy Server: servoy_server.sh/etc/init.d/servoy: 141:  : not found
 failed!

Regards and once more thank you Nicola,

You’re welcome.
About the error: you are missing a semicolon, this is how the file should end:

        #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
        echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
        exit 3
        ;;
esac

:

Don’t fotget the last semicolon!

Hi Nicola,

I have added the “:” (doublecolon? I think semicolon is a “;”, or?) on the end of the script.
Now it is working. I can start/stop/restart() the servoy server by "sudo /etc/init.d/servoy ()", but only on stop I get no error.

Anyway, it’s doing what it should do and I will investigate a little bit more the script code and the way I have installed/configured it.
You helped me a lot and I could save time to get it working only by myself.

Regards,

Woops, I was in a hurry, it’s a “colon” (:slight_smile: not a “semicolon” (;).

Glad to have helped.