Følgende veiledning forklarer hvordan du setter opp en IceCast radiostrømmeserver og spiller av lydfiler (musikk eller podcaster) på FreeBSD-plattformen. Denne opplæringen forutsetter at du kjører FreeBSD 10.0 eller høyere og at du er logget på som root-bruker. Det antok også at du har et tekstredigeringsprogram for å redigere konfigurasjonsfiler.
Før vi begynner, er det viktig å forstå de tre delene av en lydstrømmeserver. For det første har vi selve serverprogramvaren, IceCast. IceCast fungerer som et sentralt knutepunkt der lydstrømmer kommer inn og sendes ut. IceCast-tjenesten tar inn lydstrømmer fra kildeklienter. Kildeklienter er programmer som leser lydfiler eller andre lydkilder, for eksempel mikrofoner. I vårt eksempel er kildeklienten Ices og den leverer en lydstrøm til IceCast-serveren. Den tredje komponenten er en lyttende klient. Lydstrømmer går fra IceCast-serveren til lyttere som deretter hører lyden. Vanligvis er en lytteklient en skrivebordsapplikasjon, for eksempel en nettleser, VLC multimediaspiller eller WinAMP. Visuelt ser opplegget slik ut:
Source client (Ices) --> IceCast server --> Listening client (browser)
For å sette opp en IceCast-streamingserver på FreeBSD, installerer vi først selve serverprogramvaren. Dette kan gjøres ved å kjøre følgende kommando.
pkg install icecast2
Vi åpner deretter /etc/rc.conffilen og aktiverer bakgrunnstjenesten IceCast. Dette gjøres ved å legge til følgende tekst nederst i /etc/rc.conffilen.
icecast_enable="YES"
Vårt neste trinn er å konfigurere IceCast-tjenesten. IceCast-pakken leveres med en eksempelkonfigurasjonsfil som vi kan endre. Denne eksempelfilen ligger i /usr/local/etckatalogen. Vi vil lage en kopi av denne eksempelfilen før vi redigerer den.
cd /usr/local/etc
cp icecast.xml.sample icecast.xml
Vi ønsker nå å redigere noen få nøkkelfelt i icecast.xmlfilen. Det meste av filen kan stå igjen med standardinnstillingene, men vi bør endre påloggingsinformasjonen. Vi kan gjøre dette ved å besøke autentiseringsdelen (ca. linje 30) og endre kilde-passordet og relé-passordet til noe passende. Disse passordene vil tillate oss å streame data til IceCast-serveren fra en kildeklient. Vi bør også endre admin-bruker- og admin-passord- variablene til noe unikt for systemet vårt. Disse to legitimasjonene beskytter IceCast-serverens nettbaserte grensesnitt. Så, ned rundt linje 150, bør vi endre variablene mount-name , brukernavn , ogpassord . Disse tre variablene beskytter IceCast-serverens monteringspunkt. Til slutt, nederst i icecast.xmlfilen bør vi se en sikkerhetsdel som er kommentert ut. Vi bør fjerne åpningssymbolene <-- og avsluttende --> rundt sikkerhetsparagrafen . Når icecast.xmlfilen er endret, lagrer du filen.
Når konfigurasjonsfilen er redigert, ønsker vi å aktivere logging. For å gjøre dette, kjør følgende kommandoer.
mkdir /var/log/icecast
chown nobody:nogroup /var/log/icecast
Til slutt starter vi IceCast-serveren. Dette får serveren til å lytte etter input og innkommende klientforbindelser.
service icecast2 start
IceCast-serveren er oppe og går, så nå må vi gi den noe å spille på. Vårt neste trinn er å installere Ices-kildeklienten. FreeBSD tilbyr for øyeblikket ikke en binær pakke for Ices, så vi må bygge den fra porter. Dette kan gjøres ved å kjøre følgende kommandoer.
portsnap fetch
portsnap extract
cd /usr/ports/audio/ices
make install
make clean
Ices-kildeklienten trenger en brukerkonto og logging. For å opprette en bruker for Ices-programvaren og angi et passord på kontoen, kjør disse kommandoene.
pw groupadd ice
pw useradd ices -g ice -m
passwd ices
Med brukeren opprettet, kan vi nå aktivere logging for Ices.
mkdir /var/log/ices
chown ices:ice /var/log/ices
Fra nå av skal vi ikke lenger trenge root-brukertilgang og kan fungere som ices- bruker. Deretter må vi lage to kataloger. En katalog, music, vil inneholde lydfilene som vi skal streame. Den andre katalogen, conf, vil inneholde våre konfigurasjonsfiler.
su ices
cd /home/ices
mkdir music conf
cp /usr/local/share/ices/ices-playlist.xml conf/configuration.xml
Vi har nå en eksempel konfigurasjonsfil på plass. Det er på tide å redigere conf/configuration.xmlfilen slik at den passer til miljøet vårt. De eneste delene av filen vi trenger å endre er nede rundt linje 60. Her må vi oppgi passordet og monteringsstedet vi angir i icecast.xmlfilen. For eksempel, hvis vi setter monteringsnavnet vårt i icecast.xmlfilen til å være /radio.ogg, bør vi endre configuration.xmlfilens monteringsparameter til også å være /radio.ogg. Passordfeltet vårt i configuration.xmlskal samsvare med kildepassordet vi opprettet i icecast.xmlfilen. Når configuration.xmlfilen vår er redigert, må vi lagre endringene.
Med konfigurasjonsfilen på plass, bør neste trinn være å kopiere lydfiler som vi ønsker å streame inn i musickatalogen. Alle lydfilene skal være i .oggformat, da IceCast ikke vil håndtere .mp3filer med standardinnstillingene. Når alle lydfilene vi ønsker å streame er i musickatalogen, må vi lage en spilleliste. En spilleliste er en ren tekstfil med en liste over musikken vi ønsker å streame. Vi kan enkelt lage en spilleliste med følgende kommandoer.
cd /home/ices/conf
ls -d ../music/*.ogg > playlist.txt
Lydfilene spilles av i den rekkefølgen de vises i playlist.txtfilen. Filen kan redigeres i et hvilket som helst tekstredigeringsprogram for å justere rekkefølgen på streaming-lyden.
Alt vi trenger å gjøre for å begynne å streame lydfilene våre er å kjøre denne kommandoen.
ices configuration.xml
Sidenotat: Ofte vil vi kanskje kjøre Ices-kildeklienten og deretter logge ut og gjøre noe annet. I så fall, jeg liker å kjøre Ices innenfra en skjerm sesjon. Her er et eksempel på hvordan du kjører is med skjerm.
screen
cd /home/ices/conf
ices configuration.xml
Trykk deretter Ctrl + A og trykk på D- tasten. Det vil koble fra skjermøkten og tillate oss å logge ut mens Ices spiller av lyd i bakgrunnen. Senere kan vi stoppe Ices ved å logge på og kjøre:
screen -r
killall ices
exit
Vi kan nå koble til serveren vår på port 8000 i en nettleser for å lytte til lydstrømmen vår. URL-en vil se slik ut http://myservername:8000. Denne adressen kan gjøres offentlig tilgjengelig hvis du vil la andre lytte til strømmen.
Tidligere nevnte jeg at IceCast spiller av .oggfiler og ikke .mp3. Dette er ganske enkelt å overvinne på FreeBSD. Som root-bruker kan vi installere et konverteringsverktøy, kalt sox , som vil konvertere .mp3filene våre til .oggfiler. Forutsatt at alle .mp3filene våre er i /home/ices/musickatalogen, kan vi installere sox og utføre en konvertering som følger:
pkg install sox
cd /home/ices/music
for i in *.mp3; do sox ./"$i" ./"$i".ogg; done
Vi kan deretter oppdatere spillelisten vår ved å bruke:
cd ../conf
ls -d ../music/*.ogg > playlist.txt
Vær oppmerksom på at lydstrømming kan være båndbreddekrevende. En eller to klienter som lytter til radiostasjonen vår vil ikke kreve mye båndbredde, men 50 eller flere klienter kan presse en server over den tildelte månedlige båndbredden. Det er en god idé å aktivere båndbreddetak på strømmeserveren for å unngå uventede økonomiske kostnader.