====== Mettre en place une dlbox dans un container VZ: ======
Page non terminée - en cours de rédaction
Petit projet perso d'un serveur virtuel permettant d'automatiser quelques tâches sur les newsgroups :)
===== Installation de Sabnzbd =====
echo "deb http://ppa.launchpad.net/jcfp/ppa/ubuntu precise main" | sudo tee -a /etc/apt/sources.list && sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:11371 --recv-keys 0x98703123E0F52B2BE16D586EF13930B14BB9F05F
aptitude update ; aptitude install sabnzbdplus
Editer le fichier de configuration de daemon pour pouvoir l'activer
root@dl:~# cat /etc/default/sabnzbdplus
# This file is sourced by /etc/init.d/sabnzbdplus
#
# When SABnzbd+ is started using the init script, the
# --daemon option is always used, and the program is
# started under the account of $USER, as set below.
#
# Each setting is marked either "required" or "optional";
# leaving any required setting unconfigured will cause
# the service to not start.
# [required] user or uid of account to run the program as:
USER=vincentp
# [optional] full path to the configuration file of your choice;
# otherwise, the default location (in $USER's home
# directory) is used:
CONFIG=
# [optional] hostname/ip and port number to listen on:
**HOST=192.168.32.100
PORT=9090**
# [optional] extra command line options, if any:
EXTRAOPTS=
===== Installation de Sickbeard =====
useradd --system --user-group --no-create-home sickbear
git clone git://github.com/midgetspy/Sick-Beard.git
mv Sick-Beard /usr/local/sickbeard
chown -R sickbeard:nzb /usr/local/sickbeard
chmod ug+rw /usr/local/sickbeard/autoProcessTV/
mkdir /var/sickbeard
chown sickbeard:nzb /var/sickbeard
Installation du service dans /etc/init.d/sickbeard :
#!/bin/sh
### BEGIN INIT INFO
# Provides: SickBeard
# Required-Start: $network $remote_fs $syslog
# Required-Stop: $network $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start SickBeard at boot time
# Description: Start SickBeard.
### END INIT INFO
case "$1" in
start)
echo "Starting SickBeard."
/usr/bin/sudo -u sickbeard -H /usr/local/sickbeard/SickBeard.py -d —datadir /var/sickbeard —config /var/sickbeard/sickbeard.ini
;;
stop)
echo "Shutting down SickBeard."
p=`ps aux | grep -v grep | grep SickBeard.py | tr -s \ | cut -d ’ ’ -f 2`
if [ -n “$p” ]; then
sb_api_key=`grep -m 1 api_key ${sb_config} | cut -d ’ ’ -f 3`;
sb_port=`grep -m 1 web_port ${sb_config} | cut -d ’ ’ -f 3`;
wget -q —delete-after http://localhost:${sb_port}/api/${sb_api_key}/\?cmd=sb.shutdown
while ps -p $p > /dev/null; do sleep 1; done
fi
;;
*)
echo "Usage: $0 {start|stop}"
exit 1
esac
exit 0
chmod 755 /etc/init.d/sickbeard
update-rc.d sickbeard defaults
/etc/init.d/sickbeard start
===== Installation de couchpatatoes =====
useradd --system --user-group --no-create-home couchpotato
git clone git://github.com/RuudBurger/CouchPotatoServer.git
mv CouchPotatoServer /usr/local/couchpotato
chown -R couchpotato:couchpotato /usr/local/couchpotato
mkdir /var/couchpotato
chown -R couchpotato:couchpotato /var/couchpotato
Installation du service dans /etc/init.d/couchpotato :
#!/bin/sh
### BEGIN INIT INFO
# Provides: CouchPotato
# Required-Start: $network $remote_fs $syslog
# Required-Stop: $network $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start CouchPotato at boot time
# Description: Start CouchPotato.
### END INIT INFO
case "$1" in
start)
echo "Starting CouchPotato."
/usr/bin/sudo -u couchpotato -H /usr/local/couchpotato/CouchPotato.py --daemon --data_dir=/var/couchpotato --config_file=/var/couchpotato/couchpotato.ini
;;
stop)
echo "Shutting down CouchPotato."
p=`ps aux | grep -v grep | grep CouchPotato.py | tr -s \ | cut -d ’ ’ -f 2`
couch_api_key=`grep -m 1 api_key /var/couchpotato/couchpotato.ini | cut -d ’ ’ -f 3`;
couch_port=`grep -m 1 port /var/couchpotato/couchpotato.ini | cut -d ’ ’ -f 3`;
wget -q —delete-after http://localhost:${couch_port}/api/${couch_api_key}/app.shutdown
while ps -p $p > /dev/null; do sleep 1; done
;;
*)
echo "Usage: $0 {start|stop}"
exit 1
esac
exit 0
chmod 755 /etc/init.d/couchpotato
update-rc.d couchpotato defaults
/etc/init.d/couchpotato start
===== Installation de Headphone =====
useradd --system --user-group --no-create-home headphones
git clone git://github.com/rembo10/headphones.git
mv headphones /usr/local/headphones
chown -R headphones:headphones /usr/local/headphones
chmod ug+x /usr/local/headphones/Headphones.py
mkdir /var/headphones
chown -R headphones:headphones /var/headphones
Installation du service dans /etc/init.d/heaphones :
#!/bin/sh
#
## Don't edit this file
## Edit user configuation in /etc/default/headphones to change
##
## Make sure init script is executable
## sudo chmod +x /opt/headphones/init.ubuntu
##
## Install the init script
## sudo ln -s /opt/headphones/init.ubuntu /etc/init.d/headphones
##
## Create the headphones daemon user:
## sudo adduser --system --no-create-home headphones
##
## Make sure /opt/headphones is owned by the headphones user
## sudo chown headphones:nogroup -R /opt/headphones
##
## Touch the default file to stop the warning message when starting
## sudo touch /etc/default/headphones
##
## To start Headphones automatically
## sudo update-rc.d headphones defaults
##
## To start/stop/restart Headphones
## sudo service headphones start
## sudo service headphones stop
## sudo service headphones restart
##
## HP_USER= #$RUN_AS, username to run headphones under, the default is headphones
## HP_HOME= #$APP_PATH, the location of Headphones.py, the default is /opt/headphones
## HP_DATA= #$DATA_DIR, the location of headphones.db, cache, logs, the default is /opt/headphones
## HP_PIDFILE= #$PID_FILE, the location of headphones.pid, the default is /var/run/headphones/headphones.pid
## PYTHON_BIN= #$DAEMON, the location of the python binary, the default is /usr/bin/python
## HP_OPTS= #$EXTRA_DAEMON_OPTS, extra cli option for headphones, i.e. " --config=/home/headphones/config.ini"
## SSD_OPTS= #$EXTRA_SSD_OPTS, extra start-stop-daemon option like " --group=users"
## HP_PORT= #$PORT_OPTS, hardcoded port for the webserver, overrides value in config.ini
##
## EXAMPLE if want to run as different user
## add HP_USER=username to /etc/default/headphones
## otherwise default headphones is used
#
### BEGIN INIT INFO
# Provides: headphones
# 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 Headphones
# Description: starts instance of Headphones using start-stop-daemon
### END INIT INFO
# Script name
NAME=headphones
# App name
DESC=Headphones
SETTINGS_LOADED=FALSE
. /lib/lsb/init-functions
# Source Headphones configuration
if [ -f /usr/local/headphones ]; then
SETTINGS=/usr/local/headphones
else
log_warning_msg "/etc/default/headphones not found using default settings.";
fi
check_retval() {
if [ $? -eq 0 ]; then
log_end_msg 0
return 0
else
log_end_msg 1
exit 1
fi
}
load_settings() {
if [ $SETTINGS_LOADED != "TRUE" ]; then
. $SETTINGS
## The defaults
# Run as username
RUN_AS=${HP_USER-headphones}
# Path to app HP_HOME=path_to_app_Headphones.py
APP_PATH=${HP_HOME-/usr/local/headphones/}
# Data directory where headphones.db, cache and logs are stored
DATA_DIR=${HP_DATA-/var/headphones}
# Path to store PID file
PID_FILE=${HP_PIDFILE-/var/run/headphones/headphones.pid}
# Path to python bin
DAEMON=${PYTHON_BIN-/usr/bin/python}
# Extra daemon option like: HP_OPTS=" --config=/var/headphones/headphones.ini"
EXTRA_DAEMON_OPTS=${HP_OPTS-}
# Extra start-stop-daemon option like START_OPTS=" --group=users"
EXTRA_SSD_OPTS=${SSD_OPTS-}
# Hardcoded port to run on, overrides config.ini settings
[ -n "$HP_PORT" ] && {
PORT_OPTS=" --port=${HP_PORT} "
}
DAEMON_OPTS=" Headphones.py --quiet --daemon --nolaunch --pidfile=${PID_FILE} --datadir=${DATA_DIR} ${PORT_OPTS}${EXTRA_DAEMON_OPTS}"
SETTINGS_LOADED=TRUE
fi
[ -x $DAEMON ] || {
log_warning_msg "$DESC: Can't execute daemon, aborting. See $DAEMON";
return 1;}
return 0
}
load_settings || exit 0
is_running () {
# returns 1 when running, else 0.
if [ -e $PID_FILE ]; then
PID=`cat $PID_FILE`
RET=$?
[ $RET -gt 1 ] && exit 1 || return $RET
else
return 1
fi
}
handle_pid () {
PID_PATH=`dirname $PID_FILE`
[ -d $PID_PATH ] || mkdir -p $PID_PATH && chown -R $RUN_AS $PID_PATH > /dev/null || {
log_warning_msg "$DESC: Could not create $PID_FILE, See $SETTINGS, aborting.";
return 1;}
if [ -e $PID_FILE ]; then
PID=`cat $PID_FILE`
if ! kill -0 $PID > /dev/null 2>&1; then
log_warning_msg "Removing stale $PID_FILE"
rm $PID_FILE
fi
fi
}
handle_datadir () {
[ -d $DATA_DIR ] || mkdir -p $DATA_DIR && chown -R $RUN_AS $DATA_DIR > /dev/null || {
log_warning_msg "$DESC: Could not create $DATA_DIR, See $SETTINGS, aborting.";
return 1;}
}
handle_updates () {
chown -R $RUN_AS $APP_PATH > /dev/null || {
log_warning_msg "$DESC: $APP_PATH not writable by $RUN_AS for web-updates";
return 0; }
}
start_headphones () {
handle_pid
handle_datadir
handle_updates
if ! is_running; then
log_daemon_msg "Starting $DESC"
start-stop-daemon -o -d $APP_PATH -c $RUN_AS --start $EXTRA_SSD_OPTS --pidfile $PID_FILE --exec $DAEMON -- $DAEMON_OPTS
check_retval
else
log_success_msg "$DESC: already running (pid $PID)"
fi
}
stop_headphones () {
if is_running; then
log_daemon_msg "Stopping $DESC"
start-stop-daemon -o --stop --pidfile $PID_FILE --retry 15
check_retval
else
log_success_msg "$DESC: not running"
fi
}
case "$1" in
start)
start_headphones
;;
stop)
stop_headphones
;;
restart|force-reload)
stop_headphones
start_headphones
;;
*)
N=/etc/init.d/$NAME
echo "Usage: $N {start|stop|restart|force-reload}" >&2
exit 1
;;
esac
exit 0
chmod 755 /etc/init.d/headphones
update-rc.d headphones defaults
/etc/init.d/headphones start
===== Installation de Pyload =====
Télécharger le paquet Debian sur le site de pyload et l'installer:
wget http://download.pyload.org/pyload-v0.4.9-all.deb
dpkg -i pyload-v0.4.9-all.deb
rm pyload-v0.4.9-all.deb -Rf
On lance le logiciel puis on passe donc à la configuration de celui-ci :
cd /usr/share/pyload/
./pyLoadCore.py
Une fois l'ensemble des variables de l'assistant renseignées, nous pouvons redémarrer le service:
service pyload restart
===== Installation de Transmission =====