List Info

Thread: cherokee init script FEDORA COMPLIANT




cherokee init script FEDORA COMPLIANT
user name
2006-10-06 21:53:27
Hello Alvaro.

Just my first time testing the cherokee web server, and I found a TRIVIAL bug on the init script.I'm using Fedora Core 5 on a x86_64 based system and wanted to start cherokee on startup, so I followed trying some steps:

FC (and any RH-based distro) doesn't have the update-rc.d script; instead, they have chkconfig. So, I created the link on /etc/rc.d and tried to enable cherokee on chkconfig, but it failed,

I build the last 0.5.5 tarball source, and all goes very good, so I went to copy de contrib/cherokee init script to my /etc/init.d/ directory and for make a link to the especial init scripts on /etc/rc[x].d, I use the redhat chkconfig util,

[rootlocalhost init.d]# chkconfig --add cherokee
service cherokee does not support chkconfig

but I realize that the special line for chkconfig wasn't there, and all the things I need for cherokee to start on my Fedora 5 x86_64 based system, (ANGEL OF GOODNESS come to me and inspire me), so I made some investigation of your DAEMON and the arguments, to finally wrote a contrib REDHAT FEDORA compliant cherokee init script for all the folks who have problems with the init so this is the new contrib/cherokee.server.fedora compliant:

******************************************************************
#!/bin/sh
#
# Contrib to RedHat Fedora Based Systems by: carlotezgmail.com">carlotezgmail.com
# chkconfig: 2345 95 05
# description: Starts and stops the Cherokee ligth Web Server system
#

# Source function library
. /etc/rc.d/init.d/functions

NAME=cherokee
BASE=/usr/local/cherokee/sbin/$NAME
DAEMON="-b";
CONF="/etc/cherokee/cherokee.conf"
PIDFILE="/var/run/$NAME.pid"

# Check that $BASE exists.
[ -f $BASE ] || exit 0

# Source networking configuration.
. /etc/sysconfig/network

# Check that networking is up.
[ ${NETWORKING} = "no" ] && exit 0

RETVAL=0
# See how we were called.
case "$1" in
  start)
        if [ -n "`/sbin/pidof $NAME`" ]; then
          ;      echo -n $"$NAME: already running"
     ;           echo ""
       ;         exit $RETVAL
      ;  fi
     ;   echo -n "Starting Cherokee service: "
        $BASE -C $CONF $DAEMON pidfile $PIDFILE
  ;      sleep 1
       ; action "" /sbin/pidof $NAME
        RETVAL=$?
  ;      [ $RETVAL -eq 0 ] && touch /var/lock/subsys/cherokee
   ;     ;;
  stop)
        echo -n "Shutting down Cherokee service: "
      ;  killproc $BASE
        RETVAL=$?
  ;      echo
 ;       [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/cherokee
   ;     ;;
  restart|reload)
 ;       $0 stop
 ;       $0 start
        RETVAL=$?
        ;;
  status)
      ;  status $BASE
        RETVAL=$?
  ;      ;;
  *)
     ;   echo "Usage: $NAME {start|stop|restart|reload|status}"
      ;  exit 1
esac

exit $RETVAL

******************************************************************

Now everything is fine:

[rootlocalhost init.d]# chkconfig --add cherokee

[rootlocalhost init.d]# chkconfig cherokee on
[rootlocalhost init.d]# service cherokee start
Starting cherokee ...

I could provide a patch, but I don't know how to send the initial script is generated. So, long story short, this issue requires many changes

Thats all Budy !!!
The Cherokee Server just fine on my Fedora 5 x86_64 based system
I hope you can made the changes to that script, or at least, made one called contrib/cherokee.server.fedora with this contrib.


I forgot to tell, I'm a former teacher of operating systems at my university, and the shell programing is a base of that, so I came up with this thing.

Regards,

--
---
Carlitux
Blog Personal: http://carlotez.blogspot.com/
"May the source be with you..."
"In a World without walls and fences who needs WINDOWS and GATES?"
http://counter.li.org/cgi-bin/certificate.cgi/409534

---
Ing. Carlos Alcalá Helguero
Administrador Encargado de Laboratorios de Computo
Universidad Catolica Boliviana "San Pablo";
Phone:  (591)+4249234
Office: (591)+4293100 - Int. 247
Cel:    72735250
Cochabamba - Bolivia


GPG Key:
https://166.114.106.12/~carlotez/key.gpg.asc
pub&nbsp; 1024D/CD98DB19 2006-06-02 Ing. Carlos Javier Alcala Helguero (Administrador de Laboratorios y Servidores) < carlotezgmail.com">carlotezgmail.com >
GPG Fingerprint = BC12 864C 3A3E 9D09 8533  6B7A D3C2 EE1A CD98 DB19
cherokee init script FEDORA COMPLIANT
user name
2006-10-06 22:02:10
El Viernes, 6 de Octubre de 2006 23:53, Carlitux escribió:
> Hello Alvaro.
>
> Just my first time testing the cherokee web server, and
I found a TRIVIAL
> bug on the init script.I'm using Fedora Core 5 on a
x86_64 based system and
> wanted to start cherokee on startup, so I followed
trying some steps:
>
> FC (and any RH-based distro) doesn't have the
update-rc.d script; instead,
> they have chkconfig. So, I created the link on
/etc/rc.d and tried to
> enable cherokee on chkconfig, but it failed,
>
> I build the last 0.5.5 tarball source, and all goes
very good, so I went to
> copy de contrib/cherokee init script to my /etc/init.d/
directory and for
> make a link to the especial init scripts on
/etc/rc[x].d, I use the redhat
> chkconfig util,
>
> [rootlocalhost init.d]# chkconfig --add cherokee
> service cherokee does not support chkconfig
>
> but I realize that the special line for chkconfig
wasn't there, and all the
> things I need for cherokee to start on my Fedora 5
x86_64 based system,
> (ANGEL OF GOODNESS come to me and inspire me), so I
made some investigation
> of your DAEMON and the arguments, to finally wrote a
contrib REDHAT FEDORA
> compliant cherokee init script for all the folks who
have problems with the
> init so this is the new contrib/cherokee.server.fedora
compliant:
>
>
************************************************************
******
> #!/bin/sh
> #
> # Contrib to RedHat Fedora Based Systems by:
carlotezgmail.com
> # chkconfig: 2345 95 05
> # description: Starts and stops the Cherokee ligth Web
Server system
> #
>
> # Source function library
> . /etc/rc.d/init.d/functions
>
> NAME=cherokee
> BASE=/usr/local/cherokee/sbin/$NAME
> DAEMON="-b"
> CONF="/etc/cherokee/cherokee.conf"
> PIDFILE="/var/run/$NAME.pid"
>
> # Check that $BASE exists.
> [ -f $BASE ] || exit 0
>
> # Source networking configuration.
> . /etc/sysconfig/network
>
> # Check that networking is up.
> [ $ = "no" ] && exit 0
>
> RETVAL=0
> # See how we were called.
> case "$1" in
>   start)
>         if [ -n "`/sbin/pidof $NAME`" ]; then
>                 echo -n $"$NAME: already
running"
>                 echo ""
>                 exit $RETVAL
>         fi
>         echo -n "Starting Cherokee service: "
>         $BASE -C $CONF $DAEMON pidfile $PIDFILE
>         sleep 1
>         action "" /sbin/pidof $NAME
>         RETVAL=$?
>         [ $RETVAL -eq 0 ] && touch
/var/lock/subsys/cherokee
>         ;;
>   stop)
>         echo -n "Shutting down Cherokee service:
"
>         killproc $BASE
>         RETVAL=$?
>         echo
>         [ $RETVAL -eq 0 ] && rm -f
/var/lock/subsys/cherokee
>         ;;
>   restart|reload)
>         $0 stop
>         $0 start
>         RETVAL=$?
>         ;;
>   status)
>         status $BASE
>         RETVAL=$?
>         ;;
>   *)
>         echo "Usage: $NAME
{start|stop|restart|reload|status}"
>         exit 1
> esac
>
> exit $RETVAL
>
>
************************************************************
******
>
> Now everything is fine:
>
> [rootlocalhost init.d]# chkconfig --add cherokee
>
> [rootlocalhost init.d]# chkconfig cherokee on
> [rootlocalhost init.d]# service cherokee start
> Starting cherokee ...
>
> I could provide a patch, but I don't know how to send
the initial script is
> generated. So, long story short, this issue requires
many changes
>
> Thats all Budy !!!
> The Cherokee Server just fine on my Fedora 5 x86_64
based system
> I hope you can made the changes to that script, or at
least, made one
> called contrib/cherokee.server.fedora with this
contrib.
>
> I forgot to tell, I'm a former teacher of operating
systems at my
> university, and the shell programing is a base of that,
so I came up with
> this thing.
>
> Regards,

Ummmmmmmm, that seems to work fine, of course.
I'm afraid that there's already one start script for
cherokee, which is 
skeleton-based, here it is:

#!/bin/sh
#
#     Fedora Linux init script for cherokee webserver, by
Manuel Arostegui 
#Ramirez, original cherokee.init for Suse by:

#     Marcus Rueckert, SUSE / Novell Inc.
#     Copyright (C) 2006 Marcus Rueckert, SUSE / Novell Inc.
#
#     This init script has the same license as the cherokee
package itself.
#
# /etc/init.d/cherokee
#   and its symbolic link
# /(usr/)sbin/rccherokee
#
# LSB compatible service control script; see http://www.linuxbase.o
rg/spec/
# Please send feedback to http://www.suse.de/feedb
ack/
# 
# Note: This template uses functions rc_XXX defined in
/etc/rc.status on
# UnitedLinux/SUSE/Novell based Linux distributions.
However, it will work
# on other distributions as well, by using the LSB (Linux
Standard Base) 
# or RH functions or by open coding the needed functions.
# Read htt
p://www.tldp.org/HOWTO/HighQuality-Apps-HOWTO/ if you
prefer not 
# to use this template.
#
# chkconfig: 345 99 00
# description: FOO XYZ daemon providing ZYX
# 
### BEGIN INIT INFO
# Provides:          cherokee
# Required-Start:    $syslog $remote_fs
# Should-Start: $time ypbind sendmail
# Required-Stop:     $syslog $remote_fs
# Should-Stop: $time ypbind sendmail
# Default-Start:     3 5
# Default-Stop:      0 1 2 6
# Short-Description: cherokee is a fast webserver
# Description:       cherokee is a fast webserver
### END INIT INFO
#
# Any extensions to the keywords given above should be
preceeded by
# X-VendorTag- (X-UnitedLinux- X-SuSE- for us) according to
LSB.
#
# Notes on Required-Start/Should-Start:
# * There are two different issues that are solved by
Required-Start
#    and Should-Start
# (a) Hard dependencies: This is used by the runlevel editor
to determine
#     which services absolutely need to be started to make
the start of
#     this service make sense. Example: nfsserver should
have
#     Required-Start: $portmap
#     Also, required services are started before the
dependent ones.
#     The runlevel editor will warn about such missing hard
dependencies
#     and suggest enabling. During system startup, you may
expect an error,
#     if the dependency is not fulfilled.
# (b) Specifying the init script ordering, not real (hard)
dependencies.
#     This is needed by insserv to determine which service
should be
#     started first (and at a later stage what services can
be started
#     in parallel). The tag Should-Start: is used for this.
#     It tells, that if a service is available, it should be
started
#     before. If not, never mind.
# * When specifying hard dependencies or ordering
requirements, you can
#   use names of services (contents of their Provides:
section)
#   or pseudo names starting with a $. The following ones
are available
#   according to LSB (1.1):
#       $local_fs               all local file systems are
mounted
#                               (most services should need
this!)
#       $remote_fs              all remote file systems are
mounted
#                               (note that /usr may be
remote, so
#                                many services should
Require this!)
#       $syslog                 system logging facility up
#       $network                low level networking (eth
card, ...)
#       $named                  hostname resolution
available
#       $netdaemons             all network daemons are
running
#   The $netdaemons pseudo service has been removed in LSB
1.2.
#   For now, we still offer it for backward compatibility.
#   These are new (LSB 1.2):
#       $time                   the system time has been set
correctly
#       $portmap                SunRPC portmapping service
available
#   UnitedLinux/SUSE/Novell extensions:
#       $ALL                    indicates that a script
should be inserted
#                               at the end
# * The services specified in the stop tags
#   (Required-Stop/Should-Stop)
#   specify which services need to be still running when
this service
#   is shut down. Often the entries there are just copies or
a subset
#   from the respective start tag.
# * Should-Start/Stop are now part of LSB as of 2.0,
#   formerly SUSE/Unitedlinux used
X-UnitedLinux-Should-Start/-Stop.
#   insserv does support both variants.
# * X-UnitedLinux-Default-Enabled: yes/no is used at
installation time
#   (%fillup_and_insserv macro in %post of many RPMs) to
specify whether
#   a startup script should default to be enabled after
installation.
#   It's not used by insserv.
#
# Note on runlevels:
# 0 - halt/poweroff                     6 - reboot
# 1 - single user                       2 - multiuser
without network exported
# 3 - multiuser w/ network (text mode)  5 - multiuser w/
network and X11 (xdm)
#
# Note on script names:
# http://www.linuxbase.org/spec/refspecs
/LSB_1.3.0/gLSB/gLSB/scrptnames.html
# A registry has been set up to manage the init script
namespace.
# http://www.lanana.org/
# Please use the names already registered or register one or
use a
# vendor prefix.


# Check for missing binaries (stale symlinks should not
happen)
# Note: Special treatment of stop for LSB conformance
CHEROKEE_BIN=/usr/sbin/cherokee
test -x $CHEROKEE_BIN || { echo "$CHEROKEE_BIN not
installed";
        if [ "$1" = "stop" ]; then exit
0;
           else exit 5; fi; }

# Check for existence of needed config file and read it
# CHEROKEE_CONFIG=/etc/sysconfig/cherokee
# test -r $CHEROKEE_CONFIG || { echo "$CHEROKEE_CONFIG
not existing";
#       if [ "$1" = "stop" ]; then exit
0;
#       else exit 6; fi; }

# Read config
# . $CHEROKEE_CONFIG

# Source LSB init functions
# providing start_daemon, killproc, pidofproc,
# log_success_msg, log_failure_msg and log_warning_msg.
# This is currently not used by UnitedLinux based
distributions and
# not needed for init scripts for UnitedLinux only. If it is
used,
# the functions from rc.status should not be sourced or
used.
#. /lib/lsb/init-functions

# 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     be verbose in local rc status and
clear it afterwards
#      rc_status -v -r  ditto and clear both the local and
overall rc status
#      rc_status -s     display "skipped" and exit
with status 3
#      rc_status -u     display "unused" and exit
with status 3
#      rc_failed        set local and overall rc status to
failed
#      rc_failed <num>  set local and overall rc
status to <num>
#      rc_reset         clear both the local and overall rc
status
#      rc_exit          exit appropriate to overall rc
status
#      rc_active        checks whether a service is
activated by symlinks

# Use the SUSE rc_ init script functions;
# emulate them on LSB, RH and other systems

# Default: Assume sysvinit binaries exist
if test -e /etc/rc.status; then
    # SUSE rc script library
    . /etc/rc.status
else
    export LC_ALL=POSIX
    start_daemon() { return /sbin/start_daemon
${1+"$"}; }
    killproc()     { return /sbin/killproc    
${1+"$"}; }
    pidofproc()    { return /sbin/pidofproc   
${1+"$"}; }
    checkproc()    { return /sbin/checkproc   
${1+"$"}; }
    _cmd=$1
    declare -a _SMSG
    if test "$" = "status"; then
        _SMSG=(running dead dead unused unknown reserved)
        _RC_UNUSED=3
    else
        _SMSG=(done failed failed missed failed skipped
unused failed failed 
reserved)
        _RC_UNUSED=6
    fi
     if test -e /lib/lsb/init-functions; then
        # LSB    
        . /lib/lsb/init-functions
        echo_rc()
        {
            if test $ = 0; then
                log_success_msg " 
[${_SMSG[$]}] "
            else
                log_failure_msg " 
[${_SMSG[$]}] "
            fi
        }
        # TODO: Add checking for lockfiles
        checkproc() { return pidofproc ${1+"$"}
>/dev/null 2>&1; }
    elif test -e /etc/init.d/functions; then
        # RHAT
        . /etc/init.d/functions
        echo_rc()
        {
            #echo -n "  [${_SMSG[$]}] "
            if test $ = 0; then
                success "  [${_SMSG[$]}] "
            else
                failure "  [${_SMSG[$]}] "
            fi
        }
        checkproc() { return status ${1+"$"};
}
        start_daemon() { return daemon ${1+"$"};
}
    else
        # emulate it
        echo_rc() { echo "  [${_SMSG[$]}]
"; }
    fi
    rc_reset() { _RC_RV=0; }
    rc_failed()
    {
        if test -z "$1"; then
            _RC_RV=1;
        elif test "$1" != "0"; then
            _RC_RV=$1;
        fi
        return $
    }
    rc_check()
    {
        return rc_failed $?
    }
    rc_status()
    {
        rc_failed $?
        if test "$1" = "-r"; then
_RC_RV=0; shift; fi
        if test "$1" = "-s"; then
rc_failed 5; echo_rc; rc_failed 3; shift; fi
        if test "$1" = "-u"; then
rc_failed $; echo_rc; rc_failed 
3; shift; fi
        if test "$1" = "-v"; then
echo_rc; shift; fi
        if test "$1" = "-r"; then
_RC_RV=0; shift; fi
        return $
    }
    rc_exit() { exit $; }
    rc_active()
    {
        #if test -z "$RUNLEVEL"; then read
RUNLEVEL REST < <(/sbin/runlevel); 
fi
        if test -e /etc/init.d/S[0-9][0-9]$; then return
0; fi
        return 1
    }
fi

# 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       - user had insufficient privileges
# 5       - program is not installed
# 6       - program is not configured
# 7       - program is not running
# 8--199  - reserved (8--99 LSB, 100--149 distrib, 150--199
appl)
#
# Note that starting an already running service, stopping
# or restarting a not-running service as well as the restart
# with force-reload (in case signaling is not supported) are
# considered a success.

case "$1" in
    start)
        echo -n "Starting cherokee "
        ## Start daemon with startproc(8). If this fails
        ## the return value is set appropriately by
startproc.
        start_daemon $CHEROKEE_BIN -b

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

        killproc -TERM $CHEROKEE_BIN

        # Remember status and be verbose
        rc_status -v
        ;;
    try-restart|condrestart)
        ## Do a restart only if the service was active
before.
        ## Note: try-restart is now part of LSB (as of 1.9).
        ## RH has a similar command named condrestart.
        if test "$1" = "condrestart";
then
                echo "$ Use try-restart
$(LSB)$ rather than 
condrestart $(RH)$"
 fi
        $0 status
        if test $? = 0; then
                $0 restart
        else
                rc_reset        # Not running is not a
failure.
        fi
        # 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 the service if
it
        ## is running.

        echo -n "Reload service cherokee "
        ## if it supports it:
        killproc -HUP $CHEROKEE_BIN
        #touch /var/run/cherokee.pid
        rc_status -v

        ## Otherwise:
        #$0 try-restart
        #rc_status
        ;;
    reload)
        ## Like force-reload, but if daemon does not support
        ## signaling, do nothing (!)

        # If it supports signaling:
        echo -n "Reload service cherokee "
        killproc -HUP $CHEROKEE_BIN
        #touch /var/run/cherokee.pid
        rc_status -v

        ## Otherwise if it does not support reload:
        #rc_failed 3
        #rc_status -v
        ;;
    status)
        echo -n "Checking for service cherokee "
        ## 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 $CHEROKEE_BIN
        # NOTE: rc_status knows that we called this init
script with
        # "status" option and adapts its messages
accordingly.
        rc_status -v
        ;;
    probe)
        ## Optional: Probe for the necessity of a reload,
print out the
        ## argument to this init script which is required
for a reload.
        ## Note: probe is not (yet) part of LSB (as of 1.9)

        test /etc/cherokee/cherokee.conf -nt
/var/run/cherokee.pid && echo 
reload
        ;;
    *)
        echo "Usage: $0
{start|stop|status|try-restart|restart|force-reload|
reload|probe}"
        exit 1
        ;;
esac
rc_exit
                                                      
                                                            
                                                            
                                                            
                                     
                                                            
         
And here you are:
[manuArbusto Desktop]$ sh cherokee.init start
Starting cherokee
[rootArbusto ~]# sh /home/manu/cherokee/cherokee.init
start
Starting cherokee 
[rootArbusto ~]#
[rootArbusto ~]# netstat -putan | grep -i cherokee
tcp        0      0 0.0.0.0:80                  0.0.0.0            
      
LISTEN      7530/cherokee       
[rootArbusto ~]# 

Kind regards
-- 
Manuel Arostegui Ramirez.

Electronic Mail is not secure, may not be read every day,
and should not
be used for urgent or sensitive issues.
_______________________________________________
Cherokee mailing list
Cherokee0x50.org
http://www.0x50.org/cgi-bin/mailman/listinfo/cherokee
cherokee init script FEDORA COMPLIANT
user name
2006-10-06 22:13:59
Of course... how could I forget SuSe init Scripts...but...

# Read http://www.tldp.org/HOWTO/HighQuality-Apps-HOWTO/ if you prefer not
# to use this template.

...the one you show me is for SUSE based systems, (althought) works fine for Fedora, Red Hat, and SuSe based systems. My aproach is fresh and ligth as the Web server, and I'm JUST asking to make a contrib/cherokee.fedora or similar on the next release.

Kind Regards... 

2006/10/6, Manuel Arostegui Ramirez < manueltodo-linux.com">manueltodo-linux.com>:
El Viernes, 6 de Octubre de 2006 23:53, Carlitux escribió:
> Hello Alvaro.
&gt;
> Just my first time testing the cherokee web server, and I found a TRIVIAL
&gt; bug on the init script.I'm using Fedora Core 5 on a x86_64 based system and
> wanted to start cherokee on startup, so I followed trying some steps:
>;
> FC (and any RH-based distro) doesn't have the update-rc.d script; instead,
&gt; they have chkconfig. So, I created the link on /etc/rc.d and tried to
> enable cherokee on chkconfig, but it failed,
&gt;
> I build the last 0.5.5 tarball source, and all goes very good, so I went to
> copy de contrib/cherokee init script to my /etc/init.d/ directory and for
> make a link to the especial init scripts on /etc/rc[x].d, I use the redhat
>; chkconfig util,
>
> [rootlocalhost init.d]# chkconfig --add cherokee
&gt; service cherokee does not support chkconfig
>
> but I realize that the special line for chkconfig wasn't there, and all the
> things I need for cherokee to start on my Fedora 5 x86_64 based system,
&gt; (ANGEL OF GOODNESS come to me and inspire me), so I made some investigation
> of your DAEMON and the arguments, to finally wrote a contrib REDHAT FEDORA
>; compliant cherokee init script for all the folks who have problems with the
> init so this is the new contrib/cherokee.server.fedora compliant:
>
> ******************************************************************
> #!/bin/sh
> #
> # Contrib to RedHat Fedora Based Systems by: carlotezgmail.com">carlotezgmail.com
> # chkconfig: 2345 95 05
> # description: Starts and stops the Cherokee ligth Web Server system
>; #
>
>; # Source function library
&gt; . /etc/rc.d/init.d/functions
>
> NAME=cherokee
> BASE=/usr/local/cherokee/sbin/$NAME
> DAEMON=&quot;-b"
> CONF=";/etc/cherokee/cherokee.conf";
> PIDFILE=&quot;/var/run/$NAME.pid"
>
> # Check that $BASE exists.
&gt; [ -f $BASE ] || exit 0
>
>; # Source networking configuration.
> . /etc/sysconfig/network
>
> # Check that networking is up.
> [ ${NETWORKING} = "no&quot; ] && exit 0
>
&gt; RETVAL=0
&gt; # See how we were called.
&gt; case "$1&quot; in
>&nbsp;  start)
>; &nbsp; &nbsp; &nbsp; &nbsp; if [ -n "`/sbin/pidof $NAME`&quot; ]; then
>&nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ;  echo -n $"$NAME: already running&quot;
>&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   echo "&quot;
>&nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; exit $RETVAL
&gt; &nbsp; &nbsp; &nbsp;   fi
>&nbsp; &nbsp; &nbsp;   ; echo -n "Starting Cherokee service: "
>; &nbsp; &nbsp; &nbsp; &nbsp; $BASE -C $CONF $DAEMON pidfile $PIDFILE
> &nbsp;   ; &nbsp;  sleep 1
>&nbsp; &nbsp; &nbsp; &nbsp;  action "&quot; /sbin/pidof $NAME
>  ; &nbsp; &nbsp; &nbsp; RETVAL=$?
> &nbsp;   ; &nbsp;  [ $RETVAL -eq 0 ] && touch /var/lock/subsys/cherokee
>&nbsp; &nbsp;   ; &nbsp; ;;
>&nbsp;  stop)
>  ; &nbsp; &nbsp; &nbsp; echo -n "Shutting down Cherokee service: "
&gt; &nbsp; &nbsp; &nbsp;   killproc $BASE
>  ; &nbsp; &nbsp; &nbsp; RETVAL=$?
> &nbsp;   ; &nbsp;  echo
>&nbsp;   ; &nbsp; &nbsp; [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/cherokee
>&nbsp; &nbsp;   ; &nbsp; ;;
>&nbsp;  restart|reload)
>&nbsp;   ; &nbsp; &nbsp; $0 stop
>  ; &nbsp; &nbsp; &nbsp; $0 start
>  ; &nbsp; &nbsp; &nbsp; RETVAL=$?
> &nbsp;   ; &nbsp;  ;;
>&nbsp;  status)
&gt; &nbsp; &nbsp; &nbsp;   status $BASE
>  ; &nbsp; &nbsp; &nbsp; RETVAL=$?
> &nbsp;   ; &nbsp;  ;;
>&nbsp;  *)
>&nbsp; &nbsp; &nbsp;   ; echo "Usage: $NAME {start|stop|restart|reload|status}"
&gt; &nbsp; &nbsp;   ;  exit 1
> esac
>
> exit $RETVAL
&gt;
> ******************************************************************
>
> Now everything is fine:
>
> [rootlocalhost init.d]# chkconfig --add cherokee
&gt;
> [rootlocalhost init.d]# chkconfig cherokee on
> [rootlocalhost init.d]# service cherokee start
> Starting cherokee ...
>
&gt; I could provide a patch, but I don't know how to send the initial script is
> generated. So, long story short, this issue requires many changes
&gt;
> Thats all Budy !!!
> The Cherokee Server just fine on my Fedora 5 x86_64 based system
>; I hope you can made the changes to that script, or at least, made one
> called contrib/cherokee.server.fedora with this contrib.
&gt;
> I forgot to tell, I'm a former teacher of operating systems at my
> university, and the shell programing is a base of that, so I came up with
> this thing.
>;
> Regards,

Ummmmmmmm, that seems to work fine, of course.
I'm afraid that there's already one start script for cherokee, which is
skeleton-based, here it is:

#!/bin/sh
#
#&nbsp; &nbsp;  Fedora Linux init script for cherokee webserver, by Manuel Arostegui
#Ramirez, original cherokee.init for Suse by:

#&nbsp; &nbsp;  Marcus Rueckert, SUSE / Novell Inc.
#&nbsp; &nbsp;  Copyright (C) 2006 Marcus Rueckert, SUSE / Novell Inc.
#
#&nbsp;   ; This init script has the same license as the cherokee package itself.
#
# /etc/init.d/cherokee
# &nbsp; and its symbolic link
# /(usr/)sbin/rccherokee
#
# LSB compatible service control script; see http://www.linuxbase.org/spec/
# Please send feedback to http://www.suse.de/feedback/
#
# Note: This template uses functions rc_XXX defined in /etc/rc.status on
# UnitedLinux/SUSE/Novell based Linux distributions. However, it will work
# on other distributions as well, by using the LSB (Linux Standard Base)
# or RH functions or by open coding the needed functions.
# Read http://www.tldp.org/HOWTO/HighQuality-Apps-HOWTO/ if you prefer not
# to use this template.
#
# chkconfig: 345 99 00
# description: FOO XYZ daemon providing ZYX
#
### BEGIN INIT INFO
# Provides:&nbsp;   ; &nbsp; &nbsp; &nbsp;cherokee
# Required-Start:   ; $syslog $remote_fs
# Should-Start: $time ypbind sendmail
# Required-Stop: &nbsp;   $syslog $remote_fs
# Should-Stop: $time ypbind sendmail
# Default-Start: &nbsp;   3 5
# Default-Stop: &nbsp; &nbsp;  0 1 2 6
# Short-Description: cherokee is a fast webserver
# Description: &nbsp; &nbsp; &nbsp; cherokee is a fast webserver
### END INIT INFO
#
# Any extensions to the keywords given above should be preceeded by
# X-VendorTag- (X-UnitedLinux- X-SuSE- for us) according to LSB.
#
# Notes on Required-Start/Should-Start:
# * There are two different issues that are solved by Required-Start
; &nbsp; and Should-Start
# (a) Hard dependencies: This is used by the runlevel editor to determine
# &nbsp; &nbsp; which services absolutely need to be started to make the start of
  ;  this service make sense. Example: nfsserver should have
#&nbsp; &nbsp;  Required-Start: $portmap
#  ; &nbsp; Also, required services are started before the dependent ones.
#&nbsp; &nbsp;  The runlevel editor will warn about such missing hard dependencies
# &nbsp;   and suggest enabling. During system startup, you may expect an error,
#&nbsp; &nbsp;  if the dependency is not fulfilled.
# (b) Specifying the init script ordering, not real (hard) dependencies.
; &nbsp;  This is needed by insserv to determine which service should be
  ;  started first (and at a later stage what services can be started
#&nbsp;   ; in parallel). The tag Should-Start: is used for this.
#&nbsp; &nbsp;  It tells, that if a service is available, it should be started
#  ; &nbsp; before. If not, never mind.
# * When specifying hard dependencies or ordering requirements, you can
;  use names of services (contents of their Provides: section)
#  ; or pseudo names starting with a $. The following ones are available
# &nbsp; according to LSB (1.1):
#&nbsp; &nbsp;   ; $local_fs&nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   all local file systems are mounted
#&nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; (most services should need this!)
#&nbsp; &nbsp;   ; $remote_fs  ; &nbsp; &nbsp; &nbsp; &nbsp;   ; all remote file systems are mounted
#  ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; (note that /usr may be remote, so
  ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; many services should Require this!)
#&nbsp; &nbsp;   ; $syslog&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp; system logging facility up
  ; &nbsp;  $network&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;  low level networking (eth card, ...)
#&nbsp; &nbsp; &nbsp;  $named&nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;hostname resolution available
# &nbsp; &nbsp; &nbsp; $netdaemons &nbsp; &nbsp; &nbsp; &nbsp;   ;  all network daemons are running
#&nbsp;  The $netdaemons pseudo service has been removed in LSB 1.2.
#&nbsp;  For now, we still offer it for backward compatibility.
#&nbsp;  These are new (LSB 1.2):
#&nbsp; &nbsp; &nbsp;  $time ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; the system time has been set correctly
# &nbsp; &nbsp; &nbsp; $portmap&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;  SunRPC portmapping service available
# &nbsp; UnitedLinux/SUSE/Novell extensions:
# &nbsp;   ;  $ALL   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp;indicates that a script should be inserted
#  ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; at the end
# * The services specified in the stop tags
#&nbsp;  (Required-Stop/Should-Stop)
#&nbsp;  specify which services need to be still running when this service
#  ; is shut down. Often the entries there are just copies or a subset
#&nbsp;  from the respective start tag.
# * Should-Start/Stop are now part of LSB as of 2.0,
#&nbsp;  formerly SUSE/Unitedlinux used X-UnitedLinux-Should-Start/-Stop.
# &nbsp; insserv does support both variants.
# * X-UnitedLinux-Default-Enabled: yes/no is used at installation time
#&nbsp;  (%fillup_and_insserv macro in %post of many RPMs) to specify whether
#&nbsp;  a startup script should default to be enabled after installation.
;  It's not used by insserv.
#
# Note on runlevels:
# 0 - halt/poweroff &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; 6 - reboot
# 1 - single user   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp; 2 - multiuser without network exported
# 3 - multiuser w/ network (text mode) ; 5 - multiuser w/ network and X11 (xdm)
#
# Note on script names:
# http://www.linuxbase.org/spec/refspecs/LSB_1.3.0/gLSB/gLSB/scrptnames.html
# A registry has been set up to manage the init script namespace.
# http://www.lanana.org/
# Please use the names already registered or register one or use a
# vendor prefix.


# Check for missing binaries (stale symlinks should not happen)
# Note: Special treatment of stop for LSB conformance
CHEROKEE_BIN=/usr/sbin/cherokee
test -x $CHEROKEE_BIN || { echo "$CHEROKEE_BIN not installed&quot;;
&nbsp; &nbsp; &nbsp; &nbsp; if [ "$1&quot; = "stop" ]; then exit 0;
   ; &nbsp; &nbsp; &nbsp;  else exit 5; fi; }

# Check for existence of needed config file and read it
# CHEROKEE_CONFIG=/etc/sysconfig/cherokee
# test -r $CHEROKEE_CONFIG || { echo "$CHEROKEE_CONFIG not existing&quot;;
#&nbsp; &nbsp; &nbsp;  if [ "$1&quot; = "stop" ]; then exit 0;
  ; &nbsp;  else exit 6; fi; }

# Read config
# . $CHEROKEE_CONFIG

# Source LSB init functions
# providing start_daemon, killproc, pidofproc,
# log_success_msg, log_failure_msg and log_warning_msg.
# This is currently not used by UnitedLinux based distributions and
# not needed for init scripts for UnitedLinux only. If it is used,
# the functions from rc.status should not be sourced or used.
#. /lib/lsb/init-functions

# Shell functions sourced from /etc/rc.status:
#&nbsp; &nbsp; &nbsp; rc_check&nbsp; &nbsp; &nbsp; &nbsp;  check and set local and overall rc status
#&nbsp; &nbsp;   ;rc_status&nbsp;   ; &nbsp; &nbsp;check and set local and overall rc status
#&nbsp;   ; &nbsp;rc_status -v &nbsp; &nbsp; be verbose in local rc status and clear it afterwards
# &nbsp; &nbsp; &nbsp;rc_status -v -r &nbsp;ditto and clear both the local and overall rc status
#&nbsp; &nbsp;   ;rc_status -s &nbsp; &nbsp; display "skipped" and exit with status 3
  ; &nbsp; rc_status -u &nbsp; &nbsp; display "unused" and exit with status 3
# &nbsp;   ; rc_failed   ; &nbsp; &nbsp; set local and overall rc status to failed
#&nbsp; &nbsp;   ;rc_failed <num>; &nbsp;set local and overall rc status to <num>;
# &nbsp;   ; rc_reset &nbsp;   ; &nbsp;  clear both the local and overall rc status
#&nbsp; &nbsp;   ;rc_exit&nbsp; &nbsp; &nbsp;   ; &nbsp;exit appropriate to overall rc status
#&nbsp; &nbsp;   ;rc_active&nbsp;   ; &nbsp; &nbsp;checks whether a service is activated by symlinks

# Use the SUSE rc_ init script functions;
# emulate them on LSB, RH and other systems

# Default: Assume sysvinit binaries exist
if test -e /etc/rc.status; then
 ; &nbsp; # SUSE rc script library
&nbsp; &nbsp; . /etc/rc.status
else
&nbsp;   ;export LC_ALL=POSIX
 &nbsp;  start_daemon() { return /sbin/start_daemon ${1+"$"}; }
 &nbsp; &nbsp;killproc() &nbsp;   { return /sbin/killproc &nbsp;   ${1+"$"}; }
 &nbsp; &nbsp;pidofproc()   ; { return /sbin/pidofproc   ; ${1+"$"}; }
 &nbsp;  checkproc() ; &nbsp; { return /sbin/checkproc   ; ${1+"$"}; }
 &nbsp; &nbsp;_cmd=$1
 &nbsp; &nbsp;declare -a _SMSG
&nbsp; &nbsp; if test "${_cmd}" = "status"; then
 ; &nbsp; &nbsp; &nbsp; _SMSG=(running dead dead unused unknown reserved)
 &nbsp; &nbsp; &nbsp; &nbsp;_RC_UNUSED=3
&nbsp; &nbsp; else
 &nbsp; &nbsp;   ; _SMSG=(done failed failed missed failed skipped unused failed failed
reserved)
&nbsp; &nbsp; &nbsp; &nbsp; _RC_UNUSED=6
 &nbsp; &nbsp;fi
&nbsp; &nbsp;  if test -e /lib/lsb/init-functions; then
 ; &nbsp; &nbsp; &nbsp; # LSB
 ; &nbsp; &nbsp; &nbsp; . /lib/lsb/init-functions
 &nbsp; &nbsp;   ; echo_rc()
 ; &nbsp; &nbsp; &nbsp; {
 &nbsp; &nbsp; &nbsp; &nbsp;   ; if test $ = 0; then
 ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;log_success_msg "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;else
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;log_failure_msg "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp;fi
&nbsp; &nbsp; &nbsp; &nbsp; }
 &nbsp; &nbsp; &nbsp;  # TODO: Add checking for lockfiles
  ; &nbsp; &nbsp; &nbsp;checkproc() { return pidofproc ${1+"$"} >/dev/null 2>&1; }
 &nbsp; &nbsp;elif test -e /etc/init.d/functions; then
 ; &nbsp; &nbsp; &nbsp; # RHAT
&nbsp; &nbsp; &nbsp; &nbsp; . /etc/init.d/functions
 &nbsp; &nbsp; &nbsp; &nbsp;echo_rc()
 &nbsp;   ; &nbsp; {
&nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;#echo -n "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;if test $ = 0; then
 ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;success "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp;else
&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;  failure "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;fi
 ; &nbsp; &nbsp; &nbsp; }
 &nbsp; &nbsp; &nbsp; &nbsp;checkproc() { return status ${1+"$"}; }
 &nbsp; &nbsp;   ; start_daemon() { return daemon ${1+"$"}; }
 &nbsp;  else
  ; &nbsp; &nbsp; &nbsp;# emulate it
 &nbsp;   ; &nbsp; echo_rc() { echo "&nbsp; [${_SMSG[${_RC_RV}]}] "; }
 &nbsp; &nbsp;fi
&nbsp; &nbsp; rc_reset() { _RC_RV=0; }
 &nbsp; &nbsp;rc_failed()
 ; &nbsp; {
&nbsp;   ; &nbsp; &nbsp;if test -z "$1&quot;; then
&nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp;_RC_RV=1;
 &nbsp; &nbsp; &nbsp; &nbsp;elif test "$1&quot; != "0&quot;; then
 ; &nbsp; &nbsp; &nbsp; &nbsp;   ;_RC_RV=$1;
 &nbsp; &nbsp; &nbsp; &nbsp;fi
&nbsp; &nbsp; &nbsp;   ;return $
  ; &nbsp;}
 &nbsp;  rc_check()
 ; &nbsp; {
&nbsp;   ; &nbsp; &nbsp;return rc_failed $?
 &nbsp;  }
&nbsp; &nbsp; rc_status()
 &nbsp; &nbsp;{
   ; &nbsp; &nbsp; rc_failed $?
 &nbsp;   ; &nbsp; if test "$1&quot; = "-r&quot;; then _RC_RV=0; shift; fi
 &nbsp;   ; &nbsp; if test "$1&quot; = "-s&quot;; then rc_failed 5; echo_rc; rc_failed 3; shift; fi
   ; &nbsp; &nbsp; if test "$1&quot; = "-u&quot;; then rc_failed ${_RC_UNUSED}; echo_rc; rc_failed
3; shift; fi
 &nbsp;   ; &nbsp; if test "$1&quot; = "-v&quot;; then echo_rc; shift; fi
 &nbsp;   ; &nbsp; if test "$1&quot; = "-r&quot;; then _RC_RV=0; shift; fi
   ; &nbsp; &nbsp; return $
  ; &nbsp;}
 &nbsp;  rc_exit() { exit $; }
 &nbsp; &nbsp;rc_active()
 ; &nbsp; {
&nbsp;   ; &nbsp; &nbsp;#if test -z "$RUNLEVEL"; then read RUNLEVEL REST < <(/sbin/runlevel);
fi
 &nbsp;   ; &nbsp; if test -e /etc/init.d/S[0-9][0-9]$; then return 0; fi
   ; &nbsp; &nbsp; return 1
 &nbsp; &nbsp;}
fi

# Reset status of this service
rc_reset

# Return values acc. to LSB for all commands but status:
# 0 &nbsp; &nbsp; &nbsp; - success
# 1 &nbsp; &nbsp; &nbsp; - generic or unspecified error
# 2 &nbsp; &nbsp; &nbsp; - invalid or excess argument(s)
# 3 &nbsp; &nbsp; &nbsp; - unimplemented feature (e.g. "reload")
# 4 &nbsp; &nbsp; &nbsp; - user had insufficient privileges
# 5 &nbsp; &nbsp; &nbsp; - program is not installed
# 6 &nbsp; &nbsp; &nbsp; - program is not configured
# 7 &nbsp; &nbsp; &nbsp; - program is not running
# 8--199&nbsp; - reserved (8--99 LSB, 100--149 distrib, 150--199 appl)
#
# Note that starting an already running service, stopping
# or restarting a not-running service as well as the restart
# with force-reload (in case signaling is not supported) are
# considered a success.

case "$1&quot; in
 &nbsp;  start)
 &nbsp; &nbsp; &nbsp;  echo -n "Starting cherokee "
&nbsp; &nbsp; &nbsp;   ;## Start daemon with startproc(8). If this fails
&nbsp; &nbsp; &nbsp; &nbsp; ## the return value is set appropriately by startproc.
 &nbsp; &nbsp; &nbsp;  start_daemon $CHEROKEE_BIN -b

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

&nbsp; &nbsp; &nbsp; &nbsp; killproc -TERM $CHEROKEE_BIN

   ; &nbsp; &nbsp; # Remember status and be verbose
&nbsp; &nbsp;   ; &nbsp;rc_status -v
 &nbsp;   ; &nbsp; ;;
  ; &nbsp;try-restart|condrestart)
 ; &nbsp; &nbsp; &nbsp; ## Do a restart only if the service was active before.
&nbsp; &nbsp;   ; &nbsp;## Note: try-restart is now part of LSB (as of 1.9).
&nbsp; &nbsp; &nbsp; &nbsp; ## RH has a similar command named condrestart.
 &nbsp; &nbsp;   ; if test "$1&quot; = "condrestart&quot;; then
&nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp;echo "${attn} Use try-restart $(LSB)$ rather than
condrestart $(RH)$&quot;
fi
 &nbsp;   ; &nbsp; $0 status
&nbsp; &nbsp; &nbsp;   ;if test $? = 0; then
 ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;$0 restart
&nbsp; &nbsp;   ; &nbsp;else
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;rc_reset &nbsp; &nbsp; &nbsp;  # Not running is not a failure.
&nbsp;   ; &nbsp; &nbsp;fi
 ; &nbsp; &nbsp; &nbsp; # Remember status and be quiet
&nbsp; &nbsp; &nbsp; &nbsp; rc_status
&nbsp;   ; &nbsp; &nbsp;;;
 ; &nbsp; restart)
 ; &nbsp; &nbsp; &nbsp; ## Stop the service and regardless of whether it was
 ; &nbsp; &nbsp; &nbsp; ## running or not, start it again.
&nbsp; &nbsp; &nbsp;   ;$0 stop
 ; &nbsp; &nbsp; &nbsp; $0 start

&nbsp; &nbsp; &nbsp;   ;# Remember status and be quiet
&nbsp; &nbsp; &nbsp; &nbsp; rc_status
&nbsp;   ; &nbsp; &nbsp;;;
 ; &nbsp; force-reload)
  ; &nbsp; &nbsp; &nbsp;## Signal the daemon to reload its config. Most daemons
&nbsp;   ; &nbsp; &nbsp;## do this on signal 1 (SIGHUP).
  ; &nbsp; &nbsp; &nbsp;## If it does not support it, restart the service if it
 &nbsp;   ; &nbsp; ## is running.

  ; &nbsp; &nbsp; &nbsp;echo -n "Reload service cherokee "
&nbsp; &nbsp; &nbsp;   ;## if it supports it:
 ; &nbsp; &nbsp; &nbsp; killproc -HUP $CHEROKEE_BIN
 &nbsp;   ; &nbsp; #touch /var/run/cherokee.pid
 &nbsp; &nbsp; &nbsp; &nbsp;rc_status -v

   ; &nbsp; &nbsp; ## Otherwise:
 &nbsp; &nbsp; &nbsp; &nbsp;#$0 try-restart
 &nbsp; &nbsp; &nbsp;  #rc_status
 ; &nbsp; &nbsp; &nbsp; ;;
 &nbsp; &nbsp;reload)
 &nbsp; &nbsp; &nbsp; &nbsp;## Like force-reload, but if daemon does not support
&nbsp;   ; &nbsp; &nbsp;## signaling, do nothing (!)

 ; &nbsp; &nbsp; &nbsp; # If it supports signaling:
 &nbsp; &nbsp; &nbsp; &nbsp;echo -n "Reload service cherokee "
&nbsp; &nbsp; &nbsp;   ;killproc -HUP $CHEROKEE_BIN
 &nbsp;   ; &nbsp; #touch /var/run/cherokee.pid
 &nbsp; &nbsp; &nbsp;  rc_status -v

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

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

&nbsp;   ; &nbsp; &nbsp;# NOTE: checkproc returns LSB compliant status values.
&nbsp; &nbsp;   ; &nbsp;checkproc $CHEROKEE_BIN
 &nbsp;   ; &nbsp; # NOTE: rc_status knows that we called this init script with
 ; &nbsp; &nbsp; &nbsp; # "status" option and adapts its messages accordingly.
 &nbsp;   ; &nbsp; rc_status -v
 &nbsp;   ; &nbsp; ;;
  ; &nbsp;probe)
&nbsp; &nbsp;   ; &nbsp;## Optional: Probe for the necessity of a reload, print out the
   ; &nbsp; &nbsp; ## argument to this init script which is required for a reload.
&nbsp; &nbsp;   ; &nbsp;## Note: probe is not (yet) part of LSB (as of 1.9)

&nbsp; &nbsp; &nbsp;   ;test /etc/cherokee/cherokee.conf -nt /var/run/cherokee.pid && echo
reload
 &nbsp; &nbsp; &nbsp;  ;;
&nbsp; &nbsp; *)
 &nbsp; &nbsp;   ; echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|
reload|probe}"
&nbsp; &nbsp;   ; &nbsp;exit 1
 &nbsp; &nbsp;   ; ;;
esac
rc_exit



And here you are:
[manuArbusto Desktop]$ sh cherokee.init start
Starting cherokee
[rootArbusto ~]# sh /home/manu/cherokee/cherokee.init start
Starting cherokee
[rootArbusto ~]#
[rootArbusto ~]# netstat -putan | grep -i cherokee
tcp &nbsp; &nbsp; &nbsp;  0&nbsp; &nbsp; &nbsp; 0 0.0.0.0:80 &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; 0.0.0.0
LISTEN&nbsp; &nbsp; &nbsp; 7530/cherokee
[rootArbusto ~]#

Kind regards
--
Manuel Arostegui Ramirez.

Electronic Mail is not secure, may not be read every day, and should not
be used for urgent or sensitive issues.
_______________________________________________
Cherokee mailing list
Cherokee0x50.org">Cherokee0x50.org
http://www.0x50.org/cgi-bin/mailman/listinfo/cherokee



--
---
Carlitux
Blog Personal: http://carlotez.blogspot.com/
&quot;May the source be with you...&quot;
"In a World without walls and fences who needs WINDOWS and GATES?&quot;
http://counter.li.org/cgi-bin/certificate.cgi/409534

---
Ing. Carlos Alcalá Helguero
Administrador Encargado de Laboratorios de Computo
Universidad Catolica Boliviana "San Pablo";
Phone:&nbsp; (591)+4249234
Office: (591)+4293100 - Int. 247
Cel:&nbsp; &nbsp; 72735250
Cochabamba - Bolivia


GPG Key:
https://166.114.106.12/~carlotez/key.gpg.asc
pub&nbsp; 1024D/CD98DB19 2006-06-02 Ing. Carlos Javier Alcala Helguero (Administrador de Laboratorios y Servidores) < carlotezgmail.com">carlotezgmail.com >
GPG Fingerprint = BC12 864C 3A3E 9D09 8533  6B7A D3C2 EE1A CD98 DB19
cherokee init script FEDORA COMPLIANT
user name
2006-10-06 22:25:16
El Sábado, 7 de Octubre de 2006 00:13, escribió:
> Of course... how could I forget SuSe init
Scripts...but...
>
> # Read htt
p://www.tldp.org/HOWTO/HighQuality-Apps-HOWTO/ if you
prefer not
> # to use this template.
>
> ...the one you show me is for SUSE based systems,
(althought) works fine
> for Fedora, Red Hat, and SuSe based systems. My aproach
is fresh and ligth
> as the Web server, and I'm JUST asking to make a
contrib/cherokee.fedora or
> similar on the next release.
>

As you want.... not flame, it's too late here 

-- 
Manuel Arostegui Ramirez.

Electronic Mail is not secure, may not be read every day,
and should not
be used for urgent or sensitive issues.
_______________________________________________
Cherokee mailing list
Cherokee0x50.org
http://www.0x50.org/cgi-bin/mailman/listinfo/cherokee
cherokee init script FEDORA COMPLIANT
user name
2006-10-06 22:18:37
El Sábado, 7 de Octubre de 2006 00:13, escribió:
> Of course... how could I forget SuSe init
Scripts...but...
>
> # Read htt
p://www.tldp.org/HOWTO/HighQuality-Apps-HOWTO/ if you
prefer not
> # to use this template.
>
> ...the one you show me is for SUSE based systems,
(althought) works fine
> for Fedora, Red Hat, and SuSe based systems. My aproach
is fresh and ligth
> as the Web server, and I'm JUST asking to make a
contrib/cherokee.fedora or
> similar on the next release.
>

As you want.... not flame, it's too late here 

-- 
Manuel Arostegui Ramirez.

Electronic Mail is not secure, may not be read every day,
and should not
be used for urgent or sensitive issues.
_______________________________________________
Cherokee mailing list
Cherokee0x50.org
http://www.0x50.org/cgi-bin/mailman/listinfo/cherokee
cherokee init script FEDORA COMPLIANT
user name
2006-10-06 22:17:45
Why is the http://www.0x50.org/bugs/newticket#preview

show: 500 Internal Server Error

how could I send test bugs to the system ¿?

--Carlitux

2006/10/6, Carlitux < carlotezgmail.com">carlotezgmail.com>:
Of course... how could I forget SuSe init Scripts...but...

# Read http://www.tldp.org/HOWTO/HighQuality-Apps-HOWTO/ if you prefer not
# to use this template.

...the one you show me is for SUSE based systems, (althought) works fine for Fedora, Red Hat, and SuSe based systems. My aproach is fresh and ligth as the Web server, and I'm JUST asking to make a contrib/cherokee.fedora or similar on the next release.

Kind Regards... 

2006/10/6, Manuel Arostegui Ramirez < manueltodo-linux.com" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)"> manueltodo-linux.com>:
El Viernes, 6 de Octubre de 2006 23:53, Carlitux escribió:
> Hello Alvaro.
&gt;
> Just my first time testing the cherokee web server, and I found a TRIVIAL
&gt; bug on the init script.I'm using Fedora Core 5 on a x86_64 based system and
> wanted to start cherokee on startup, so I followed trying some steps:
>;
> FC (and any RH-based distro) doesn't have the update-rc.d script; instead,
&gt; they have chkconfig. So, I created the link on /etc/rc.d and tried to
> enable cherokee on chkconfig, but it failed,
&gt;
> I build the last 0.5.5 tarball source, and all goes very good, so I went to
> copy de contrib/cherokee init script to my /etc/init.d/ directory and for
> make a link to the especial init scripts on /etc/rc[x].d, I use the redhat
>; chkconfig util,
>
> [rootlocalhost init.d]# chkconfig --add cherokee
&gt; service cherokee does not support chkconfig
>
> but I realize that the special line for chkconfig wasn't there, and all the
> things I need for cherokee to start on my Fedora 5 x86_64 based system,
&gt; (ANGEL OF GOODNESS come to me and inspire me), so I made some investigation
> of your DAEMON and the arguments, to finally wrote a contrib REDHAT FEDORA
>; compliant cherokee init script for all the folks who have problems with the
> init so this is the new contrib/cherokee.server.fedora compliant:
>
> ******************************************************************
> #!/bin/sh
> #
> # Contrib to RedHat Fedora Based Systems by: carlotezgmail.com" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)"> carlotezgmail.com
> # chkconfig: 2345 95 05
> # description: Starts and stops the Cherokee ligth Web Server system
>; #
>
>; # Source function library
&gt; . /etc/rc.d/init.d/functions
>
> NAME=cherokee
> BASE=/usr/local/cherokee/sbin/$NAME
> DAEMON=&quot;-b"
> CONF=";/etc/cherokee/cherokee.conf";
> PIDFILE=&quot;/var/run/$NAME.pid"
>
> # Check that $BASE exists.
> [ -f $BASE ] || exit 0
>
>; # Source networking configuration.
> . /etc/sysconfig/network
>
> # Check that networking is up.
> [ ${NETWORKING} = "no&quot; ] && exit 0
>
&gt; RETVAL=0
&gt; # See how we were called.
&gt; case "$1&quot; in
>&nbsp;  start)
>; &nbsp; &nbsp; &nbsp; &nbsp; if [ -n "`/sbin/pidof $NAME`&quot; ]; then
>&nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ;  echo -n $"$NAME: already running&quot;
>&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   echo "&quot;
>&nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; exit $RETVAL
&gt; &nbsp; &nbsp; &nbsp;   fi
>&nbsp; &nbsp; &nbsp;   ; echo -n "Starting Cherokee service: "
>; &nbsp; &nbsp; &nbsp; &nbsp; $BASE -C $CONF $DAEMON pidfile $PIDFILE
  ; &nbsp; &nbsp;  sleep 1
>&nbsp; &nbsp; &nbsp; &nbsp;  action "&quot; /sbin/pidof $NAME
>  ; &nbsp; &nbsp; &nbsp; RETVAL=$?
> &nbsp;   ; &nbsp;  [ $RETVAL -eq 0 ] && touch /var/lock/subsys/cherokee
>&nbsp; &nbsp;   ; &nbsp; ;;
>&nbsp;  stop)
>  ; &nbsp; &nbsp; &nbsp; echo -n "Shutting down Cherokee service: "
&gt; &nbsp; &nbsp; &nbsp;   killproc $BASE
>  ; &nbsp; &nbsp; &nbsp; RETVAL=$?
> &nbsp;   ; &nbsp;  echo
>&nbsp;   ; &nbsp; &nbsp; [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/cherokee
>&nbsp; &nbsp;   ; &nbsp; ;;
>&nbsp;  restart|reload)
>&nbsp;   ; &nbsp; &nbsp; $0 stop
>  ; &nbsp; &nbsp; &nbsp; $0 start
>  ; &nbsp; &nbsp; &nbsp; RETVAL=$?
> &nbsp;   ; &nbsp;  ;;
>&nbsp;  status)
&gt; &nbsp; &nbsp; &nbsp;   status $BASE
>  ; &nbsp; &nbsp; &nbsp; RETVAL=$?
> &nbsp;   ; &nbsp;  ;;
>&nbsp;  *)
>&nbsp; &nbsp; &nbsp;   ; echo "Usage: $NAME {start|stop|restart|reload|status}"
&gt; &nbsp; &nbsp;   ;  exit 1
> esac
>
> exit $RETVAL
&gt;
> ******************************************************************
>
> Now everything is fine:
>
> [rootlocalhost init.d]# chkconfig --add cherokee
&gt;
> [rootlocalhost init.d]# chkconfig cherokee on
> [rootlocalhost init.d]# service cherokee start
> Starting cherokee ...
>
&gt; I could provide a patch, but I don't know how to send the initial script is
> generated. So, long story short, this issue requires many changes
&gt;
> Thats all Budy !!!
> The Cherokee Server just fine on my Fedora 5 x86_64 based system
>; I hope you can made the changes to that script, or at least, made one
> called contrib/cherokee.server.fedora with this contrib.
&gt;
> I forgot to tell, I'm a former teacher of operating systems at my
> university, and the shell programing is a base of that, so I came up with
> this thing.
>;
> Regards,

Ummmmmmmm, that seems to work fine, of course.
I'm afraid that there's already one start script for cherokee, which is
skeleton-based, here it is:

#!/bin/sh
#
#&nbsp; &nbsp;  Fedora Linux init script for cherokee webserver, by Manuel Arostegui
#Ramirez, original cherokee.init for Suse by:

#&nbsp; &nbsp;  Marcus Rueckert, SUSE / Novell Inc.
#&nbsp; &nbsp;  Copyright (C) 2006 Marcus Rueckert, SUSE / Novell Inc.
#
#&nbsp;   ; This init script has the same license as the cherokee package itself.
#
# /etc/init.d/cherokee
# &nbsp; and its symbolic link
# /(usr/)sbin/rccherokee
#
# LSB compatible service control script; see http://www.linuxbase.org/spec/
# Please send feedback to http://www.suse.de/feedback/
#
# Note: This template uses functions rc_XXX defined in /etc/rc.status on
# UnitedLinux/SUSE/Novell based Linux distributions. However, it will work
# on other distributions as well, by using the LSB (Linux Standard Base)
# or RH functions or by open coding the needed functions.
# Read http://www.tldp.org/HOWTO/HighQuality-Apps-HOWTO/ if you prefer not
# to use this template.
#
# chkconfig: 345 99 00
# description: FOO XYZ daemon providing ZYX
#
### BEGIN INIT INFO
# Provides:&nbsp;   ; &nbsp; &nbsp; &nbsp;cherokee
# Required-Start:   ; $syslog $remote_fs
# Should-Start: $time ypbind sendmail
# Required-Stop: &nbsp;   $syslog $remote_fs
# Should-Stop: $time ypbind sendmail
# Default-Start: &nbsp;   3 5
# Default-Stop: &nbsp; &nbsp;  0 1 2 6
# Short-Description: cherokee is a fast webserver
# Description: &nbsp; &nbsp; &nbsp; cherokee is a fast webserver
### END INIT INFO
#
# Any extensions to the keywords given above should be preceeded by
# X-VendorTag- (X-UnitedLinux- X-SuSE- for us) according to LSB.
#
# Notes on Required-Start/Should-Start:
# * There are two different issues that are solved by Required-Start
; &nbsp; and Should-Start
# (a) Hard dependencies: This is used by the runlevel editor to determine
# &nbsp; &nbsp; which services absolutely need to be started to make the start of
  ;  this service make sense. Example: nfsserver should have
#&nbsp; &nbsp;  Required-Start: $portmap
#  ; &nbsp; Also, required services are started before the dependent ones.
#&nbsp; &nbsp;  The runlevel editor will warn about such missing hard dependencies
# &nbsp;   and suggest enabling. During system startup, you may expect an error,
#&nbsp; &nbsp;  if the dependency is not fulfilled.
# (b) Specifying the init script ordering, not real (hard) dependencies.
; &nbsp;  This is needed by insserv to determine which service should be
  ;  started first (and at a later stage what services can be started
#&nbsp;   ; in parallel). The tag Should-Start: is used for this.
#&nbsp; &nbsp;  It tells, that if a service is available, it should be started
#  ; &nbsp; before. If not, never mind.
# * When specifying hard dependencies or ordering requirements, you can
;  use names of services (contents of their Provides: section)
#  ; or pseudo names starting with a $. The following ones are available
# &nbsp; according to LSB (1.1):
#&nbsp; &nbsp;   ; $local_fs&nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   all local file systems are mounted
#&nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; (most services should need this!)
#&nbsp; &nbsp;   ; $remote_fs  ; &nbsp; &nbsp; &nbsp; &nbsp;   ; all remote file systems are mounted
#  ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; (note that /usr may be remote, so
  ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; many services should Require this!)
#&nbsp; &nbsp;   ; $syslog&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp; system logging facility up
  ; &nbsp;  $network&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;  low level networking (eth card, ...)
#&nbsp; &nbsp; &nbsp;  $named&nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;hostname resolution available
# &nbsp; &nbsp; &nbsp; $netdaemons &nbsp; &nbsp; &nbsp; &nbsp;   ;  all network daemons are running
#&nbsp;  The $netdaemons pseudo service has been removed in LSB 1.2.
#&nbsp;  For now, we still offer it for backward compatibility.
#&nbsp;  These are new (LSB 1.2):
#&nbsp; &nbsp; &nbsp;  $time ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; the system time has been set correctly
# &nbsp; &nbsp; &nbsp; $portmap&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;  SunRPC portmapping service available
# &nbsp; UnitedLinux/SUSE/Novell extensions:
# &nbsp;   ;  $ALL   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp;indicates that a script should be inserted
#  ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; at the end
# * The services specified in the stop tags
#&nbsp;  (Required-Stop/Should-Stop)
#&nbsp;  specify which services need to be still running when this service
#  ; is shut down. Often the entries there are just copies or a subset
#&nbsp;  from the respective start tag.
# * Should-Start/Stop are now part of LSB as of 2.0,
#&nbsp;  formerly SUSE/Unitedlinux used X-UnitedLinux-Should-Start/-Stop.
# &nbsp; insserv does support both variants.
# * X-UnitedLinux-Default-Enabled: yes/no is used at installation time
#&nbsp;  (%fillup_and_insserv macro in %post of many RPMs) to specify whether
#&nbsp;  a startup script should default to be enabled after installation.
;  It's not used by insserv.
#
# Note on runlevels:
# 0 - halt/poweroff &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; 6 - reboot
# 1 - single user   ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp; 2 - multiuser without network exported
# 3 - multiuser w/ network (text mode) ; 5 - multiuser w/ network and X11 (xdm)
#
# Note on script names:
# http://www.linuxbase.org/spec/refspecs/LSB_1.3.0/gLSB/gLSB/scrptnames.html
# A registry has been set up to manage the init script namespace.
# http://www.lanana.org/
# Please use the names already registered or register one or use a
# vendor prefix.


# Check for missing binaries (stale symlinks should not happen)
# Note: Special treatment of stop for LSB conformance
CHEROKEE_BIN=/usr/sbin/cherokee
test -x $CHEROKEE_BIN || { echo "$CHEROKEE_BIN not installed&quot;;
&nbsp; &nbsp; &nbsp; &nbsp; if [ "$1&quot; = "stop" ]; then exit 0;
   ; &nbsp; &nbsp; &nbsp;  else exit 5; fi; }

# Check for existence of needed config file and read it
# CHEROKEE_CONFIG=/etc/sysconfig/cherokee
# test -r $CHEROKEE_CONFIG || { echo "$CHEROKEE_CONFIG not existing&quot;;
#&nbsp; &nbsp; &nbsp;  if [ "$1&quot; = "stop" ]; then exit 0;
  ; &nbsp;  else exit 6; fi; }

# Read config
# . $CHEROKEE_CONFIG

# Source LSB init functions
# providing start_daemon, killproc, pidofproc,
# log_success_msg, log_failure_msg and log_warning_msg.
# This is currently not used by UnitedLinux based distributions and
# not needed for init scripts for UnitedLinux only. If it is used,
# the functions from rc.status should not be sourced or used.
#. /lib/lsb/init-functions

# Shell functions sourced from /etc/rc.status:
#&nbsp; &nbsp; &nbsp; rc_check&nbsp; &nbsp; &nbsp; &nbsp;  check and set local and overall rc status
#&nbsp; &nbsp;   ;rc_status&nbsp;   ; &nbsp; &nbsp;check and set local and overall rc status
#&nbsp;   ; &nbsp;rc_status -v &nbsp; &nbsp; be verbose in local rc status and clear it afterwards
# &nbsp; &nbsp; &nbsp;rc_status -v -r &nbsp;ditto and clear both the local and overall rc status
#&nbsp; &nbsp;   ;rc_status -s &nbsp; &nbsp; display "skipped" and exit with status 3
  ; &nbsp; rc_status -u &nbsp; &nbsp; display "unused" and exit with status 3
# &nbsp;   ; rc_failed   ; &nbsp; &nbsp; set local and overall rc status to failed
#&nbsp; &nbsp;   ;rc_failed <num>; &nbsp;set local and overall rc status to <num>;
# &nbsp;   ; rc_reset &nbsp;   ; &nbsp;  clear both the local and overall rc status
#&nbsp; &nbsp;   ;rc_exit&nbsp; &nbsp; &nbsp;   ; &nbsp;exit appropriate to overall rc status
#&nbsp; &nbsp;   ;rc_active&nbsp;   ; &nbsp; &nbsp;checks whether a service is activated by symlinks

# Use the SUSE rc_ init script functions;
# emulate them on LSB, RH and other systems

# Default: Assume sysvinit binaries exist
if test -e /etc/rc.status; then
 ; &nbsp; # SUSE rc script library
&nbsp; &nbsp; . /etc/rc.status
else
&nbsp;   ;export LC_ALL=POSIX
 &nbsp;  start_daemon() { return /sbin/start_daemon ${1+"$"}; }
 &nbsp; &nbsp;killproc() &nbsp;   { return /sbin/killproc &nbsp;   ${1+"$"}; }
 &nbsp; &nbsp;pidofproc()   ; { return /sbin/pidofproc   ; ${1+"$"}; }
   ; checkproc()&nbsp; &nbsp; { return /sbin/checkproc   ; ${1+"$"}; }
 &nbsp; &nbsp;_cmd=$1
 &nbsp; &nbsp;declare -a _SMSG
&nbsp; &nbsp; if test "${_cmd}" = "status"; then
 ; &nbsp; &nbsp; &nbsp; _SMSG=(running dead dead unused unknown reserved)
 &nbsp; &nbsp; &nbsp; &nbsp;_RC_UNUSED=3
&nbsp; &nbsp; else
 &nbsp; &nbsp;   ; _SMSG=(done failed failed missed failed skipped unused failed failed
reserved)
&nbsp; &nbsp; &nbsp; &nbsp; _RC_UNUSED=6
 &nbsp; &nbsp;fi
&nbsp; &nbsp;  if test -e /lib/lsb/init-functions; then
 ; &nbsp; &nbsp; &nbsp; # LSB
 ; &nbsp; &nbsp; &nbsp; . /lib/lsb/init-functions
 &nbsp; &nbsp;   ; echo_rc()
 ; &nbsp; &nbsp; &nbsp; {
 &nbsp; &nbsp; &nbsp; &nbsp;   ; if test $ = 0; then
 ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;log_success_msg "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;else
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;log_failure_msg "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp;fi
&nbsp; &nbsp; &nbsp; &nbsp; }
 &nbsp; &nbsp; &nbsp;  # TODO: Add checking for lockfiles
  ; &nbsp; &nbsp; &nbsp;checkproc() { return pidofproc ${1+"$"} >/dev/null 2>&1; }
 &nbsp; &nbsp;elif test -e /etc/init.d/functions; then
&nbsp; &nbsp; &nbsp; &nbsp; # RHAT
&nbsp; &nbsp; &nbsp; &nbsp; . /etc/init.d/functions
 &nbsp; &nbsp; &nbsp; &nbsp;echo_rc()
 &nbsp;   ; &nbsp; {
&nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;#echo -n "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;if test $ = 0; then
 ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;success "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp;else
&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;  failure "&nbsp; [${_SMSG[${_RC_RV}]}] "
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;fi
 ; &nbsp; &nbsp; &nbsp; }
 &nbsp; &nbsp; &nbsp; &nbsp;checkproc() { return status ${1+"$"}; }
 &nbsp; &nbsp;   ; start_daemon() { return daemon ${1+"$"}; }
 &nbsp;  else
  ; &nbsp; &nbsp; &nbsp;# emulate it
 &nbsp;   ; &nbsp; echo_rc() { echo "&nbsp; [${_SMSG[${_RC_RV}]}] "; }
 &nbsp; &nbsp;fi
&nbsp; &nbsp; rc_reset() { _RC_RV=0; }
 &nbsp; &nbsp;rc_failed()
 ; &nbsp; {
&nbsp;   ; &nbsp; &nbsp;if test -z "$1&quot;; then
&nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;_RC_RV=1;
 &nbsp; &nbsp; &nbsp;  elif test "$1&quot; != "0&quot;; then
 ; &nbsp; &nbsp; &nbsp; &nbsp;   ;_RC_RV=$1;
 &nbsp; &nbsp; &nbsp; &nbsp;fi
&nbsp; &nbsp; &nbsp;   ;return $
  ; &nbsp;}
 &nbsp;  rc_check()
 ; &nbsp; {
&nbsp;   ; &nbsp; &nbsp;return rc_failed $?
 &nbsp;  }
&nbsp; &nbsp; rc_status()
 &nbsp; &nbsp;{
   ; &nbsp; &nbsp; rc_failed $?
 &nbsp;   ; &nbsp; if test "$1&quot; = "-r&quot;; then _RC_RV=0; shift; fi
 &nbsp;   ; &nbsp; if test "$1&quot; = "-s&quot;; then rc_failed 5; echo_rc; rc_failed 3; shift; fi
   ; &nbsp; &nbsp; if test "$1&quot; = "-u&quot;; then rc_failed ${_RC_UNUSED}; echo_rc; rc_failed
3; shift; fi
 &nbsp;   ; &nbsp; if test "$1&quot; = "-v&quot;; then echo_rc; shift; fi
 &nbsp;   ; &nbsp; if test "$1&quot; = "-r&quot;; then _RC_RV=0; shift; fi
   ; &nbsp; &nbsp; return $
  ; &nbsp;}
 &nbsp;  rc_exit() { exit $; }
 &nbsp; &nbsp;rc_active()
 ; &nbsp; {
&nbsp;   ; &nbsp; &nbsp;#if test -z "$RUNLEVEL"; then read RUNLEVEL REST < <(/sbin/runlevel);
fi
 &nbsp;   ; &nbsp; if test -e /etc/init.d/S[0-9][0-9]$; then return 0; fi
   ; &nbsp; &nbsp; return 1
 &nbsp; &nbsp;}
fi

# Reset status of this service
rc_reset

# Return values acc. to LSB for all commands but status:
# 0 &nbsp; &nbsp; &nbsp; - success
# 1 &nbsp; &nbsp; &nbsp; - generic or unspecified error
# 2 &nbsp; &nbsp; &nbsp; - invalid or excess argument(s)
# 3 &nbsp; &nbsp; &nbsp; - unimplemented feature (e.g. "reload")
# 4 &nbsp; &nbsp; &nbsp; - user had insufficient privileges
# 5 &nbsp; &nbsp; &nbsp; - program is not installed
# 6 &nbsp; &nbsp; &nbsp; - program is not configured
# 7 &nbsp; &nbsp; &nbsp; - program is not running
# 8--199&nbsp; - reserved (8--99 LSB, 100--149 distrib, 150--199 appl)
#
# Note that starting an already running service, stopping
# or restarting a not-running service as well as the restart
# with force-reload (in case signaling is not supported) are
# considered a success.

case "$1&quot; in
 &nbsp;  start)
 &nbsp; &nbsp; &nbsp;  echo -n "Starting cherokee "
&nbsp; &nbsp; &nbsp;   ;## Start daemon with startproc(8). If this fails
&nbsp; &nbsp; &nbsp; &nbsp; ## the return value is set appropriately by startproc.
 &nbsp; &nbsp; &nbsp;  start_daemon $CHEROKEE_BIN -b

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

&nbsp; &nbsp; &nbsp; &nbsp; killproc -TERM $CHEROKEE_BIN

   ; &nbsp; &nbsp; # Remember status and be verbose
&nbsp; &nbsp;   ; &nbsp;rc_status -v
 &nbsp;   ; &nbsp; ;;
  ; &nbsp;try-restart|condrestart)
 ; &nbsp; &nbsp; &nbsp; ## Do a restart only if the service was active before.
&nbsp; &nbsp;   ; &nbsp;## Note: try-restart is now part of LSB (as of 1.9).
&nbsp; &nbsp; &nbsp; &nbsp; ## RH has a similar command named condrestart.
 &nbsp; &nbsp;   ; if test "$1&quot; = "condrestart&quot;; then
&nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp;echo "${attn} Use try-restart $(LSB)$ rather than
condrestart $(RH)$&quot;
fi
 &nbsp;   ; &nbsp; $0 status
&nbsp; &nbsp; &nbsp;   ;if test $? = 0; then
 ; &nbsp; &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp;$0 restart
&nbsp;   ; &nbsp; &nbsp;else
&nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp;  rc_reset &nbsp; &nbsp;   ; # Not running is not a failure.
&nbsp;   ; &nbsp; &nbsp;fi
 ; &nbsp; &nbsp; &nbsp; # Remember status and be quiet
&nbsp; &nbsp; &nbsp; &nbsp; rc_status
&nbsp;   ; &nbsp; &nbsp;;;
 ; &nbsp; restart)
 ; &nbsp; &nbsp; &nbsp; ## Stop the service and regardless of whether it was
 ; &nbsp; &nbsp; &nbsp; ## running or not, start it again.
&nbsp; &nbsp; &nbsp;   ;$0 stop
 ; &nbsp; &nbsp; &nbsp; $0 start

&nbsp; &nbsp; &nbsp;   ;# Remember status and be quiet
&nbsp; &nbsp; &nbsp; &nbsp; rc_status
&nbsp;   ; &nbsp; &nbsp;;;
 ; &nbsp; force-reload)
  ; &nbsp; &nbsp; &nbsp;## Signal the daemon to reload its config. Most daemons
&nbsp;   ; &nbsp; &nbsp;## do this on signal 1 (SIGHUP).
  ; &nbsp; &nbsp; &nbsp;## If it does not support it, restart the service if it
 &nbsp;   ; &nbsp; ## is running.

  ; &nbsp; &nbsp; &nbsp;echo -n "Reload service cherokee "
&nbsp; &nbsp; &nbsp;   ;## if it supports it:
 ; &nbsp; &nbsp; &nbsp; killproc -HUP $CHEROKEE_BIN
 &nbsp;   ; &nbsp; #touch /var/run/cherokee.pid
 &nbsp; &nbsp; &nbsp; &nbsp;rc_status -v

   ; &nbsp; &nbsp; ## Otherwise:
 &nbsp; &nbsp; &nbsp; &nbsp;#$0 try-restart
 &nbsp; &nbsp; &nbsp;  #rc_status
 ; &nbsp; &nbsp; &nbsp; ;;
 &nbsp; &nbsp;reload)
 &nbsp; &nbsp; &nbsp; &nbsp;## Like force-reload, but if daemon does not support
&nbsp;   ; &nbsp; &nbsp;## signaling, do nothing (!)

 ; &nbsp; &nbsp; &nbsp; # If it supports signaling:
 &nbsp; &nbsp; &nbsp; &nbsp;echo -n "Reload service cherokee "
&nbsp; &nbsp; &nbsp;   ;killproc -HUP $CHEROKEE_BIN
 &nbsp;   ; &nbsp; #touch /var/run/cherokee.pid
 &nbsp; &nbsp;   ; rc_status -v

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

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

&nbsp;   ; &nbsp; &nbsp;# NOTE: checkproc returns LSB compliant status values.
&nbsp; &nbsp;   ; &nbsp;checkproc $CHEROKEE_BIN
 &nbsp;   ; &nbsp; # NOTE: rc_status knows that we called this init script with
 ; &nbsp; &nbsp; &nbsp; # "status" option and adapts its messages accordingly.
 &nbsp;   ; &nbsp; rc_status -v
 &nbsp;   ; &nbsp; ;;
  ; &nbsp;probe)
&nbsp; &nbsp;   ; &nbsp;## Optional: Probe for the necessity of a reload, print out the
   ; &nbsp; &nbsp; ## argument to this init script which is required for a reload.
&nbsp; &nbsp;   ; &nbsp;## Note: probe is not (yet) part of LSB (as of 1.9)

&nbsp; &nbsp; &nbsp;   ;test /etc/cherokee/cherokee.conf -nt /var/run/cherokee.pid && echo
reload
 &nbsp; &nbsp; &nbsp;  ;;
&nbsp; &nbsp; *)
 &nbsp; &nbsp;   ; echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|
reload|probe}"
&nbsp; &nbsp;   ; &nbsp;exit 1
 &nbsp; &nbsp;   ; ;;
esac
rc_exit



And here you are:
[manuArbusto Desktop]$ sh cherokee.init start
Starting cherokee
[rootArbusto ~]# sh /home/manu/cherokee/cherokee.init start
Starting cherokee
[rootArbusto ~]#
[rootArbusto ~]# netstat -putan | grep -i cherokee
tcp &nbsp; &nbsp; &nbsp;  0&nbsp; &nbsp; &nbsp; 0 0.0.0.0:80  &nbsp; &nbsp; &nbsp;   ; &nbsp; &nbsp; &nbsp; &nbsp; 0.0.0.0
LISTEN&nbsp; &nbsp; &nbsp; 7530/cherokee
[rootArbusto ~]#

Kind regards
--
Manuel Arostegui Ramirez.

Electronic Mail is not secure, may not be read every day, and should not
be used for urgent or sensitive issues.
_______________________________________________
Cherokee mailing list
Cherokee0x50.org" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">Cherokee0x50.org
http://www.0x50.org/cgi-bin/mailman/listinfo/cherokee



--
---
Carlitux
Blog Personal: http://carlotez.blogspot.com/
"May the source be with you...&quot;
"In a World without walls and fences who needs WINDOWS and GATES?&quot;
http://counter.li.org/cgi-bin/certificate.cgi/409534

---
Ing. Carlos Alcalá Helguero
Administrador Encargado de Laboratorios de Computo
Universidad Catolica Boliviana "San Pablo";
Phone:&nbsp; (591)+4249234
Office: (591)+4293100 - Int. 247
Cel:&nbsp; &nbsp; 72735250
Cochabamba - Bolivia


GPG Key:
https://166.114.106.12/~carlotez/key.gpg.asc
pub&nbsp; 1024D/CD98DB19 2006-06-02 Ing. Carlos Javier Alcala Helguero (Administrador de Laboratorios y Servidores) < carlotezgmail.com" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)"> carlotezgmail.com >
GPG Fingerprint = BC12 864C 3A3E 9D09 8533  6B7A D3C2 EE1A CD98 DB19



--
---
Carlitux
Blog Personal: http://carlotez.blogspot.com/
&quot;May the source be with you...&quot;
"In a World without walls and fences who needs WINDOWS and GATES?&quot;
http://counter.li.org/cgi-bin/certificate.cgi/409534

---
Ing. Carlos Alcalá Helguero
Administrador Encargado de Laboratorios de Computo
Universidad Catolica Boliviana "San Pablo";
Phone:&nbsp; (591)+4249234
Office: (591)+4293100 - Int. 247
Cel:&nbsp; &nbsp; 72735250
Cochabamba - Bolivia


GPG Key: