Uberspace – Prosody 0.9.8 => 0.9.10

36
8855
E1N7E / Pixabay

Wie ich meinen XMPP-Server auf Uberspace eingerichtet habe, wurde ich im Artikel „XMPP-Server auf Uberspace mit vorhandenem WoSign-Zertifikat installieren“ bereits erläutert. Nun wagte ich mich daran Prosody von Version 0.9.8 auf die aktuelle 0.9.10 zu schieben. Hierbei war die Gesamt-Anleitung auf pomm.es sehr hilfreich.

Ubernauten, die das Upgrade installieren wollen, brauchen jedoch starke Nerven, da die CPU-Last des Service Lua auf ca. 100% ansteigt. Das hat wieder zur Folge, dass man sich für mindestens 40 Minuten aussperrt. Irgendwann beruhigt sich das Ganze und eine Einwahl ist wieder möglich. Die Kontakte etc. erscheinen dann sehr langsam und zeitversetzt.

Empfehlen würde ich deshalb, das Upgrade am späten Abend durchzuführen und mit den ersten Einwahl-Versuchen bis zum nächsten Tag abzuwarten.

Nun zur Vorgehensweise. Zuerst wurde der Service von Prosody beendet und danach die aktuelle Version Prosody 0.9.10 aus dem Netz geladen.

Da meine alte Beispiel-Config aus irgendwelchen Gründen nicht beschreibbar war, musste dies vorab noch geändert werden.

Im Anschluss habe ich die Beispiel-Config nach ~/etc/prosody/ verschoben.

Dann wurde der Symlink erneut erstellt

und der Service  wieder gestartet.

Die alte Version 0.9.8 konnte anschließend so entfernt werden.

36 Kommentare

  1. Bei mir gab es keinen signifikanten Anstieg der CPU-Last. Alles läuft wie geschmiert. Deine Site befindet sich wahrscheinlich auf irgendeinem Auslaufmodell von Server.

  2. Ah danke für die Rückmeldung! Dachte schon, dass ich mir irgendein Problem eingehandelt hatte, da der Service bei mir zum Anfang auch instabil war…

  3. Hello, fellow uberspacelings… 🙂

    Bin neu in der Familie und spiele gerade mit prosody auf uberspace herum; dabei hänge ich jetzt irgendwie fest… Vielleicht könnt Ihr mir ja helfen?

    Also ich bin der schönen pomm.es/cosmofox Anleitung in weiten Teilen gefolgt,
    (siehe -> https://pomm.es/hosting/Uberspace/prosody.html),
    bekomme jedoch solche Fehlermeldungen ausgegeben:

    LuaSec, das hier augenscheinlich nicht gefunden wird, habe ich aber nach der Anleitung installiert und die Ausgaben von „luarocks list“ bzw. „prosodyctl about“ spiegeln das auch wieder.

    Kennt jemand das Problem?

  4. Hi mo,
    also anhand der Fehlermeldung würde ich erstmal ausschließen, dass es irgend etwas mit deinen Zertifikaten ansich zutun hat. Bist du dir sicher, dass du in dein .bash_profile LUA_PATH und LUA_CPATH korrekt angegeben hast? Hast du die Änderung danach mit source ~/.bash_profile aktiviert bzw. dich neu angemeldet? Was gibt denn „echo $LUA_PATH“ aus?

    • Hallo,
      das ergibt folgende Ausgabe:

    • habe an falscher stelle geantwortet… da oben 0o
      @ intux: wenn ich wüsste wie, würde ich meine comments auch selbst ansehnlich formatieren… 🙂

        • Hallo nochmal,
          danke für dein Angebot, Robert, da komme ich vielleicht auch drauf zurück, aber erstmal möchte ich versuchen, das selbst in den Griff zu bekommen… der Ehrgeiz hat mich gepackt und ich will ja auch was lernen…
          Es eilt nicht, daher kann ich mich da nach Lust und Laune mit beschäftigen…
          Sobald es bei mir läuft werde ich auf jeden Fall berichten!

          • Hab’s denke ich…
            Bei der Installation von luasec via luarocks musste ich explizit die Versionsnummer 0.5.1-1 angeben. Ohne die Angabe wird eine neuere Version installiert, mit der prosody nicht arbeiten kann.

            Also anstatt

            luarocks install luasec –local OPENSSL_DIR=…

            nimmt man

            luarocks install luasec 0.5.1-1 –local OPENSSL_DIR=…

            Hier steht das auch, bzgl. Versionsnummern…
            https://prosody.im/doc/depends#luasec

            Interessant, dass sich nicht schon mehr Leute mit dem Prob gemeldet haben…
            Danke auf jeden Fall für eure Unterstützung!

  5. Ich habe auch mit massiver CPU-Last auf meinem Prosody zu kämpfen. Wo gibt es denn noch mehr Infos bzw. Referenzen zu weiteren Menschen, die mit der CPU-Last von Prosody auf dem Uberspace zu kämpfen haben?

    Mein Prosody läuft auf 100%, beruhight sich aber nicht sondern startet dann irgendwie neu 🙁

    Die Logs sagen mir überhaupt nix, auch nicht mit debug infos.

      • Erst als ich diesen Artikel gestern gesehen habe, bin ich überhaupt auf die Idee gekommen, mal die CPU-Last von Prosody anzugucken.

        Ich habe schon vor einiger Zeit beobachtet, dass die Antwortzeiten auf ein XMPP-Ping kurz nachdem ich mich mit Pidgin einlogge ziemlich lang waren. Das hat sich aber sonst immer beruhigt.

        Dann habe ich neulich Prosody auf 0.9.10 aktualisiert und per svc -du neu gestarrtet – so dachte ich zumindest. Stellte sich heraus, dass Prosody damals gar nicht neu gestartet war, sondern schon kaum reagiert hatte. Nach einem ernsten svc -k dann hat es tatsächlich neu gestartet. In der Zwischenzeit hatte ich noch andere Module aktivieren wollen (und wieder mit svc -du neustarten).

        Nachdem Prosody tatsächlich mal neu gestartet hat, beobachte ich nun diesen sehr verwirrenden Zustand:

        Wenn ich s2s deaktiviere, ist alles cool. Ich kann aber dann nicht mit anderen Servern reden.

        Wenn ich s2s aktiviere und mich mit einem Client einzuloggen versuche, dreht Prosody auf 100% CPU auf und irgendwann sehe ich dann in den debug logs, dass Prosody neu startet und alle Module neu hochfährt. Ohne, dass sich die Prozess-ID ändern würde. Das verwirrt mich total.

        Und das unabhängig ob ich libevent benutze oder nicht.

        Das verwirrende: Ich kann prosody nicht mit svc -t zum stoppen bringen. Ich muss svc -k benutzen, damit Prosody in endlicher Zeit anhält.

        🙁

        • Mittlerweile habe ich noch etwas mit der Config herumgespielt. Libevent ist jetzt deaktiviert.

          Es zeigt sich, dass Prosody jetzt schon seit über einer Stunde läuft und – wenn sich *kein* client verbindet, alles OK zu sein scheint. Solange der Client mit dem Server reden will, dreht letzterer auf 100% auf, woraufhin er kaum noch antworten kann. Dann bekommt der Client ein Timeout und der Server beruhigt sch wieder.
          Auch das IM Observatory von xmpp.net gibt mir ein schönes Resultat für die Sicherheits-Settings, solange der Server klar kommt. Interessanterweise geht die CPU-Last nicht merklich hoch, wenn xmpppoke mein Prosody durchtestet.

          Nur wenn sich dann mein Client verbinden will, dreht Prosody einfach durch. Vielleicht habe ich ja zu viele Kontakte in meinem Roster? Also genügend, dass Prosody eigentlich libevent benutzen müsste, das aber aus Gründen [irgendein Bug irgendwo] nicht geht.

  6. Ich hatte genau das selbe Problem. Zu viele Kontakte würde ich ausschließen ich hatte gerade mal zwei in meiner… Leider konnte ich bisher auch noch nicht ergründen woran es liegt. Es scheint auch kein generelles Problem mit Prosody zu sein, auf einem anderen Server schnurrt Prosody ohne Probleme. Bleiben eigentlich nur irgeend welche Bedingungen in der Uberspace Umgebung die Prosody nicht mag.

  7. Die Lösung des Problems:

    interfaces = {„x.x.x.x“, „x:x:x::x“}

    auf genau die IPv4 und IPv6 adressen setzen, unter denen Prosody (genauer: euer gesamter Uberspace) erreichbar ist. Also die Adressen, die ihr gegebenenfalls auch im DNS hinterlegt habt.

    Sonst versucht Prosody auf *allen* Netzwerk-Interfaces nach Kontakten zu suchen, und die schiere Anzahl der Interfaces war auf meinem Host über 500.

    https://prosody.im/issues/issue/649

Kommentieren Sie den Artikel

Bitte geben Sie Ihren Kommentar ein!
Bitte geben Sie hier Ihren Namen ein