Voici un script init.d pour lancer mumble comme un service via les binaires.

#!/bin/bash
# myapp daemon
# chkconfig: 345 20 80
# description: myapp daemon
# processname: myapp

DAEMON_PATH="/root/mumble" #CHANGME

DAEMON=murmur.x86 
DAEMONOPTS=""
RUNAS=matt #CHANGME

NAME=Mumble
DESC="Mumble !!!"
PIDFILE=/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME

case "$1" in
start)
	printf "%-50s" "Starting $NAME..."
	
	su -c "$DAEMON_PATH/$DAEMON" $RUNAS
	sleep 3
	PID=`pidof $DAEMON`
	#echo "Saving PID" $PID " to " $PIDFILE
        if [ -z $PID ]; then
            printf "%s\n" "Fail"
        else
            echo $PID > $PIDFILE
            printf "%s\n" "Ok"
        fi
;;
status)
        printf "%-50s" "Checking $NAME..."
        if [ -f $PIDFILE ]; then
            PID=`cat $PIDFILE`
            if [ -z "`pidof $DAEMON`" ]; then
                printf "%s\n" "Process dead but pidfile exists"
            else
                echo "Running"
            fi
        else
            printf "%s\n" "Service not running"
        fi
;;
stop)
        printf "%-50s" "Stopping $NAME"
            PID=`cat $PIDFILE`
            cd $DAEMON_PATH
        if [ -f $PIDFILE ]; then
            kill -15 $PID
            printf "%s\n" "Ok"
            rm -f $PIDFILE
        else
            printf "%s\n" "pidfile not found"
        fi
;;

restart)
  	$0 stop
  	$0 start
;;

*)
        echo "Usage: $0 {status|start|stop|restart}"
        exit 1
esac

Voici des exemples d’utilisation

service mumble stop
service mumble start
service mumble restart
service mumble status

Découvrez ici comment installer un serveur mumble

Nous allons voir ici comment installer un serveur Mumble (Murmur) sous linux.

Je vais ici expliquer comment installer le service via les binaires (et non pas avec un dépôt).

Installation

Nous devons commencer par télécharger la dernière version du serveur sur le site officiel (Choisissez Static Linux Server et de préférence stable release).

cd /root
wget http....

Une fois l’archive téléchargée sur votre serveur il faut l’extraire

tar xjvf murmur-static_*.tar.bz2

On peut à présent supprimer l’archive, elle ne nous sert plus.

rm *.tar.bz2

On va renommer le dossier pour plus de confort.

mv murmur-static_* mumble

Configuration

A présent, nous allons pouvoir éditer le fichier de configuration de mumble: murmur.ini

nano mumble/mumble.ini

Voici les lignes intéressantes:

  • Garder les logs du serveurs:
logfile=/home/matt/mumble/murmur.log
  •  Le message de bienvenue
welcometext="<br />Bienvenue sur le serveur mumble <br /> <b>matt.niloo.fr</b>"
  •  Le port d’écoute du serveur
port=64738 # c'est le port par défaut
  • Définir un mot de passe pour rejoindre le serveur
serverpassword=
  •  Défini la bande passante maximale qui est autorisé par les clients (en bps)
bandwidth=72000
  • Nombre maximal de client que le serveur peut accueillir
users=25

 Firewall

Si vous utilisez iptables, il faudra autoriser les connexion upd et tcp en trafic entrant vers le port du serveur

 iptables -A INPUT -p tcp --dport 64738 -j ACCEPT
 iptables -A INPUT -p udp --dport 64738 -j ACCEPT

 Premier démarrage

Nous somme toujours dans le répertoire mumble, on peut procéder au premier démarrage afin de définir le mot de passe SuperUser

./murmur.x86 -supw MonSuperMotDePasse

Changer le mot de passe bien sur 😀

On peux maintenant lancer le service manuellement:

./murmur.x86 -ini murmur.ini

NB: Le fichier murmur.ini doit se trouver au même endroit que l’exécutable murmur.x86

Pour lancer le service en mode debug (uniquement si vous rencontrez des problèmes)

./murmur.x86 -ini murmur.ini -v -fg

Pour le lancer comme un vrai service: rendez-vous ici pour savoir comment gérer le daemon via un script

Afficher les règles iptables en détails:

iptables -n -L -v

 Afficher les ports utilisés sur la machine ainsi que le PID du service en question

netstat -tanpu

 Compresser un dossier en tar.gz

tar czvf <nom_archive>.tar.gz <nom_dossier>

 Decompresser un tar.gz

tar xzvf <nom_archive>.tar.gz

 Faire une capture de paquet

tcpdump -i <interface>

 Autre options:

  • port XX : filtre sur le port en question
  • -v : mode verbose
  • -w <nom_du_fichier> : enregistre la capture dans un fichier (qui peut être ouvert avec wireshark)

Afficher/surveiller un fichier en continu

Très utile pour les logs notamment

tail -f <chemin_du_fichier>

Supprimer les fichiers plus vieux de X jours

Utile pour supprimer les vieux fichiers de backup

Dans l’exemple ci dessous supprime les fichiers vieux de > 3 jours dans /data/backups

cd /data/backups/ && find -type f -mtime +2 -exec /bin/rm -f {} \;

Faire un backup complet du système linux

tar cvpjf backup.tar.bz2 --exclude=/proc --exclude=/lost+found --exclude=/root/backup.tar.bz2 --exclude=/mnt --exclude=/sys /