mirror of
https://github.com/Radarr/Radarr
synced 2025-01-03 05:44:50 +00:00
Updated Autostart on Linux (markdown)
parent
24ddc29bfc
commit
c7629e1103
1 changed files with 171 additions and 101 deletions
|
@ -74,121 +74,191 @@ exec mono --debug $DIR/Radarr.exe
|
|||
sudo start radarr
|
||||
|
||||
|
||||
## LSB init-script (Debian/Ubuntu)
|
||||
## Init.d Script (Debian/Ubuntu)
|
||||
# Autostart on Debian using init.d script
|
||||
|
||||
### Init File
|
||||
The init.d file should be saved as `/etc/init.d/radarr`
|
||||
The instructions for Ubuntu/Debian did not seem to work for Debian very well, and the pid got lost whenever Radarr was restarted via the web-ui, so I've included a working script here init.d script here. You'll need to have already created an radarr user.
|
||||
|
||||
```bash
|
||||
**Create and edit the radarr init.d script**
|
||||
|
||||
#!/bin/bash
|
||||
sudo nano /etc/init.d/radarr
|
||||
|
||||
### BEGIN INIT INFO
|
||||
# Provides: radarr
|
||||
# Required-Start: $local_fs $network $remote_fs
|
||||
# Required-Stop: $local_fs $network $remote_fs
|
||||
# Default-Start: 2 3 4 5
|
||||
# Default-Stop: 0 1 6
|
||||
# Short-Description: radarr
|
||||
# Description: Radarr
|
||||
### END INIT INFO
|
||||
**Paste the following, changing applicable variables**
|
||||
````bash
|
||||
|
||||
. /lib/lsb/init-functions
|
||||
#! /bin/sh
|
||||
### BEGIN INIT INFO
|
||||
# Provides: Radarr
|
||||
# Required-Start: $local_fs $network $remote_fs
|
||||
# Required-Stop: $local_fs $network $remote_fs
|
||||
# Should-Start: $NetworkManager
|
||||
# Should-Stop: $NetworkManager
|
||||
# Default-Start: 2 3 4 5
|
||||
# Default-Stop: 0 1 6
|
||||
# Short-Description: starts instance of Radarr
|
||||
# Description: starts instance of Radarr using start-stop-daemon
|
||||
### END INIT INFO
|
||||
|
||||
#set -e
|
||||
############### EDIT ME ##################
|
||||
# path to app
|
||||
APP_PATH=/opt/Radarr
|
||||
|
||||
NAME=radarr
|
||||
DESC="Radarr"
|
||||
MONO=$(which mono)
|
||||
# user
|
||||
RUN_AS=root
|
||||
|
||||
DAEMON=/opt/radarr/Radarr.exe
|
||||
DAEMONOPTS=""
|
||||
# path to mono bin
|
||||
DAEMON=$(which mono)
|
||||
|
||||
PIDDIR=/var/run/${NAME}
|
||||
PIDFILE=${PIDDIR}/${NAME}.pid
|
||||
# Path to store PID file
|
||||
PID_FILE=/var/run/radarr/radarr.pid
|
||||
PID_PATH=$(dirname $PID_FILE)
|
||||
|
||||
RUNASUSER=user
|
||||
RUNASGROUP=group
|
||||
RUNAS=$RUNASUSER:$RUNASGROUP
|
||||
# script name
|
||||
NAME=radarr
|
||||
|
||||
DATADIR=/home/$RUNASUSER/
|
||||
# app name
|
||||
DESC=Radarr
|
||||
|
||||
if ! [ -r ${DAEMON} ]; then echo "Can't read: ${DAEMON}" 2>&1; exit 1; fi
|
||||
if ! [ -x ${MONO} ]; then echo "Not executable: ${MONO}" 2>&1; exit 1; fi
|
||||
if ! [ -d ${DATADIR} ]; then echo "No such directory: ${DATADIR}" 2>&1; exit 1; fi
|
||||
# startup args
|
||||
EXENAME="Radarr.exe"
|
||||
DAEMON_OPTS=" "$EXENAME
|
||||
|
||||
if [ ! -d ${PIDDIR} ]; then
|
||||
mkdir -p ${PIDDIR}; chown ${RUNASUSER}:root ${PIDDIR}; chmod 0750 ${PIDDIR};
|
||||
############### END EDIT ME ##################
|
||||
|
||||
RADARR_PID=`ps auxf | grep Radarr.exe | grep -v grep | awk '{print $2}'`
|
||||
|
||||
test -x $DAEMON || exit 0
|
||||
|
||||
set -e
|
||||
|
||||
#Look for PID and create if doesn't exist
|
||||
if [ ! -d $PID_PATH ]; then
|
||||
mkdir -p $PID_PATH
|
||||
chown $RUN_AS $PID_PATH
|
||||
fi
|
||||
|
||||
if [ ! -d $DATA_DIR ]; then
|
||||
mkdir -p $DATA_DIR
|
||||
chown $RUN_AS $DATA_DIR
|
||||
fi
|
||||
|
||||
if [ -e $PID_FILE ]; then
|
||||
PID=`cat $PID_FILE`
|
||||
if ! kill -0 $PID > /dev/null 2>&1; then
|
||||
echo "Removing stale $PID_FILE"
|
||||
rm $PID_FILE
|
||||
fi
|
||||
fi
|
||||
|
||||
do_start() {
|
||||
RETVAL=1
|
||||
if [ -e ${PIDFILE} ]; then
|
||||
if ! kill -0 $(cat ${PIDFILE}) &> /dev/null; then
|
||||
rm -f $PIDFILE
|
||||
fi
|
||||
fi
|
||||
echo $RADARR_PID > $PID_FILE
|
||||
|
||||
log_daemon_msg "Starting ${DESC}" "${NAME}"
|
||||
if pgrep -f "^${MONO} ${DAEMON}" > /dev/null 2>&1; then
|
||||
log_progress_msg "(already running?)"
|
||||
case "$1" in
|
||||
start)
|
||||
if [ -z "${RADARR_PID}" ]; then
|
||||
echo "Starting $DESC"
|
||||
rm -rf $PID_PATH || return 1
|
||||
install -d --mode=0755 -o $RUN_AS $PID_PATH || return 1
|
||||
start-stop-daemon -d $APP_PATH -c $RUN_AS --start --background --pidfile $PID_FILE --exec $DAEMON -- $DAEMON_OPTS
|
||||
else
|
||||
echo "Radarr already running."
|
||||
fi
|
||||
;;
|
||||
stop)
|
||||
echo "Stopping $DESC"
|
||||
echo $RADARR_PID > $PID_FILE
|
||||
start-stop-daemon --stop --pidfile $PID_FILE --retry 15
|
||||
;;
|
||||
|
||||
restart|force-reload)
|
||||
echo "Restarting $DESC"
|
||||
start-stop-daemon --stop --pidfile $PID_FILE --retry 15
|
||||
start-stop-daemon -d $APP_PATH -c $RUN_AS --start --background --pidfile $PID_FILE --exec $DAEMON -- $DAEMON_OPTS
|
||||
;;
|
||||
status)
|
||||
# Use LSB function library if it exists
|
||||
if [ -f /lib/lsb/init-functions ]; then
|
||||
. /lib/lsb/init-functions
|
||||
if [ -e $PID_FILE ]; then
|
||||
status_of_proc -p $PID_FILE "$DAEMON" "$NAME" && exit 0 || exit $?
|
||||
else
|
||||
start-stop-daemon -q -d ${DATADIR} -c $RUNAS --start --background --make-pidfile --pidfile $PIDFILE --exec $MONO -- $DAEMON $DAEMON_OPTS
|
||||
RETVAL=$?
|
||||
log_daemon_msg "$NAME is not running"
|
||||
exit 3
|
||||
fi
|
||||
log_end_msg $RETVAL
|
||||
}
|
||||
do_stop() {
|
||||
RETVAL=1
|
||||
log_daemon_msg "Stopping ${DESC}" "${NAME}"
|
||||
if ! pgrep -f "^${MONO} ${DAEMON}" > /dev/null 2>&1; then
|
||||
log_progress_msg "(not running?)"
|
||||
|
||||
else
|
||||
# Use basic functions
|
||||
if [ -e $PID_FILE ]; then
|
||||
PID=`cat $PID_FILE`
|
||||
if kill -0 $PID > /dev/null 2>&1; then
|
||||
echo " * $NAME is running"
|
||||
exit 0
|
||||
fi
|
||||
else
|
||||
start-stop-daemon -q --stop --pidfile $PIDFILE --retry 15
|
||||
RETVAL=$?
|
||||
echo " * $NAME is not running"
|
||||
exit 3
|
||||
fi
|
||||
log_end_msg $RETVAL
|
||||
fi
|
||||
;;
|
||||
*)
|
||||
N=/etc/init.d/$NAME
|
||||
echo "Usage: $N {start|stop|restart|force-reload|status}" >&2
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
|
||||
}
|
||||
exit 0
|
||||
|
||||
case "$1" in
|
||||
start)
|
||||
do_start
|
||||
;;
|
||||
stop)
|
||||
do_stop
|
||||
;;
|
||||
````
|
||||
|
||||
status)
|
||||
status_of_proc -p $PIDFILE $DAEMON $NAME && exit 0 || exit $?
|
||||
;;
|
||||
**Make it executable**
|
||||
|
||||
restart|force-reload)
|
||||
do_stop;
|
||||
do_start;
|
||||
;;
|
||||
*)
|
||||
N=/etc/init.d/$NAME
|
||||
echo "Usage: $0 {start|stop|status|restart|force-reload}" >&2
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
sudo chmod +x /etc/init.d/radarr
|
||||
|
||||
exit 0
|
||||
```
|
||||
**Update rc.d**
|
||||
|
||||
### Make init.d script executable
|
||||
`sudo chmod +x /etc/init.d/radarr`
|
||||
sudo update-rc.d radarr defaults
|
||||
|
||||
### Run insserv
|
||||
`sudo insserv -v radarr`
|
||||
**Create radarr user**
|
||||
|
||||
Note: May need to run `sudo ln -s /usr/lib/insserv/insserv /sbin/insserv` first if insserv is not found.
|
||||
useradd radarr
|
||||
|
||||
## Start init.d script
|
||||
`sudo /etc/init.d/radarr start`
|
||||
**Start Radarr**
|
||||
|
||||
Note: The script by default runs as root. I suggest adding an radarr user (`useradd -m -d /var/lib/radarr --gid nogroup radarr`) and adjusting the script so that RUNASUSER=radarr & RUNASGROUP=nogroup.
|
||||
sudo service radarr start
|
||||
|
||||
**Security Note**
|
||||
|
||||
For security purposes, you can prevent this account from being logged into by editing the '/etc/passwd' entry for user radarr and changing it to '/bin/false' or /usr/sbin/nologin'. I've also removed the password from '/etc/shadow'. From researching, these both appear to be the manual ways to perform the '--disable-login' and '--disable-password' while creating a new user. Alternatively, you can accomplish this same task by creating a user with the '--system' option.
|
||||
|
||||
/etc/passwd 'radarr:x:1001:1001:Radarr Movie Media:/opt/Radarr:/bin/false'
|
||||
/etc/shadow 'radarr:*:17124:0:99999:7:::'
|
||||
|
||||
Utilizing the '/usr/sbin/nologin' option will output what's seen below, when attempting to change to that user from root.
|
||||
|
||||
su - radarr
|
||||
This account is currently not available.
|
||||
|
||||
Now, recursively edit the /opt/Radarr directory to only allow read, write and executable access to the directory owner and other users in the same group as this directory.
|
||||
|
||||
chmod 770 /opt/Radarr -R
|
||||
|
||||
Add the directory to the group 'radarr' and modify the owner to 'radarr'
|
||||
|
||||
chown radarr:radarr /opt/Radarr -R
|
||||
|
||||
If all is well, you should see the following outputs.
|
||||
|
||||
ls -ld /opt/Radarr/
|
||||
drwxrwx--- 4 radarr radarr 4096 Nov 23 17:31 /opt/Radarr/
|
||||
|
||||
ls -la /opt/Radarr/Radarr.exe
|
||||
-rwxrwx--- 1 radarr radarr 23552 Nov 6 13:05 /opt/Radarr/Radarr.exe
|
||||
|
||||
Test from a different user account to confirm these user and group permissions
|
||||
|
||||
su - test123
|
||||
cd /opt/Radarr/
|
||||
-su cd: /opt/Radarr/: Permission denied
|
||||
|
||||
## FreeBSD/FreeNAS
|
||||
https://raw.github.com/tofagerl/freedrone/master/nzbdrone
|
||||
|
|
Loading…
Reference in a new issue