[Icecast] Icecast mount points help

Jordan Erickson jerickson at logicalnetworking.net
Tue Nov 1 22:44:21 UTC 2016


Hi Mark,

Add extensions to all of your mountpoints for the appropriate audio
codec/format you're using.

For example, <mount-name>/test.opus</mount-name> for an Ogg/Opus stream.

Don't forget to add extensions in the <fallback-mount> sections, too.

I didn't look too closely at your config otherwise, that error was
standing out.



Cheers,
Jordan

P.S. Please 'reply-all' so list can get your replies as well :}


---
On 11/01/2016 03:12 PM, Mark wrote:
>    Hi many thanks here is the code
> 
> 
> 
>    <limits>
>        <clients>100</clients>
>        <sources>2</sources>
>        <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>
> 
> <mount>
> <mount-name>/test</mount-name>
>    </mount>
>   <mount>
>        <mount-name>/autodj</mount-name>
>        <hidden>0</hidden>
>   </mount>
>   <mount>
>        <mount-name>/live</mount-name>
>        <fallback-mount>/autodj</fallback-mount>
>        <fallback-override>1</fallback-override>
>        <hidden>0</hidden>
>   </mount>
>   <mount>
>        <mount-name>/listen</mount-name>
>        <fallback-mount>/live</fallback-mount>
>        <fallback-override>1</fallback-override>
>        <hidden>0</hidden>
>   </mount>
> 
> <!-- 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>
>    -->
> 
>    <!-- You may have multiple <listener> elements -->
>    <listen-socket>
>        <port>8000</port>
>        <!-- <bind-address>127.0.0.1</bind-address> -->
>        <!-- <shoutcast-mount>/stream</shoutcast-mount> -->
>    </listen-socket>
>    <!--
>    <listen-socket>
>        <port>8080</port>
>    </listen-socket>
>    -->
>    <!--
>    <listen-socket>
>        <port>8443</port>
>        <ssl>1</ssl>s
>    </listen-socket>
>    -->
> 
> 
>    <!-- Global header settings
>         Headers defined here will be returned for every HTTP request to
> Icecast.
> 
>         The ACAO header makes Icecast public content/API by default
>         This will make streams easier embeddable (some HTML5
> functionality needs it).
>         Also it allows direct access to e.g. /status-json.xsl from other
> sites.
>         If you don't want this, comment out the following line or read
> up on CORS.
>    -->
>    <http-headers>
>        <header name="Access-Control-Allow-Origin" value="*" />
>    </http-headers>
> 
> 
>    <!-- Relaying
>         You don't need this if you only have one server.
>         Please refer to the config for a detailed explanation.
>    -->
>    <!--<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>8080</port>
>        <mount>/example.ogg</mount>
>        <local-mount>/different.ogg</local-mount>
>        <on-demand>0</on-demand>
> 
>        <relay-shoutcast-metadata>0</relay-shoutcast-metadata>
>    </relay>
>    -->
> 
> 
>    <!-- Mountpoints
>         Only define <mount> sections if you want to use advanced options,
>         like alternative usernames or passwords
>    -->
> 
>    <!-- Default settings for all mounts that don't have a specific
> <mount type="normal">.
>    -->
>    <!--    <mount type="default">
>        <public>0</public>
>        <intro>/server-wide-intro.ogg</intro>
>        <max-listener-duration>3600</max-listener-duration>
>        <authentication type="url">
>                <option name="mount_add"
> value="http://auth.example.org/stream_start.php"/>
>        </authentication>
>        <http-headers>
>                <header name="foo" value="bar" />
>        </http-headers>
>    </mount>
>    -->
> 
>    <!-- Normal mounts -->
>    <!--
>    <mount type="normal">
>        <mount-name>/example-complex.ogg</mount-name>
> 
>        <username>othersource</username>
>        <password>tafnuk2004</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>
>        <public>1</public>
>        <authentication type="htpasswd">
>                <option name="filename" value="myauth"/>
>                <option name="allow_duplicate_users" value="0"/>
>        </authentication>
>        <http-headers>
>                <header name="Access-Control-Allow-Origin"
> value="http://webplayer.example.org" />
>                <header name="baz" value="quux" />
>        </http-headers>
>        <on-connect>/home/icecast/bin/stream-start</on-connect>
>        <on-disconnect>/home/icecast/bin/stream-stop</on-disconnect>
>    </mount>
>    -->
> 
>    <!--
>    <mount type="normal">
>        <mount-name>/auth_example.ogg</mount-name>
>        <authentication type="url">
>            <option name="mount_add"
> value="http://myauthserver.net/notify_mount.php"/>
>            <option name="mount_remove"
> value="http://myauthserver.net/notify_mount.php"/>
>            <option name="listener_add"
> value="http://myauthserver.net/notify_listener.php"/>
>            <option name="listener_remove"
> value="http://myauthserver.net/notify_listener.php"/>
>            <option name="headers"         value="x-pragma,x-token"/>
>            <option name="header_prefix"   value="ClientHeader."/>
>        </authentication>
>    </mount>
>    -->
> 
>    <fileserve>1</fileserve>
> 
>    <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" destination="/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="/" destination="/status.xsl"/>
>        <!-- The certificate file needs to contain both public and
> private part.
>             Both should be PEM encoded.
>        <ssl-certificate>/usr/share/icecast2/icecast.pem</ssl-certificate>
>        -->
>    </paths>
> 
>    <logging>
>        <accesslog>access.log</accesslog>
>        <errorlog>error.log</errorlog>
>        <!-- <playlistlog>playlist.log</playlistlog> -->
>        <loglevel>3</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>
> 
> 
> 
> -----Original Message----- From: Jordan Erickson
> Sent: Tuesday, November 1, 2016 7:26 PM
> To: Mark ; Icecast streaming server user discussions
> Subject: Re: [Icecast] Icecast mount points help
> 
> Hi Mark, can you please post <mount> configuration (omit sensitive info
> if needed)? Could be a few different things.
> 
> 
> Cheers,
> Jordan
> 
> On 11/01/2016 12:20 PM, Mark wrote:
>>    Hi i have a problem
>> if a DJ is streaming no one can connect  to the test mount
>> my setup is as follows
>> i have a pc streaming 24 hours a day 7 days a week with mount point
>> autodj
>> then all the djs are connected using live
>> then i have another  mount called test
>> if no one is streaming live then djs can connect to the test mount but
>> if any one is connected live no one can use the test mount
>> can any one tell me where i am going wrong
>> Mark.
>>
>>
>> _______________________________________________
>> Icecast mailing list
>> Icecast at xiph.org
>> http://lists.xiph.org/mailman/listinfo/icecast
>>
> 

-- 
Jordan Erickson (PGP: 0x78DD41CB)
Logical Networking Solutions, 707-636-5678





More information about the Icecast mailing list