Home page > Web services > Streaming Audio et Video > Installation d’un serveur radio ShoutCast

Installation d’un serveur radio ShoutCast

ShoutCast est un serveur de streaming radio propriétaire ne gérant que le format sonore MP3. Il a un équivalent libre, Icecast, cependant ce dernier ne peut pas publier ses flux dans le répertoire des radios de shoutcast qui est énormément consulté.

Nous allons installer la version 2.0 car cette version permet de gérer plusieurs flux sur le même serveur contrairement à ses versions précédentes.

Après connexion au serveur, on procède à l’installation de shoutcast.

Récupération et configuration du logiciel

Dans un premier temps, on récupère la dernière version disponible sur le site officiel :

  1. cd ~
  2. mkdir shoutcast
  3. cd shoutcast
  4. wget http://download.nullsoft.com/shoutcast/tools/sc_serv2_linux_x64_07_31_2011.tar.gz

On décompresse le fichier récupéré :

  1. tar xvzf sc_serv2_linux_x64_07_31_2011.tar.gz

Le binaire du serveur est le fichier sc_serv. Il est nécessaire de créer un fichier de configuration sc_serv.conf avant son utilisation, quatre fichiers d’exemples sont fournis dans la distribution :

  • sc_serv_basic.conf;
  • sc_serv_debug.conf;
  • sc_serv_public.conf;
  • sc_serv_relay.conf;
  1. nano sc_serv.conf

Ce fichier doit ressembler à quelque chose comme cela [1]:

  1. ; NOTE: for any relative paths specified are relative to
  2. ; sc_serv and not to where the conf file is being stored
  3. log=1
  4. ; here we will setup where the log and other related files
  5. ; will be stored. make sure that these folders exist else
  6. ; sc_serv will throw an error and will close itself down.
  7. logfile=/var/log/shoutcast/sc_serv.log
  8. ; we will make the logs save to the sc_serv2 directory
  9. banfile=/etc/shoutcast/sc_serv.ban
  10. ripfile=/etc/shoutcast/sc_serv.rip
  11. screenlog=1
  12. w3cenable=1
  13. w3clog=/var/log/shoutcast/sc_w3c.log
  14. shoutcastsourcedebug=1
  15. SrcIP=ANY
  16. DestIP=ANY
  17. ; enable YP2 features (not used directly in this example
  18. ; but should be enabled when making a new YP2 setup)
  19. yp2=1
  20. ypaddr=yp.shoutcast.com
  21. ypport=80
  22. yppath=/yp2
  23. yp2debug=1
  24. ; for testing we will make the server only work locally
  25. ; (i.e. localhost / 127.0.0.1) though if this is left out
  26. ; or set to publicserver=always then we attempt to make a
  27. ; connection to the YP for listing - do not forget to add
  28. ; in a 'streamauthhash' value for any public streams made
  29. publicserver=allways
  30. ; if you're wanting to use a different port to use for any
  31. ; connections then you can use this option e.g. to use 80
  32. ; otherwise port 8000 is used as the default to listen on.
  33. portbase=8002
  34. ; password used by sc_trans or the Winamp dsp plug-in
  35. ; NOTE: remember to change this to something else
  36. password=pass_stream
  37. ; password used for accessing the administation pages
  38. ; NOTE: remember to change this to something else
  39. adminpassword=password_admin
  40. maxuser=200
  41. ; now we will specify the details of the stream we're going
  42. ; to serve which can be done as follows
  43. ;streamid=1
  44. ;streampath=/point_de_montage
  45. ;streamauthhash=hash_fournit_par_shoutcast
  46. ; or
  47. ; it can be done like this which is how it needs to be done
  48. ; if you are going to provide multiple streams from sc_serv
  49. streamid_1=1
  50. streampath_1=/point_de_montage_stream_1
  51. streamauthhash_1=hash_fournit_par_shoutcast_stream_1
  52. ;streamid_2=2
  53. ;streampath_2=/test2.aac

Installation définitive

Pour finir l’installation, on va copier le binaire du serveur dans le répertoire des autres binaires en lui donnant les droits d’exécution :

  1. chmod +x sc_serv
  2. sudo cp sc_serv /usr/local/bin/sc_serv

On crée ensuite un utilisateur système qui fera tourner le serveur :

  1. sudo adduser shoutcast

On déplace également le fichier de configuration dans un endroit plus habituel et on donne les droits à notre utilisateur de l’utiliser :

  1. sudo mkdir /etc/shoutcast
  2. sudo cp sc_serv.conf /etc/shoutcast
  3. sudo chown -Rvf shoutcast:shoutcast /etc/shoutcast

Enfin, on va créer le répertoire où les logs du serveurs seront déposés et donner les droits d’écriture sur ce dossier à l’utilisateur qui fera tourner le serveur shoutcast :

  1. sudo mkdir -p /var/log/shoutcast
  2. sudo chown shoutcast:shoutcast /var/log/shoutcast

Création d’un script d’initialisation

On ouvre un fichier en écriture :

  1. nano shoutcast.init

On y ajoute le contenu suivant :

  1. #!/bin/bash
  2. #
  3. # Init file for the Shoutcast server
  4. #
  5. # description: Starts a Shoutcast radio streaming server
  6. #
  7. # processname: sc_serv
  8. ### BEGIN INIT INFO
  9. # Provides:             shoutcast
  10. # Required-Start:       $syslog
  11. # Required-Stop:        $syslog
  12. # Should-Start:         $network
  13. # Should-Stop:          $network
  14. # Default-Start:        2 3 4 5
  15. # Default-Stop:         0 1 6
  16. # Short-Description:    Shoutcast -  Radio streaming server
  17. # Description:          Shoutcast provide a radio streaming server.
  18. ### END INIT INFO
  19. # Source function library.
  20. . /lib/lsb/init-functions
  21. NAME=shoutcast
  22. DESC="Shoutcast radio streaming server"
  23. DAEMON=/usr/local/bin/sc_serv
  24. CONF_FILE=/etc/shoutcast/sc_serv.conf
  25. # Pid file
  26. PIDFILE="/var/run/$NAME.pid"
  27. USER=shoutcast
  28. GROUP=shoutcast
  29. [ "$NETWORKING" = "no" ] && exit 0
  30. [ -f "$DAEMON" ] || exit 1
  31. [ -f "$CONF_FILE" ] || exit 1
  32. RETVAL=0
  33. start() {
  34.         echo -n "Starting $DESC: "
  35.         start-stop-daemon --start --background --quiet --make-pidfile --pidfile $PIDFILE \
  36.                 --chuid  $USER:$GROUP --user $USER --group $GROUP --name sc_serv \
  37.                 --exec $DAEMON  $CONF_FILE
  38.         echo "$NAME."
  39. }
  40. stop() {
  41.     echo -n "Stopping $DESC : "
  42.     start-stop-daemon --stop --quiet --pidfile $PIDFILE \
  43.         --oknodo
  44.     echo "$NAME."
  45. }
  46. restart() {
  47.     stop
  48.     sleep 5
  49.     start
  50. }
  51. status() {
  52.     PID=$(cat $PIDFILE)
  53.     if [ -n "$PID" ]; then
  54.         log_success_msg "$DESC is running (pid $PID)."
  55.             exit 0
  56.     else
  57.         log_failure_msg "$DESC is not running."
  58.             exit 1
  59.     fi
  60. }
  61. case "$1" in
  62.   start)
  63.         start
  64.     ;;
  65.   stop)
  66.         stop
  67.     ;;
  68.   status)
  69.         status
  70.     ;;
  71.   restart|reload)
  72.         restart
  73.     ;;
  74.   *)
  75.     echo "Usage: {start|stop|status|restart}"
  76.     RETVAL=1
  77. esac
  78. exit $RETVAL

Pour activer le script d’initialisation, il est ensuite nécessaire de le copier au bon endroit, de lui donner des droits d’exécution et de l’activer aux différentes étapes de lancement et de d’extinction du serveur en lançant les trois commandes suivantes :

  1. sudo cp shoutcast.init /etc/init.d/shoutcast
  2. sudo chmod +x /etc/init.d/shoutcast
  3. sudo update-rc.d shoutcast defaults

Démarrer, arrêter, redémarrer le serveur

Pour démarrer le serveur, il vous suffit donc de lancer la commande :

  1. sudo /etc/init.d/shoutcast start

Pour l’arrêter :

  1. sudo /etc/init.d/shoutcast stop

Et pour le redémarrer :

  1. sudo /etc/init.d/shoutcast restart

Vous devriez avoir accès dorénavant à l’interface web d’administration à l’adresse : http://domaine.tld:8002/index.html

Footnotes

[1] On décide de démarrer le serveur sur le port 8002 pour ne pas rentrer en conflit avec icecast sur le même serveur qui utilise le port 8000 comme la configuration par défaut de shoutcast

No comments



Any message or comment?
  • (To create paragraphs, you simply leave blank lines.)

Who are you? (optional)
  • [Sign In]