Config icecast2 + darkice

1. Config icecast2 + darkice

Sergio A.S. de Aguiar
ssaguiar

(usa Ubuntu)

Enviado em 21/02/2008 - 12:33h

Pessoal:

Um grande abraço à toda a comunidade.

Estou tentando fazer funcionar um stream de áudio em meu linux, mas não consigo.

Baixei o icecast2, o darkice, assim como o lame e as libs necessárias.
Compilei tudo e instalei.
Ontem, por algum milagre, até funcionou, mas agora parou de capturar o áudio.
Explico:
Uso o aumix para controlar a entrada de áudio pela entrada microfone da placa de som. O áudio aparecenas caixas de som, sem problemas. Se eu uso o mocp para ouvir músicas, funciona também, ou seja, a placa de som funciona e o aumix consegue controlar a entrada do microfone.
Muito bem, os daemons icecast2 e darkice estãop rodando aparentemente sem erros.
Se eu acesso minha máquina, na porta do icecast2 (8100 - foi a que eu usei), usando uma máquina windows, ele apresenta a tela com o ponto de montagem do áudio. Quando clico no link desta página para ouvir o áudio, é aberto o media player do windows e ele começa a receber o stream mas não tem áudio (na verdade ele conecta, mas não diz nada que está buferizando).

abaixo, meus arquivos de configuração:

icecast.xml:

<icecast>
<limits>
<clients>100</clients>
<sources>2</sources>
<threadpool>5</threadpool>
<queue-size>524288</queue-size>
<client-timeout>30</client-timeout>
<header-timeout>15</header-timeout>
<source-timeout>10</source-timeout>
<!-- If enabled, this will provide a burst of data when a client
first connects, thereby significantly reducing the startup
time for listeners that do substantial buffering. However,
it also significantly increases latency between the source
client and listening client. For low-latency setups, you
might want to disable this. -->
<burst-on-connect>1</burst-on-connect>
<!-- same as burst-on-connect, but this allows for being more
specific on how much to burst. Most people won't need to
change from the default 64k. Applies to all mountpoints -->
<burst-size>65535</burst-size>
</limits>

<authentication>
<!-- Sources log in with username 'source' -->
<source-password>senha</source-password>
<!-- Relays log in username 'relay' -->
<relay-password>senha</relay-password>

<!-- Admin logs in with the username given below -->
<admin-user>admin</admin-user>
<admin-password>senha</admin-password>
</authentication>

<!-- Uncomment this if you want directory listings -->
<!--
<directory>
<yp-url-timeout>15</yp-url-timeout>
<yp-url>http://dir.xiph.org/cgi-bin/yp-cgi</yp-url>
</directory>
-->

<!-- This is the hostname other people will use to connect to your server.
It affects mainly the urls generated by Icecast for playlists and yp
listings. -->

#<hostname>localhost</hostname>
<hostname>10.1.1.20</hostname>

<!-- You can use these two if you only want a single listener -->
<port>8100</port>
<!--<bind-address>127.0.0.1</bind-address>-->

<!-- You may have multiple <listener> elements -->

<listen-socket>
<!-- <port>8100</port> -->
<!-- <bind-address>127.0.0.1</bind-address> -->
</listen-socket>

<!--
<listen-socket>
<port>8001</port>
</listen-socket>
-->

<!--<master-server>127.0.0.1</master-server>-->
<!--<master-server-port>8001</master-server-port>-->
<!--<master-update-interval>120</master-update-interval>-->
<!--<master-password>hackme</master-password>-->

<!-- setting this makes all relays on-demand unless overridden, this is
useful for master relays which do not have <relay> definitions here.
The default is 0 -->
<!--<relays-on-demand>1</relays-on-demand>-->

<!--
<relay>
<server>127.0.0.1</server>
<port>8001</port>
<mount>/example.ogg</mount>
<local-mount>/different.ogg</local-mount>
<on-demand>0</on-demand>

<relay-shoutcast-metadata>0</relay-shoutcast-metadata>
</relay>
-->

<!-- Only define a <mount> section if you want to use advanced options,
like alternative usernames or passwords
<mount>
<mount-name>/example-complex.ogg</mount-name>

<username>othersource</username>
<password>hackmemore</password>

<max-listeners>1</max-listeners>
<dump-file>/tmp/dump-example1.ogg</dump-file>
<burst-size>65536</burst-size>
<fallback-mount>/example2.ogg</fallback-mount>
<fallback-override>1</fallback-override>
<fallback-when-full>1</fallback-when-full>
<intro>/example_intro.ogg</intro>
<hidden>1</hidden>
<no-yp>1</no-yp>
<authentication type="htpasswd">
<option name="filename" value="myauth"/>
<option name="allow_duplicate_users" value="0"/>
</authentication>
<on-connect>/home/icecast/bin/stream-start</on-connect>
<on-disconnect>/home/icecast/bin/stream-stop</on-disconnect>
</mount>
-->
<mount>
<mount-name>bombeiros</mount-name>
<password> senha </password>
<max-listeners> 5 </max-listeners>
<burst-size> 65536 </burst-size>
<hidden> 1 </hidden>
<no-yp> 1 </no-yp>
</mount>

<fileserve>1</fileserve>

<!-- set the mountpoint for a shoutcast source to use, the default if not
specified is /stream but you can change it here if an alternative is
wanted or an extension is required
<shoutcast-mount>/live.nsv</shoutcast-mount>
-->

<paths>
<!-- basedir is only used if chroot is enabled -->
<basedir>/usr/share/icecast2</basedir>

<!-- Note that if <chroot> is turned on below, these paths must both
be relative to the new root, not the original root -->
<logdir>/var/log/icecast2</logdir>
<webroot>/usr/share/icecast2/web</webroot>
<adminroot>/usr/share/icecast2/admin</adminroot>
<!-- <pidfile>/usr/share/icecast2/icecast.pid</pidfile> -->

<!-- Aliases: treat requests for 'source' path as being for 'dest' path
May be made specific to a port or bound address using the "port"
and "bind-address" attributes.
-->
<!--
<alias source="/foo" dest="/bar"/>
-->
<!-- Aliases: can also be used for simple redirections as well,
this example will redirect all requests for http://server:port/ to
the status page
-->
<alias source="/" dest="/status.xsl"/>
</paths>

<logging>
<accesslog>access.log</accesslog>
<errorlog>error.log</errorlog>
<!-- <playlistlog>playlist.log</playlistlog> -->
<loglevel>4</loglevel> <!-- 4 Debug, 3 Info, 2 Warn, 1 Error -->
<logsize>10000</logsize> <!-- Max size of a logfile -->
<!-- If logarchive is enabled (1), then when logsize is reached
the logfile will be moved to [error|access|playlist].log.DATESTAMP,
otherwise it will be moved to [error|access|playlist].log.old.
Default is non-archive mode (i.e. overwrite)
-->
<!-- <logarchive>1</logarchive> -->
</logging>

<security>
<chroot>0</chroot>
<!--
<changeowner>
<user>nobody</user>
<group>nogroup</group>
</changeowner>
-->
</security>
</icecast>



Agora, o darkice.cfg:

# sample DarkIce configuration file, edit for your needs before using
# see the darkice.cfg man page for details

# this section describes general aspects of the live streaming session
[general]
duration = 0 # duration of encoding, in seconds. 0 means forever
bufferSecs = 5 # size of internal slip buffer, in seconds
reconnect = yes # reconnect to the server(s) if disconnected

# this section describes the audio input that will be streamed
[input]
device = /dev/dsp # OSS DSP soundcard device for the audio input
sampleRate = 44100 # 22050 # sample rate in Hz. try 11025, 22050 or 44100
bitsPerSample = 16 # bits per sample. try 16
channel = 2 # channels. 1 = mono, 2 = stereo

# this section describes a streaming connection to an IceCast2 server
# there may be up to 8 of these sections, named [icecast2-0] ... [icecast2-7]
# these can be mixed with [icecast-x] and [shoutcast-x] sections
[icecast2-0]
bitrateMode = cbr # iconstant bit rate
format = mp3 # format of the stream: ogg vorbis
bitrate = 128 # bitrate of the stream sent to the server
server = 10.1.1.20
# host name of the server
port = 8100 # port of the IceCast2 server, usually 8000
password = senha # source password to the IceCast2 server
mountPoint = bombeiros # mount point of this stream on the IceCast2 server
name = Bombeiros Florianopolis
# name of the stream
description = Audio dos Bombeiros de Florianopolis
# description of the stream
url = http://10.1.1.20
# URL related to the stream
genre = my own # genre of the stream
public = yes # advertise this stream?

Alguém tem algua sugestão?

Já estou perdendo o resto dos cabelos que me sobram...

Obrigado a todos.

Sérgio


  






Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts