Wiki-Quellcode von Nextcloud Upgrade

Version 11.1 von Tom Altenbrunn am 2024/11/08 08:25

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 Verbinden Sie nun mit dem Container und starten Sie diesen zur Sicherheit neu.
115
116 {{code language="bash"}}
117 root@ldhost:~ # lxc-attach -n nextcloud-g1
118 root@nextcloud-g1:~ # reboot
119 {{/code}}
120
121
122 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.
123
124
125 {{code language="bash"}}
126 root@nextcloud-g1:~ # apt install --reinstall ld-nextcloud=27.1.9
127
128 root@nextcloud-g1:~ # prun
129
130 root@nextcloud-g1:~ # apt install --reinstall ld-nextcloud=28.0.5
131
132 root@nextcloud-g1:~ # prun
133
134 root@nextcloud-g1:~ # apt upgrade -y
135
136 root@nextcloud-g1:~ # prun
137 {{/code}}
138
139 Damit ist der eigentliche Aktualisierungsvorgang abgeschlossen.
140
141
142 == Upgrade Anpassungen entfernen ==
143
144 Abschließend die gesetzten Upgrade-Anpassungen wieder entfernen und die Änderungen ins GIT commiten.
145
146 {{code language="bash"}}
147 root@puppeteer:~ # cd /etc/logodidact/hiera/custom.d/
148 root@puppeteer:/etc/logodidact/hiera/custom.d # vi nextcloud-g1.yaml
149 {{/code}}
150
151 {{code language="bash"}}
152 root@puppeteer:/etc/logodidact/hiera/custom.d # git add .
153 root@puppeteer:/etc/logodidact/hiera/custom.d # git commit -am "KÜRZEL: Temporäre Anpassungen für Nextcloud Upgrade zurückgesetzt."
154 {{/code}}
155
156 == Abschluss ==
157
158 Im Nextcloud-Container die Änderungen durch prun übernehmen. Dadurch wird ggf. auch eine neuere PHP-Version installiert.
159
160 {{code language="bash"}}
161 root@nextcloud-g1:~ # prun;prun
162 {{/code}}
163
164 [[https:~~/~~/github.com/nextcloud/server/wiki/Releases-and-PHP-versions>>https://github.com/nextcloud/server/wiki/Releases-and-PHP-versions]]