Skip to content

Nextcloud - Upgrade auf Bookworm 12

Angeheftet Verschoben Nextcloud
  • Mein Debian Server mit einer Nextcloud-Installation läuft noch auf Debian 11. Das möchte ich gerne ändern, wie ich aber letzte Woche lernen musste, ist das gar nicht so einfach. Ich war kläglich gescheitert. Warum?

    ce2d1065-185e-4def-b241-59675ab97f8b-grafik.png

    Auf dem Bild sieht man das erste Problem. Die NC Version Nextcloud Hub 3 (25.0.8) läßt sich nicht auf eine höhere Version upgraden wegen der PHP Version. Man müßte als erstes auf eine PHP Version > 8

    Wenn man jetzt so schlau ist wie ich, schraubt man den Debian Server auf Bookworm 12 hoch. Dort ist ja PHP 8.2 enthalten. Man kann aber jetzt nicht die NC Installation upgraden 😞

    Ok, eine recht doofe Situation. Man könnte warten, wenn die Version EOL ist sollte es funktionieren. Voraussichtlich Ende des Jahres (?). Ja aber, man kann ja so schlecht warten 😊

    Ok, ich hatte gelesen, wenn man auf Debian 11 ist, soll man die PHP Version auf 8.1 hochziehen. NC upgraden. Wenn das erledigt ist auf Bookworm 12 hochziehen. Danach sollte man dann wieder aktuell sein.

    Auf gehts

    Wir brauchen mehrere PHP Versionen auf dem Debian 11 Server. Der Maintainer der PHP Debian Packages hat da eine Webseite

    Zur Installation findet man folgendes

    https://packages.sury.org/php/README.txt

    Inhalt der README.txt

    #!/bin/sh
    # To add this repository please do:
    
    if [ "$(whoami)" != "root" ]; then
        SUDO=sudo
    fi
    
    ${SUDO} apt-get update
    ${SUDO} apt-get -y install lsb-release ca-certificates curl
    ${SUDO} curl -sSLo /usr/share/keyrings/deb.sury.org-php.gpg https://packages.sury.org/php/apt.gpg
    ${SUDO} sh -c 'echo "deb [signed-by=/usr/share/keyrings/deb.sury.org-php.gpg] https://packages.sury.org/php/ $(lsb_release -sc) main" > /etc/apt/sources.list.d/php.list'
    ${SUDO} apt-get update
    

    Achtung!

    Und bevor wir jetzt irgendwas machen, sichern wir uns den Stand vor den Änderungen. Da ich die Datenbank auf einem anderen Server habe, muss ich zwei Snapshots machen. Vorher stelle ich die NC Installation in den Maintenance Mode. So unterbinde ich das ungewollte Schreiben in die DB.

    sudo -u www-data php occ maintenance:mode --on
    

    Ausgabe

    root@:/usr/share/nginx/nextcloud# sudo -u www-data php occ maintenance:mode --on
    Maintenance mode enabled
    

    Kontrolle

    6554f1e7-d3f2-4f4a-8303-86ada0a65c0c-grafik.png

    Danach die zwei Snapshots anlegen. Jetzt können wir uns auf der Konsole austoben 🙂

    Installation deb.sury.org

    Wir arbeiten mal die Installationsschritte s.o. ab.

    apt-get update
    apt-get -y install lsb-release ca-certificates curl
    curl -sSLo /usr/share/keyrings/deb.sury.org-php.gpg https://packages.sury.org/php/apt.gpg
    sh -c 'echo "deb [signed-by=/usr/share/keyrings/deb.sury.org-php.gpg] https://packages.sury.org/php/ $(lsb_release -sc) main" > /etc/apt/sources.list.d/php.list'
    apt-get update
    

    Folgendes Problem taucht jetzt auf, man ist Systemweit jetzt auf php8.2. Das ist nicht das was ich wollte 😞

    Mit

    update-alternatives --query php
    

    kann man sich anzeigen lassen, welche PHP Versionen installiert sind und welche systemweit aktiv ist. Ausgabe (nach der Umstellung auf php8.1 !)

    root@webserver1-4gb-nbg1-1:~# update-alternatives --query php
    Name: php
    Link: /usr/bin/php
    Slaves:
     php.1.gz /usr/share/man/man1/php.1.gz
    Status: manual
    Best: /usr/bin/php8.2
    Value: /usr/bin/php8.1
    
    Alternative: /usr/bin/php7.4
    Priority: 74
    Slaves:
     php.1.gz /usr/share/man/man1/php7.4.1.gz
    
    Alternative: /usr/bin/php8.1
    Priority: 81
    Slaves:
     php.1.gz /usr/share/man/man1/php8.1.1.gz
    
    Alternative: /usr/bin/php8.2
    Priority: 82
    Slaves:
     php.1.gz /usr/share/man/man1/php8.2.1.gz
    

    Ganz oben sieht man welche aktuellste Version installiert ist und welche eingestellt ist. Umschalten kann man das mit

    sudo update-alternatives --set php /usr/bin/php8.1
    

    Aber dafür muss 8.1 auch erst mal installiert sein. Hier meine Pakete, die ich so brauche.

    Installation PHP 8.1

    apt install php8.1-common php8.1-mysql php8.1-opcache php8.1-readline php8.1-xml php8.1-xsl php8.1-zip
    apt install php8.1-cli php8.1-curl php8.1-gd php8.1-intl php8.1-mbstring php8.1-redis
    apt install php8.1-bcmath php8.1-gmp php8.1-imagick
    apt install php8.1-fpm
    

    Wir testen mal

    root@:~# php -v
    PHP 8.1.20 (cli) (built: Jun  9 2023 07:42:54) (NTS)
    Copyright (c) The PHP Group
    Zend Engine v4.1.20, Copyright (c) Zend Technologies
        with Zend OPcache v8.1.20, Copyright (c), by Zend Technologies
    

    Erledigt. PHP 8.1 installiert.

    Nur NC auf PHP 8.1 laufen lassen.

    Der phpx.x-fpm Handler gibt vor, welche PHP Version die Webseite benutzt. Da ja überall php7.4-fpm.sock eingestellt ist, würde NC auch wieder nur mit der 7.4 starten. Ich möchte aber, das es mit der 8.1 startet.

    In der NGINX Konfiguration findet man folgendes.

    /etc/nginx/conf.d/nextcloud.conf

    Die entscheidenden Zeilen

    ### Nextcloud
    upstream php-handler {
            server 127.0.0.1:9000;
            server unix:/var/run/php/php7.4-fpm.sock;
    }
    

    Ändern in

    ### Nextcloud
    upstream php-handler {
            server 127.0.0.1:9000;
            server unix:/var/run/php/php8.1-fpm.sock;
    }
    

    FPM Dienst neustarten

    systemctl restart php8.1-fpm
    systemctl status php8.1-fpm
    systemctl restart nginx
    

    NC testen auf PHP 8.1

    Den Maintenance Mode wieder beenden.

    sudo -u www-data php occ maintenance:mode --off
    

    Den Befehl muss man übrigens im Ordner

    /usr/share/nginx/nextcloud/
    

    eingeben. Kann je nach Installation anders aussehen. Wenn ihr es nicht wisst, schaut in der NGINX oder der Apache2 Konfiguration nach. z.B.

           # Path to the root of your installation
           root /usr/share/nginx/nextcloud/;
    

    Ok, dann den Webbrowser aufrufen und die NC Installation testen! Im Backend die PHP Version kontrollieren.

    485f1610-312a-4644-8e8d-bc111c0098f6-grafik.png

    Ok, die PHP Warnung ist weg. Die anderen Warnungen ignorieren wir mal, weil wir ja sowieso nicht lange auf der 8.1 bleiben wollen. Debian Bookworm nutzt ja 8.2.

    Danach habe ich alle Upgrades von NC durchgeführt und bin jetzt auf Nextcloud Hub 5 (27.0.0)

    860561ca-dfef-47ff-bfe9-012b94e2cfe0-grafik.png

    Jetzt geht es an den Schritt den Server von Debian Bullseye 11 auf Debian Bookworm 12 upzugraden.

    1. Als erstes entferne ich die Fremdquelle von PHP

      rm /etc/apt/sources.list.d/php.list

    2. Schauen ob alles aktuell ist

      apt update

    3. Sources Listen anpassen

    4. Wenn alles aktualisiert ist, die Kiste durchstarten.

    5. Danach müssen die ganzen PHP-Pakete wieder installiert werden, weil wir ja jetzt auf php8.2 sind und dafür nichts installeirt ist. Ich hatte aber (erwartet) Versionskonflikte. Also

      apt remove php8.*

    Danach war kein PHP mehr installiert. Pakete installieren.

    apt install php8.2-common
    apt install php8.2-mysql
    apt install php8.2-opache
    apt install php8.2-opcache
    apt install php8.2-readline
    apt install php8.2-xml
    apt install php8.2-xsl
    apt install php8.2-zip
    apt install php8.2-cli
    apt install php8.2-curl
    apt install php8.2-gd
    apt install php8.2-intl
    apt install php8.2-mbstring
    apt install php8.2-redis
    apt install php8.2-bcmath
    apt install php8.2-gmp
    apt install php8.2-imagick
    apt install php-pear
    apt install php8.2-fpm
    systemctl status php8.2-fpm
    

    Danach wieder die NGINX Konfiguration bearbeiten

    /etc/nginx/conf.d/nextcloud.conf

    Die entscheidenden Zeilen

    ### Nextcloud
    upstream php-handler {
            server 127.0.0.1:9000;
            server unix:/var/run/php/php8.2-fpm.sock;
    }
    

    Alles durchstarten

    systemctl restart php8.2-fpm
    systemctl restart nginx
    

    Nun sollte der Debian Bookworm 12 Server mit der php8.2 und der aktuellsten Nextcloud Installation laufen. 🤓

    Zeitaufwand bei mir, ca. drei Stunden mit kurzen ☕ Pausen 🙂

  • FrankMF FrankM verschob dieses Thema von Privat am
  • FrankMF FrankM hat dieses Thema am angepinnt
  • FrankMF FrankM hat am auf dieses Thema verwiesen
  • FrankMF FrankM hat am auf dieses Thema verwiesen

  • Ansible - Hetzner Server erstellen

    Verschoben Ansible
    1
    0 Stimmen
    1 Beiträge
    246 Aufrufe
    Niemand hat geantwortet
  • Debian 13 - Trixie

    Linux
    1
    0 Stimmen
    1 Beiträge
    149 Aufrufe
    Niemand hat geantwortet
  • Star64 - Bootvorgang

    Hardware
    1
    0 Stimmen
    1 Beiträge
    82 Aufrufe
    Niemand hat geantwortet
  • Konsolentext in Englisch

    Linux
    1
    0 Stimmen
    1 Beiträge
    53 Aufrufe
    Niemand hat geantwortet
  • checkmk - Rest-Server überwachen

    Verschoben checkmk
    1
    0 Stimmen
    1 Beiträge
    454 Aufrufe
    Niemand hat geantwortet
  • OpenWRT - Zonen

    Verschoben OpenWRT & Ubiquiti ER-X
    2
    0 Stimmen
    2 Beiträge
    540 Aufrufe
    FrankMF

    Es ist was heller geworden 🙂

    7b86e97c-31a5-44b6-809f-25d9d1c2ee4a-image.png

    Die besagte Forward Regel

    Zonen.png

    Diese Forward Regel zieht erst dann, wenn es mehrere Interfaces in einer Zone gibt. Aus der Doku

    INPUT rules for a zone describe what happens to traffic trying to reach the router itself through an interface in that zone. OUTPUT rules for a zone describe what happens to traffic originating from the router itself going through an interface in that zone. FORWARD rules for a zone describe what happens to traffic passing between different interfaces belonging in the same zone.

    Das heisst nun, das ein Forwarding zwischen zwei Zonen immer eine spezifische Regel unter Traffic Rules benötigt.

    Forwarding between zones always requires a specific rule.

    Somit ist ein Forwarding zwischen zwei Zonen in den Standard Einstellungen nicht erlaubt. Das kann ich hier auch so bestätigen. Das ist ja auch das was ich mit meiner "DMZ"-Zone erreichen möchte. Kein Zugriff auf LAN.

    Unter Zone ⇒ Forwardings kann man jetzt sehen, das das Forwarding von LAN in Richtung WAN und DMZ erlaubt ist. WAN ist logisch, sonst komme ich ja nicht ins Internet. DMZ habe ich eingestellt, damit ich auch Teilnehmer im DMZ Netz erreichen kann, wenn ich da mal ran muss.

    8a548c29-8bc5-4074-8099-66460bcea9a8-image.png

    Stelle ich das jetzt so ein.

    dca8b393-f613-4cab-a377-ffbc2bb8ddf5-image.png

    Dann kann ich von der DMZ Zone aus das LAN erreichen. Aha, so langsam verstehe ich 😉

    Quelle: https://forum.openwrt.org/t/firewall-zones-and-settings/84369

  • Ubuntu 20.04 Focal - Einrichtung

    Linux
    16
    0 Stimmen
    16 Beiträge
    2k Aufrufe
    FrankMF

    @reiner-zufall sagte in Ubuntu 20.04 Focal - Einrichtung:

    auto-save-session

    Interessant. Bitte poste, wenn Du was findest.

  • ACER und der UEFI-Booteintrag!

    Linux
    1
    0 Stimmen
    1 Beiträge
    219 Aufrufe
    Niemand hat geantwortet