mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-23 18:55:49 +03:00
Merge pull request #983 from djvdorp/sysvinit
dist/init/linux-sysvinit: caddy for SysVinit
This commit is contained in:
commit
372c77da3a
2 changed files with 104 additions and 0 deletions
11
dist/init/linux-sysvinit/README.md
vendored
Normal file
11
dist/init/linux-sysvinit/README.md
vendored
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
SysVinit conf for Caddy
|
||||||
|
=======================
|
||||||
|
|
||||||
|
Usage
|
||||||
|
-----
|
||||||
|
|
||||||
|
* Download the appropriate Caddy binary in `/usr/local/bin/caddy` or use `curl https://getcaddy.com | bash`.
|
||||||
|
* Save the SysVinit config file in `/etc/init.d/caddy`.
|
||||||
|
* Ensure that the folder `/etc/caddy` exists and that the subfolder `ssl` is owned by `www-data`.
|
||||||
|
* Create a Caddyfile in `/etc/caddy/Caddyfile`
|
||||||
|
* Now you can use `sudo /etc/init.d/caddy start|stop|restart|reload|status`.
|
93
dist/init/linux-sysvinit/caddy
vendored
Normal file
93
dist/init/linux-sysvinit/caddy
vendored
Normal file
|
@ -0,0 +1,93 @@
|
||||||
|
#!/bin/sh
|
||||||
|
### BEGIN INIT INFO
|
||||||
|
# Provides: caddy
|
||||||
|
# Required-Start: $local_fs $network $named $time $syslog
|
||||||
|
# Required-Stop: $local_fs $network $named $time $syslog
|
||||||
|
# Default-Start: 2 3 4 5
|
||||||
|
# Default-Stop: 0 1 6
|
||||||
|
# Short-Description: starts the caddy web server
|
||||||
|
# Description: starts caddy using start-stop-daemon
|
||||||
|
### END INIT INFO
|
||||||
|
|
||||||
|
# Original Author: Frédéric Galusik (fredg)
|
||||||
|
# Maintainer: Daniel van Dorp (djvdorp)
|
||||||
|
|
||||||
|
DESC="the caddy web server"
|
||||||
|
NAME=caddy
|
||||||
|
DAEMON=$(which caddy)
|
||||||
|
|
||||||
|
DAEMONUSER=www-data
|
||||||
|
PIDFILE=/var/run/$NAME.pid
|
||||||
|
LOGFILE=/var/log/$NAME.log
|
||||||
|
CONFIGFILE=/etc/caddy/Caddyfile
|
||||||
|
DAEMONOPTS="-agree=true --pidfile=$PIDFILE log=$LOGFILE -conf=$CONFIGFILE"
|
||||||
|
|
||||||
|
USERBIND="$(which setcap) cap_net_bind_service=+ep"
|
||||||
|
STOP_SCHEDULE="${STOP_SCHEDULE:-QUIT/5/TERM/5/KILL/5}"
|
||||||
|
|
||||||
|
test -x $DAEMON || exit 0
|
||||||
|
|
||||||
|
# Set the CADDYPATH; Let's Encrypt certificates will be written to this directory.
|
||||||
|
export CADDYPATH=/etc/caddy/ssl
|
||||||
|
|
||||||
|
# Set the ulimits
|
||||||
|
ulimit -n 8192
|
||||||
|
|
||||||
|
|
||||||
|
start() {
|
||||||
|
$USERBIND $DAEMON
|
||||||
|
start-stop-daemon --start --quiet --make-pidfile --pidfile $PIDFILE \
|
||||||
|
--background --chuid $DAEMONUSER --exec $DAEMON -- $DAEMONOPTS
|
||||||
|
}
|
||||||
|
|
||||||
|
stop() {
|
||||||
|
start-stop-daemon --stop --quiet --remove-pidfile --pidfile $PIDFILE \
|
||||||
|
--retry=$STOP_SCHEDULE --name $NAME --oknodo
|
||||||
|
}
|
||||||
|
|
||||||
|
reload() {
|
||||||
|
start-stop-daemon --stop --quiet --signal USR1 --pidfile $PIDFILE \
|
||||||
|
--name $NAME
|
||||||
|
}
|
||||||
|
|
||||||
|
status() {
|
||||||
|
if [ -f $PIDFILE ]; then
|
||||||
|
PID=`cat $PIDFILE`
|
||||||
|
if [ -z "`ps axf | grep ${PID} | grep -v grep`" ]; then
|
||||||
|
echo "$NAME process is dead, but pidfile exists"
|
||||||
|
else
|
||||||
|
echo "$NAME is running"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "$NAME is not running"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
start)
|
||||||
|
echo "Starting $NAME"
|
||||||
|
start
|
||||||
|
;;
|
||||||
|
stop)
|
||||||
|
echo "Stopping $NAME"
|
||||||
|
stop
|
||||||
|
;;
|
||||||
|
restart)
|
||||||
|
echo "Restarting $NAME"
|
||||||
|
stop
|
||||||
|
start
|
||||||
|
;;
|
||||||
|
reload)
|
||||||
|
echo "Reloading $NAME configuration"
|
||||||
|
reload
|
||||||
|
;;
|
||||||
|
status)
|
||||||
|
status
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Usage: $0 {start|stop|restart|reload|status}"
|
||||||
|
exit 2
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
exit 0
|
Loading…
Reference in a new issue