Wiki-Quellcode von Nextcloud Upgrade

Version 10.1 von Tom Altenbrunn am 2024/11/06 11:29

Zeige letzte Bearbeiter
1 {{toc/}}
2
3 ----
4
5 Die Ubuntu-Basis der Nextcloud unter LD2.0 benötigt eine aktuellere Version als die derzeit genutzte Version **16.0.4** (Xenial Xerus), damit neuere Nextcloud-und PHP-Versionen installiert werden können. Im Nachfolgenden wird zunächst die Basis des **nextcloud-g1** Containers auf Version **22.04.5** (Jammy) angehoben und anschließend die Komponenten Nextcloud, sowie PHP aktualisiert.
6
7
8 = Server aktualisieren =
9
10 Zunächst den Server mit den aktuellsten Updates versorgen und die aktuelle Puppet-Version 1.6.X installieren.
11
12 {{code language="bash"}}
13 root@ldhost:~ # ssh puppeteer
14 root@puppeteer:~ # ldupdate
15 {{/code}}
16
17 Im Anschluss wie gewohnt mehrere pruns im **ldhost **durchlaufen lassen und ein ldupdate im **logosrv **durchführen. Danach noch 2 x gprun im **ldhost**, damit die Updates über alle Container-Instanzen hinweg installiert werden.
18
19 {{code language="bash"}}
20 root@ldhost:~ # prun;prun
21 root@ldhost:~ # ssh logosrv
22
23 root@logosrv:~ # ldupdate
24
25 root@ldhost:~ # gprun;gprun
26 {{/code}}
27
28 = Nextcloud-Containeranpassungen =
29
30 == Nextcloud-Instanz zerstören ==
31
32 Nun wird die alte **nextcloud-g1** Instanz unter der alten Ubuntu-Basis zerstört, damit diese später mit der neuen Ubuntu-Version wieder aufgebaut werden kann.
33
34 (% class="box infomessage" %)
35 (((
36 Die Nextcloud-Benutzerdaten bleiben erhalten, da diese im ldhost im Verzeichnis lxc.data des Containers vorliegen bzw. als externe SMB-Shares eingebunden sind.
37 )))
38
39 {{code language="bash"}}
40 root@puppeteer:~ # puppet-master-remove-client nextcloud-g1
41 {{/code}}
42
43 == Ubuntu-Version des LXC anheben ==
44
45 Im **puppeteer **wird in der Konfigurations-Datei des **ldhost **für den **nextcloud-g1**-Container die Ubuntu-Release-Version auf Jammy gesetzt.
46
47 {{code language="bash"}}
48 root@puppeteer:~ # cd /etc/logodidact/hiera/custom.d/
49 root@puppeteer:/etc/logodidact/hiera/custom.d # vi ldhost.yaml
50 {{/code}}
51
52 {{code language="bash"}}
53 profile::lxc::host:
54 guests:
55 nextcloud-g1:
56 ensure: running
57 release: jammy
58 {{/code}}
59
60 == Upgrade Anpassungen ==
61
62 Während der Dauer des Upgrades ist es vonnöten die korrekte PHP-Version statisch per Nextcloud-Konfiguration mitzugeben.
63
64 {{code language="bash"}}
65 root@puppeteer:~ # cd /etc/logodidact/hiera/custom.d/
66 root@puppeteer:/etc/logodidact/hiera/custom.d # vi nextcloud-g1.yaml
67 {{/code}}
68
69 {{code language="bash"}}
70 php::globals::php_version: '8.1'
71 php::package_prefix: 'php8.1-'
72 ld_base::fixes::php::historic_php_versions:
73 - '8.3'
74 {{/code}}
75
76 Alle Änderungen an den Konfigurationen ins GIT commiten.
77
78 {{code language="bash"}}
79 root@puppeteer:/etc/logodidact/hiera/custom.d # git add .
80 root@puppeteer:/etc/logodidact/hiera/custom.d # git commit -am "KÜRZEL: Temporäre Anpassungen für Nextcloud Upgrade vorgenommen."
81 {{/code}}
82
83
84 == Re-Installation Nextcloud ==
85
86 Zunächst den jeweiligen LXC-Containerdienst im **ldhost **deaktivieren. Dadurch wird der LXC vollständig heruntergefahren.
87
88 {{code language="bash"}}
89 root@ldhost:~ # systemctl stop lxc@nextcloud-g1.service
90 root@ldhost:~ # lxc-stop -n nextcloud-g1
91
92 {{/code}}
93
94 Zur Überprüfung kann mittels lxc-ls -f der ausgeschaltete Zustand des Containers bestätigt werden.
95
96
97 Danach den ausgeschalteten und nicht mehr benötigten Nextcloud-Container vom Host-System löschen.
98
99 {{code language="bash"}}
100 root@ldhost:~ # lxc-destroy -n nextcloud-g1 -f
101 {{/code}}
102
103 Ein darauf folgender prun baut den Container neu auf unter Berücksichtigung der in den vorangegangen Schritten getätigten Vorgaben.
104
105 {{code language="bash"}}
106 root@ldhost:~ # prun
107 {{/code}}
108
109 (% class="box warningmessage" %)
110 (((
111 **Gegebenenfalls sind je nach Geschwindigkeit des Servers noch weitere pruns notwendig.**
112 )))
113
114 Nachdem der Container vollständig aufgebaut ist, die Nextcloud-Version nach und nach auf die nächsthöheren Versionen 27 und 28 aktualisieren. Ein Upgrade der Anwendung über mehrere Versionen hinweg ist nicht möglich.
115
116
117 {{code language="bash"}}
118 root@nextcloud-g1:~ # apt install --reinstall ld-nextcloud=27.1.9
119
120 root@nextcloud-g1:~ # prun
121
122 root@nextcloud-g1:~ # apt install --reinstall ld-nextcloud=28.0.5
123
124 root@nextcloud-g1:~ # prun
125
126 root@nextcloud-g1:~ # apt upgrade -y
127
128 root@nextcloud-g1:~ # prun
129 {{/code}}
130
131 Damit ist der eigentliche Aktualisierungsvorgang abgeschlossen.
132
133
134 == Upgrade Anpassungen entfernen ==
135
136 Abschließend die gesetzten Upgrade-Anpassungen wieder entfernen und die Änderungen ins GIT commiten.
137
138 {{code language="bash"}}
139 root@puppeteer:~ # cd /etc/logodidact/hiera/custom.d/
140 root@puppeteer:/etc/logodidact/hiera/custom.d # vi nextcloud-g1.yaml
141 {{/code}}
142
143 {{code language="bash"}}
144 root@puppeteer:/etc/logodidact/hiera/custom.d # git add .
145 root@puppeteer:/etc/logodidact/hiera/custom.d # git commit -am "KÜRZEL: Temporäre Anpassungen für Nextcloud Upgrade zurückgesetzt."
146 {{/code}}
147
148 == Abschluss ==
149
150 Im Nextcloud-Container die Änderungen durch prun übernehmen. Dadurch wird ggf. auch eine neuere PHP-Version installiert.
151
152 {{code language="bash"}}
153 root@nextcloud-g1:~ # prun;prun
154 {{/code}}
155
156 [[https:~~/~~/github.com/nextcloud/server/wiki/Releases-and-PHP-versions>>https://github.com/nextcloud/server/wiki/Releases-and-PHP-versions]]