MPD/Icecast: Linux-Clients spielen nur bis zum Ende des Liedes

Dieses Thema im Forum "Anwendungen" wurde erstellt von chackie-lee, 07.09.2009.

  1. #1 chackie-lee, 07.09.2009
    chackie-lee

    chackie-lee Mitglied

    Dabei seit:
    26.11.2007
    Beiträge:
    25
    Zustimmungen:
    0
    Hallo zusammen,

    ich habe gerade meinen mpd-Player mit Icecast verheiratet und das Streamen der Musik funktioniert ansich prima.
    Naja zumindest solange der Stream-Client auf einer Windows-Kiste läuft.

    Lasse ich z.B. Kaffeine, vlc oder Amarok den Stream auf einem Ubuntu 9.04-System (mit 2 Systemen getestet) abspielen, dann schaffen es die Clients immer nur bis zum Ende eines Liedes bzw. sie schaffen es es nicht ein neues Lied abzuspielen. Die Zeit in den Playern bleibt dann immer stehen und auch die Liedanzeige wird nicht aktualisiert.

    VLC und Winamp funktionieren hingegen auf Windows (Vista) mit dem Stream wunderbar.

    Ach ja, am Netzwerk kann es wohl nicht liegen. Das Problem tritt auch auf, wenn ich einen Client über localhost auf dem Stream-Server laufen lasse, der hat dieselben Probleme :hilfe2:
    Der Stream ist übrigens ein Ogg-Stream.

    Bin schon jegliche Einstellungen im mpd und im icecast durchgegangen. Allerdings ohne interessante Optionen zu finden.

    Hat jemand eine Idee wo dran es liegen könnte? Stehe gerade ziemlich auf dem Schlauch und Mr. Suchmaschine schweigt sich zu dem Thema auch aus.
     
  2. Anzeige

    Schau dir mal diese Kategorie an. Dort findest du bestimmt etwas.
    Registrieren bzw. einloggen, um diese und auch andere Anzeigen zu deaktivieren
  3. SiS

    SiS Routinier

    Dabei seit:
    12.02.2007
    Beiträge:
    318
    Zustimmungen:
    0
    Ohne config wird die Fehlersucher nicht einfacher...
     
  4. #3 chackie-lee, 08.09.2009
    Zuletzt bearbeitet: 08.09.2009
    chackie-lee

    chackie-lee Mitglied

    Dabei seit:
    26.11.2007
    Beiträge:
    25
    Zustimmungen:
    0
    Hello again,

    natürlich sind die configs hilfreich, aber wie schon geschrieben laufen die Server Anwendungen einwandfrei und es gibt nur Problem mit Linux-Clients.
    Es würde mich wundern, wenn es nur eine Kleinigkeit in den Configs ist.
    Denke da eher an architektur-bedingte Unterschiede der beiden Systeme.

    Kann es auch eine Timeout-Geschichte sein??
    Der mpd connectet sich zum Icecast ja nur, wenn er was spielen möchte.
    Evtl. unterbricht der mpd kurz die Connection bzw. setzt diese zurück und baut sich dann beim nächsten Lied neu auf.
    Und damit kämen dann die Linux-Clients nicht zurecht, da die Connection beendet wurde.
    Allerdings machen die Windows-Clients keine Mucken und leider hat die Manipulation diverser Timing-Parameter in den Optionen keine Einfluss. Naja, nur mal so als Denkanstoss :think:

    Aber auf jeden Fall sind hier die Configs:


    Code:
    cat /etc/icecast2/icecast.xml
    <icecast>
        <limits>
            <clients>10</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>XXXX</source-password>
            <!-- Relays log in username 'relay' -->
            <relay-password>XXXX</relay-password>
    
            <!-- Admin logs in with the username given below -->
            <admin-user>XXXX</admin-user>
            <admin-password>XXXX</admin-password>
        </authentication>
    
        <!-- 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>
        -->
    
        <!-- 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>
    
        <!-- 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>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>/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"/>
            </authentication>
        </mount>
    
        -->
        <!--
        <mount>
            <mount-name>/mpd</mount-name>
            <authentication type="htpasswd">
                    <option name="filename" value="myauth"/>
                    <option name="allow_duplicate_users" value="0"/>
            </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" 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>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>
    
    Code:
    sudo cat /etc/mpd.conf
    # An example configuration file for MPD
    # See the mpd.conf man page for a more detailed description of each parameter.
    
    ######################## REQUIRED PATHS ########################
    # You can put symlinks in here, if you like. Make sure that
    # the user that mpd runs as (see the 'user' config parameter)
    # can read the files in this directory.
    music_directory         "/home/daniel/Musik"
    playlist_directory      "/home/daniel/playlists"
    db_file                 "/var/lib/mpd/tag_cache"
    log_file                "/var/log/mpd/mpd.log"
    error_file              "/var/log/mpd/errors.log"
    ################################################################
    
    
    ######################## OPTIONAL PATHS ########################
    #
    # If you wish to use mpd --kill to stop MPD, then you must
    # specify a file here in which to store MPD's process ID.
    #
    pid_file                "/var/run/mpd/pid"
    #
    # If specified, MPD will save its current state (playlist,
    # current song, playing/paused, etc.) at exit.  This will be
    # used to restore the session the next time it is run.
    #
    state_file              "/var/lib/mpd/state"
    #
    ################################################################
    
    
    ######################## DAEMON OPTIONS ########################
    #
    # If started as root, MPD will drop root privileges and run as
    # this user instead.  Otherwise, MPD will run as the user it was
    # started by.  If left unspecified, MPD will not drop root
    # privileges at all (not recommended).
    #
    user                            "mpd"
    #
    # The address and port to listen on.
    #
    bind_to_address                 "127.0.0.1"
    port                            "6600"
    #
    # If the address is a path, then a UNIX domain socket will be
    # created instead of listening on a TCP port.
    #
    #bind_to_address                 "/var/run/mpd/sock"
    #
    # Controls the amount of information that is logged.  Can be
    # "default", "secure", or "verbose".
    #
    #log_level                       "default"
    #
    ################################################################
    
    
    ########################### ZEROCONF ###########################
    #
    # If yes, service information will be published with Zeroconf.
    #
    #zeroconf_enabled                "yes"
    #
    # The service name to publish.  This name should be unique on
    # your local network.
    #
    #zeroconf_name                   "Music Player"
    #
    ################################################################
    
    
    ########################## PERMISSIONS #########################
    #
    # MPD can require that users specify a password before using it.
    # You may specify one ore more here, along with what users who
    # log in with that password are allowed to do.
    #
    #password                        "password@read,add,control,admin"
    #
    # Specifies what permissions a user who has not logged in with a
    # password has.  By default, all users have full access to MPD
    # if no password is specified above, or no access if one or
    # more passwords are specified.
    #
    #default_permissions             "read,add,control,admin"
    #
    ################################################################
    
    
    ########################## AUDIO OUTPUT ########################
    #
    # MPD supports many audio output types, as well as playing
    # through multiple audio outputs at the same time.  You can
    # specify one or more here.  If you don't specify any, MPD will
    # automatically scan for a usable audio output.
    #
    # See <http://mpd.wikia.com/wiki/Configuration#Audio_Outputs>
    # for examples of other audio outputs.
    #
    # An example of an ALSA output:
    #
    #audio_output {
    #        type                    "alsa"
    #        name                    "My ALSA Device"
    #        device                  "hw:0,0"     # optional
    #        format                  "44100:16:2" # optional
    #}
    #
    # An example of an OSS output:
    #
    #audio_output {
    #        type                    "oss"
    #        name                    "My OSS Device"
    #        device                  "/dev/dsp"   # optional
    #        format                  "44100:16:2" # optional
    #}
    #
    # An example of a shout output (for streaming to Icecast):
    #
    audio_output {
            type                    "shout"
            encoding                "ogg"                   # optional
            name                    "Dan's big music hall"
            host                    "localhost"
            port                    "8000"
            mount                   "/mpd"
            password                "XXXXX"
            quality                 "5.0"
    #        bitrate                 "128"
            format                  "44100:16:1"
            user                    "source"                # optional
            description             "Nothing without music." # optional
            genre                   "Everything"                  # optional
            public                  "no"                    # optional
            timeout                 "10"                     # optional
    #}
    #
    # An example of a null output (for no audio output):
    #
    #audio_output {
    #        type                    "null"
    #        name                    "My Null Output"
    #}
    #
    # Force all decoded audio to be converted to this format before
    # being passed to the audio outputs.
    #
    #audio_output_format             "44100:16:2"
    #
    # If MPD has been compiled with libsamplerate support, this
    # specifies the sample rate converter to use.  Possible
    # values can be found in the mpd.conf man page or the
    # libsamplerate documentation.
    #
    #samplerate_converter            "Fastest Sinc Interpolator"
    #
    ################################################################
    
    
    ############################# MIXER ############################
    #
    # MPD needs to know what mixer settings to change when you
    # adjust the volume.  If you don't specify one here, MPD will
    # pick one based on which ones it was compiled with support for.
    #
    # An example for controlling an ALSA mixer:
    #
    mixer_type                      "alsa"
    mixer_device                    "default"
    mixer_control                   "PCM"
    #
    # An example for controlling an OSS mixer:
    #
    #mixer_type                      "oss"
    #mixer_device                    "/dev/mixer"
    #mixer_control                   "PCM"
    #
    # If you want MPD to adjust the volume of audio sent to the
    # audio outputs, you can tell it to use the software mixer:
    #
    #mixer_type                      "software"
    #
    ################################################################
    
    
    ######################### NORMALIZATION ########################
    #
    # Specifies the type of ReplayGain to use.  Can be "album" or
    # "track".  ReplayGain will not be used if not specified.  See
    # <http://www.replaygain.org> for more details.
    #
    #replaygain                      "album"
    #
    # Sets the pre-amp used for files that have ReplayGain tags.
    #
    #replaygain_preamp               "0"
    #
    # Enable on the fly volume normalization.  This will cause the
    # volume of all songs played to be adjusted so that they sound
    # as though they are of equal loudness.
    #
    volume_normalization            "no"
    #
    ################################################################
    
    
    ########################### BUFFERING ##########################
    #
    # The size of the buffer containing decoded audio.  You probably
    # shouldn't change this.
    #
    #audio_buffer_size               "2048"
    #
    # How much of the buffer to fill before beginning to play.
    # Increase this if you hear skipping when changing songs.
    #
    #buffer_before_play              "10%"
    #
    # Similar options for the HTTP stream buffer.  If you hear
    # skipping while playing HTTP streams, you may wish to increase
    # these.
    #
    #http_buffer_size                "128"
    #http_prebuffer_size             "25%"
    #
    ################################################################
    
    
    ########################### HTTP PROXY #########################
    #
    # Specifies the HTTP proxy to use for playing HTTP streams.
    #
    #http_proxy_host                 "proxy.isp.com"
    #http_proxy_port                 "8080"
    #http_proxy_user                 "user"
    #http_proxy_password             "password"
    #
    ################################################################
    
    
    ############################# LIMITS ###########################
    #
    # These are various limits to prevent MPD from using too many
    # resources.  You should only change them if they start
    # restricting your usage of MPD.
    #
    #connection_timeout              "60"
    #max_connections                 "5"
    #max_playlist_length             "16384"
    #max_command_list_size           "2048"
    #max_output_buffer_size          "8192"
    #
    ################################################################
    
    
    ###################### CHARACTER ENCODINGS #####################
    #
    # If file or directory names do not display correctly, then you
    # may need to change this.  In most cases it should be either
    # "ISO-8859-1" or "UTF-8".  You must recreate your database
    # after changing this (use mpd --create-db).
    #
    filesystem_charset              "UTF-8"
    #
    # The encoding that ID3v1 tags should be converted from.
    #
    id3v1_encoding                  "UTF-8"
    #
    ################################################################
    
    
    ######################### OTHER OPTIONS ########################
    #
    # Try disabling this if you have MP3s which appear to end
    # abruptly.  If this solves the problem, it is highly
    # recommended that you fix your MP3s with vbrfix (available from
    # <http://www.willwap.co.uk/Programs/vbrfix.php>), at which
    # point you can re-enable support for gapless MP3 playback.
    #
    #gapless_mp3_playback             "yes"
    #
    # Enable this if you wish to use your MPD created playlists in
    # other music players.
    #
    save_absolute_paths_in_playlists "no"
    #
    # A list of tag types that MPD will scan for and make available
    # to clients.
    #
    #metadata_to_use "artist,album,title,track,name,genre,date,composer,performer,disc"
    #
    ################################################################
    
     
  5. Rvg

    Rvg Doppel-As

    Dabei seit:
    11.07.2004
    Beiträge:
    141
    Zustimmungen:
    0
    also hier gehts, mplayer auf ubuntu-(variante) mit mpd/icecast auf arch,
    winamp/foobar2000 auf xp tun genauso

    und bis auf das ich in <hostname> in der icecast.xml nicht localhost stehen hab,
    sehen die configs eigentlich identisch aus
     
  6. #5 chackie-lee, 10.09.2009
    chackie-lee

    chackie-lee Mitglied

    Dabei seit:
    26.11.2007
    Beiträge:
    25
    Zustimmungen:
    0
    Verdammt, das scheint wohl eine längere Sache für das kommende Wochenende zu sein.
    So langsam gehen mir auch die Ideen aus wodrann es liegen könnte.

    Also ich bin für jede noch so doofe (auf den ersten Blick :)) ) Idee offen!!
     
  7. lutoma

    lutoma Möchtegern-Informatiker

    Dabei seit:
    28.01.2009
    Beiträge:
    57
    Zustimmungen:
    0
    Ort:
    Mannheim
    Also ich hab hier auch nen MPD mit Icecast laufen, und Linux user beschweren sich bei mir auch hin und wieder, dass der Stream nach dem Lied aufhört. Das aber auch nur hin und wieder und auch nicht bei jedem Linux-User.
     
  8. Anzeige

    Vielleicht findest du HIER Antworten.
    Registrieren bzw. einloggen, um diese und auch andere Anzeigen zu deaktivieren
Thema:

MPD/Icecast: Linux-Clients spielen nur bis zum Ende des Liedes

Die Seite wird geladen...

MPD/Icecast: Linux-Clients spielen nur bis zum Ende des Liedes - Ähnliche Themen

  1. Client-Management-System opsi 4.0.5 verwaltet erstmals Linux-Clients

    Client-Management-System opsi 4.0.5 verwaltet erstmals Linux-Clients: Die neue Version 4.0.5 des freien Client-Management-Systems opsi der Mainzer uib GmbH kann jetzt erstmals Linux-Clients verwalten. Ursprünglich...