Benutzer-Werkzeuge

Webseiten-Werkzeuge


fn2:aktualisierung

Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen RevisionVorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
Nächste ÜberarbeitungBeide Seiten der Revision
fn2:aktualisierung [2020/12/04 12:23] – [Releasezyklus, Patches und Hotfixes für fn2Web] christophfn2:aktualisierung [2020/12/04 15:14] christoph
Zeile 1: Zeile 1:
-====== Dokumentation zum Aktualisierungsprozess von fn2Web ====== +====== Aktualisierungsprozess von fn2Web ======
- +
-===== Aktualisierungsprozess von fn2Web =====+
  
 ==== Versionierung, Releases und Updates für fn2Web ==== ==== Versionierung, Releases und Updates für fn2Web ====
Zeile 10: Zeile 8:
  
 **fn2Web-Version**\\  **fn2Web-Version**\\ 
-Die fn2Web-Version wird nur bei grundlegenden, tiefgreifenden Änderungen im System fortgeführt, was nur sehr selten der Fall sein wird.+Die fn2Web-Version wird nur bei grundlegenden, tiefgreifenden Änderungen im System fortgeführt, was nur sehr selten der Fall ist.
  
 **Releases**\\  **Releases**\\ 
 Releases werden von uns grob zwei Mal im Jahr geplant, zum Jahres-Anfang und im Herbst. Optional können bei Bedarf zusätzliche Releases veröffentlicht werden, z.B. wenn ein schwerer Fehler im System eine zeitnahe Aktualisierung bedingt. Releases beinhalten aufwändigere Erweiterungen und Anforderungen und verlangen häufig das Anpassen von hochschulspezifischen Konfigurationsdateien.  Releases werden von uns grob zwei Mal im Jahr geplant, zum Jahres-Anfang und im Herbst. Optional können bei Bedarf zusätzliche Releases veröffentlicht werden, z.B. wenn ein schwerer Fehler im System eine zeitnahe Aktualisierung bedingt. Releases beinhalten aufwändigere Erweiterungen und Anforderungen und verlangen häufig das Anpassen von hochschulspezifischen Konfigurationsdateien. 
  
-Obwohl ein neues Release so schnell wie möglich eingespielt werden sollte, ist uns bewusst, dass das aufgrund des hohen Test-Aufands nicht immer geht. Daher versorgen wir sowohl das aktuelle, als auch das vorhergehende Release mit Updates.+Obwohl ein neues Release so schnell wie möglich eingespielt werden sollte, ist uns bewusst, dass das aufgrund des hohen Test-Aufands nicht immer möglich ist. Daher versorgen wir sowohl das aktuelle, als auch das vorhergehende Release mit Updates.
  
 {{ :fn2:releasezyklus.png?direct&300 |}} {{ :fn2:releasezyklus.png?direct&300 |}}
  
-Die Termine für Releases und Updates ist absichtlich etwas vage gehalten. Die dadurch erlangte Freiheit ermöglicht es uns zeitnah und agil auf die Bedürfnisse unserer Kunden eingehen zu können.+Die Termine für Releases und Updates sind absichtlich etwas vage gehalten. Die dadurch erlangte Freiheit ermöglicht es uns zeitnah und agil auf die Bedürfnisse unserer Kunden eingehen zu können.
  
 **Updates**\\  **Updates**\\ 
-Updates sind meist kleinere Erweiterungen und dringende Fehlerbehebungen, die von uns zeitnah veröffentlicht werden. Es ist nicht zwingend notwendig fn2Web immer auf dem neuesten Update-Stand zu halten. Dennoch sollten die [[releasenotes:|Releasenotes]] aktiv gelesen werden, da mit Updates auch kritische allgemeine Fehler behoben werden. Eine viel genutzte best practice ist auch im [[http://tickets.ihb-eg.de|Ticketing-System]] die neuesten erledigten Tickets im Auge zu behalten oder, bei Problemen, dort erst ein mal stichpunktartig zu suchen.+Updates sind meist kleinere Erweiterungen und dringende Fehlerbehebungen, die von uns zeitnah veröffentlicht werden. Es ist nicht zwingend notwendigfn2Web immer auf dem neuesten Update-Stand zu halten. Dennoch sollten die [[releasenotes:|Release Notes]] aktiv gelesen werden, da mit Updates auch kritische allgemeine Fehler behoben werden. Eine viel genutzte best practice ist auch im [[http://tickets.ihb-eg.de|Ticketing-System]] die neuesten erledigten Tickets im Auge zu behalten oder, bei Problemen, dort erst ein mal stichpunktartig zu suchen.
  
  
 ==== Releasezyklus für fn2Module ==== ==== Releasezyklus für fn2Module ====
  
-Der Releaseprozess für die fn2Module ändert sich nicht. Neue Versionen, die von Kunden angeforderte Features enthalten, werden nach Fertigstellung bereitgestellt. Die in den neuen Versionen enthaltenen Änderungen sind in den dazugehörigen Release Notes dokumentiert.+Der Releaseprozess für die fn2Module ändert sich nicht. Neue Versionen, die von Kunden angeforderte Features enthalten, werden nach Fertigstellung bereitgestellt. Die in den neuen Versionen enthaltenen Änderungen sind in den dazugehörigen [[releasenotes:|Release Notes]] dokumentiert.
  
 ==== Gegenseitig abhängige Updates von fn2Module und fn2Web ==== ==== Gegenseitig abhängige Updates von fn2Module und fn2Web ====
Zeile 43: Zeile 41:
  
 Bei Rückfragen wenden Sie sich zunächst an die im Skript angegebene Ansprechperson. Sollte ein Problem auftreten, das mehrere User betreffen könnte, eröffnen Sie bitte ein Ticket in dem entsprechenden Bereich SQL-Skripte unseres Ticketing-Systems  Bei Rückfragen wenden Sie sich zunächst an die im Skript angegebene Ansprechperson. Sollte ein Problem auftreten, das mehrere User betreffen könnte, eröffnen Sie bitte ein Ticket in dem entsprechenden Bereich SQL-Skripte unseres Ticketing-Systems 
-===== GIT zum Download der Releases ===== 
  
-GIT ist eine freie Software zur verteilten Versionsverwaltung und kann [[https://git-scm.com/|hier]] für alle gängigen Plattformen heruntergeladen.+===== git zum Download fn2Web-Versionen =====
  
-Eine Übersicht zahlreicher grafischer Oberflächen für GIT gibt es unter [[https://git-scm.com/downloads/guis| hier]]. Die Verwendung einer grafischen Oberfläche ist aber nicht zwingend erforderlich, da alle benötigten Befehle in diesem Wiki beschrieben werde. Wir selbst nutzen neben der Kommandozeile [[https://www.sourcetreeapp.com/|SourceTree von Atlassian]]. Das Programm ist sowohl für Windows als auch für Mac verfügbar.+git ist eine freie Software zur verteilten Versionsverwaltung und kann [[https://git-scm.com/|hier]] für alle gängigen Plattformen heruntergeladen.
  
-Ein Grundlagenbuch ist [[https://git-scm.com/book/de/v1|hier]] frei verfügbar. Einen tieferen Einblick in die Syntax von GIT-Befehlen erhalten Sie in der offiziellen [[https://git-scm.com/doc|Dokumention]].+Eine Übersicht zahlreicher grafischer Oberflächen für git gibt es [[https://git-scm.com/downloads/guis| hier]]. Die Verwendung einer grafischen Oberfläche ist allerdings nicht zwingend erforderlich, da alle benötigten Befehle in diesem Wiki beschrieben werden. Ein Grundlagenbuch ist [[https://git-scm.com/book/de/v1|hier]] frei verfügbar. Ein tieferer Einblick in die Syntax von git-Befehlen kann in der offiziellen [[https://git-scm.com/doc|Dokumention]] erlangt werden.
  
-===== Übersicht über die Zusammenhänge beim neuen Release-Mechanismus =====+fn2Web kann von unserem [[https://gitlab.ihb-eg.de|GitLab-Server]] bezogen werden. Grundsätzlich gibt es zwei Möglichkeiten das fn2Web-Repository herunter zu laden, die im Folgenden beschrieben werden:
  
-{{ :fn2:release_vorgang_git.png?nolink |}}+==== Direkter Download von fn2Web (nicht empfohlen) ==== 
 +Das Repository und auch einzelne Dateien können dirkt über die GitLab-Oberfläche in verschiedenen Formaten gepackt herunter geladen werden. 
 +{{ :fn2:gitlab_downloaddirekt.png?direct |}} 
 +Da hierbei sämtliche Vorteile, die git bietet, ignoriert werden, sollte so nur in Ausnahmefällen vorgegangen werden.
  
 +==== Verknüpfung mit einem lokalen git-Repository (dringend empfohlen) ====
 +Der wesentlich elegantere und ganzheitlichere Weg fn2Web zu beziehen ist ein lokales git-Repository mit dem fn2webapps-Repository auf dem GitLab-Server zu verknüpfen.
  
-===== fn2Web-Releases Verzeichnisstruktur =====+Im Folgenden werden die jeweiligen Konsolen-Befehle benutzt. Es gibt zahlreiche grafische Tools für git, die im Grunde alle das gleiche können, da sie auf eben exakt jene Befehle zurückgreifen. Auf einzelene Tools ein zu gehen würde den Rahmen dieses Wiki-Eintrages sprengen.
  
-Mit dem nachfolgenden Screenshot wird die Verzeichnisstruktur, die man beim Download von fn2Web-Releases erhält, erklärt.+**Ersteinrichtung**\\  
 +Initialisierung (Erstellen) eines lokalen git-Repositories: 
 +  git init 
 +erstellt einen Ordner .git/ im aktuellen Verszeichnis (für fn2Web-Zwecke sollte dieses Verzeichnis leer sein) in dem sich die Verwaltungsdateien für das Repository befinden.
  
-{{ :fn2:fn2web-releases_verzeichnisstruktur.jpg?nolink |}}+Verknüpfen des Repositries mit dem fn2webapps-Repository über eine Remote: 
 +  git remote add fn2web https://gitlab.ihb-eg.de/fn2/fn2webapps.git 
 +erstellt eine Remote mit dem Namen "fn2web" und verknüpft diese mit dem fn2webapps-Repository.
  
-===== Wichtige GIT-Befehle =====+  git fetch fn2web 
 +läd die Informationen zur Remote "fn2web" herunter. Es werden noch keine Dateien erstellt.
  
 +  git checkout -b 2.04.06 fn2web/2.04.06
 +erstellt einen neuen lokalen Branch "2.04.06", verknüpft diesen mit dem Branch 2.04.06 im fn2webapps-Repository und checkt ihn aus, d.h. es werden die tatsächlichen Dateien, wie sie im Branch hinterlegt sind, erstellt. Die ersteinrichtung ist damit abgeschlossen.
  
-==== Zum erstmaligen Download der FN2-Webapps ====+Mit 
 +  git log 
 +kann überprüft werden, auf welchem Stand sich der Branch befindet (genauer gesagt können so die Commits des Branches betrachtet werden).
  
-<code>git clone https://<BENUTZERNAME>:<PASSWORT>@gitlab.ihb-eg.de/fn2/fn2webapps.git</code>+  git remote add -f -t 2.04.06 -m 2.04.06 fn2web https://gitlab.ihb-eg.de/fn2/fn2webapps.git 
 +fasst die 'git remote', 'git fetch' und 'git checkout' Befehle wie sie hier beschrieben wurden zusammen.
  
-Der Befehl "git clone" kopiert die Ablage in einen neu erstellten Ordner und erstellt einen remote-tracking Zweig für jeden Zweig in der originalen Ablage. +**Aktualisierung**\\  
 +Das Aktualisieren des momentan ausgecheckten Branches ist denkbar einfach: 
 +  git pull
  
-Während des Klonens kann mehrfach die folgende Fehlermeldung auftreten: +Soll auf ein neues Release aktualisiert werden, ist dieses im fn2webapps-Repository als ein eigener Branch vorhanden (Branch "2.04.05" ist Release 5Branch "2.04.06" ist Release 6etc.). Es muss lediglich ein  
-<code>error: RETR response: 550 (curl_result = 78http_code = 550sha1 = 98120a75125204713db511227718579caea88aa6)</code> +  git fetch 
-Diese bitte ignorieren und den Klon-Vorgang bis zum Schluss durchlaufen lassen.+ausgeführt werden, damit das lokale Repository vom neuen Branch auf der Remote weiß und anschließend ein  
 +  git checkout -b [neuer Branch] fn2web/[Release] 
 +gemacht werden um den neuen Branch lokal an zu legen. Falls der Name des gewünschten Branches mit einem '#' beginnt, muss er in Anführungszeichen gesetzt werden.
  
-<WRAP center round important 60%+<WRAP center round important> 
-In dem ausgecheckten Verzeichnis dürfen niemals vorhandene Dateien geändert werden!+Der FTP-Server ist für git nicht mehr verfügbar und wurde von einem GitLab-Server abgelöst. 
 +Deshalb muss in der Datei ''/.git/config'' für die fn2web-Remote die URL ''https://gitlab.ihb-eg.de/fn2/fn2webapps.git'' hinterlegt sein (ggf. mit Nutzer und Passwort). Zum Beispiel:\\  
 + 
 +<code>[remote "fn2web"
 + url = https://gitlab.ihb-eg.de/fn2/fn2webapps.git</code> 
 +für die Remote "fn2web".
 </WRAP> </WRAP>
  
-==== Laden von Updates des aktuellen Zweiges ==== 
- 
-Um zu prüfen, ob neue Zweige oder Updates zur Verfügung stehen, ist <code>git fetch --all -v</code> einzugeben. 
- 
-Mit <code>git pull</code> wird automatisch zum aktuellsten Stand des Zweiges gesprungen. Dazu werden alle Neuerungen geholt. <WRAP center round important 60%>Um das problemlos zu ermöglichen, dürfen vorhandene Dateien niemals geändert werden!</WRAP> 
- 
- 
-Um anzuzeigen, **welche Zweige existieren**, gibt man den Befehl <code>git branch</code> ein. Mit * in der Ausgabe ist markiert, auf welchem Zweig man sich befindet. 
- 
-Zu einem anderen Zweig kann gewechselt werden mittels des Befehls <code>git checkout ZWEIGNAME</code> Dabei beachten, wenn der Name des Branches mit einen **#** beginnt, diesen Namen in einfache Anführungszeichen setzen. Beispiel: <code>git checkout '#3563'</code> 
- 
-Um die komplette Historie anzeigen zu lassen, wird der Befehl <code>git log --graph --decorate --oneline --all --since="2015-10-01"</code> eingegeben. Um anschließend einen älteren Zustand wiederherzustellen, geben Sie folgenden Befehl mit dem Label des commits ein der zu dem gewünschten älteren Zustand passt. <code>git checkout <commit label></code> Die Markierung **(HEAD)** zeigt einem an, wo man sich gerade befindet.  
- 
-**Die Ausgabe ist wie folgt zu lesen:** //Label des Commits// (//HEAD// -> dieser Zustand ist augecheckt, //origin/...// -> Name und Zweig des entfernten Rechners (auf dem FTP-Server), //origin/HEAD// -> dieser Zustand ist auf dem entfernten Rechner ausgecheckt, //Name des Zweiges//) 
- 
- 
-==== Wartung: verwaiste Zweige löschen, um Speicherplatz frei zu geben ==== 
- 
-Dieser Befehlt, löscht einen lokalen Zweig - üblicherweise, wenn eine Auslieferung zum Testen nicht mehr benötigt wird und Speicher freigegeben werden soll. 
- 
-<code>git branch -d <branchname></code> 
- 
-Mit diesem Befehl werden die Zweige die auf dem Server bereits gelöscht wurden, bereinigt <code>git remote update --prune</code> 
  
 +<WRAP center round important>
 +Es ist leider eine gängige Praxis bei Linux-Systemen (und in geringerem Umfang auch Windows) standartmäßig mit dem Superuser zu arbeiten. In Zeiten von Emotet und ähnlicher Schadsoftware, die auch schon einige Hochschulen befallen hatten, sollte es überflüssig sein zu erläutern, wieso das generell eine schlechte Idee ist. Hier ein weiterer Grund:\\ 
 +Wenn mit dem root-User git-Operationen ausgeführt werden, dann werden die Änderungen im .git-Ordner auch mit dem root-User als Inhaber hinterlegt. Ein normaler Nutzer kann dann diese nicht mehr ändern ohne die git-Befehle selbst unter Superuser-Kontext auszuführen. Je nach Art der Änderungen wird das dem Nutzer aber von git nicht mit geteilt. In anderen Worten: es kann dadurch passieren, dass ein 'git pull' ohne Fehlermeldung durchläuft, jedoch keine oder nicht alle Dateien aktualisiert werden. Daher noch einmal: **Bitte, wiederstehen Sie der 'sudo -s'-Versuchung.**
 +</WRAP>
  
 ==== Aktualisieren der FN2-Installation ==== ==== Aktualisieren der FN2-Installation ====
Zeile 108: Zeile 111:
 Im Ordner Konfigurationsdateien gibt es Skripte für Windows (//CopyFN2-Webapps.cmd//) und Linux (//CopyFN2-Webapps.sh// und //fn2excl.txt//). Bitte diese als Kopiervorlage verwenden und in den Skripten die gewünschten Variablen setzen bzw. die auszuschließenden Ordner als solche markieren. Im Ordner Konfigurationsdateien gibt es Skripte für Windows (//CopyFN2-Webapps.cmd//) und Linux (//CopyFN2-Webapps.sh// und //fn2excl.txt//). Bitte diese als Kopiervorlage verwenden und in den Skripten die gewünschten Variablen setzen bzw. die auszuschließenden Ordner als solche markieren.
  
 +===== fn2Web-Releases Verzeichnisstruktur =====
  
-==== Wechseln eines Zweiges und anzeigen von Release-notes ====+Mit dem nachfolgenden Screenshot wird die Verzeichnisstruktur, die man beim Download von fn2Web-Releases erhält, erklärt.
  
-Zu einem anderen Zweig kann gewechselt werden mittels des Befehls <code>git checkout ZWEIGNAME</code>+{{ :fn2:fn2web-releases_verzeichnisstruktur.jpg?nolink |}}
  
-Der Befehl <code>git checkout <commit hash></code> wechselt zu einem früheren Zustand des Zweiges.+===== Wichtige GIT-Befehle =====
  
-Die <commit hash> werden mit dem Befehl <code>git log</code> oder mittels <code>git log --pretty=format:"%ar %cd - %H - %an - %s" --since="2015-10-01" --graph --date=short</code> angezeigt(Weitere Dokumentation zur Ausgabe gibt es [[https://git-scm.com/book/en/v2/Git-Basics-Viewing-the-Commit-History|hier]].).+  git fetch --all -
 +aktualisiert die lokalen Informationen zu den bekannten Remotes und gibt Änderungen detailiert an. Im Endeffekt kann so überprüft werden ob neue Releases und Updates veröffentlich wurden.
  
-Die Release-Notes können mit demselben Befehl <code>git log</code> angezeigt werden und mittels <code>git show</codewerden die Release-Notes und die durchgeführten Änderungen dargestellt.+  git pull 
 +führt eigentlich zwei separate Befehle aus: 'git fetch' und 'git merge'.\\  
 +Fetch wurde bereits beschrieben, Merge führt lokal eingepflegte (commitete) Änderungen mit denen des Remote-Branches zusammen. Wir möchten Sie bitten Darauf zu verzichten lokal Änderungen ein zu pflegen. <wrap important>Wir übernehmen weder Garantie, noch Support, für derartige Änderungen! Bitte sprechen Sie solche Eingriffe mit uns ab!</wrap>
  
-Mit den folgenden Befehlen, können die release-notes in verschiedenen Formaten dargestellt werden.+  git branch 
 +zeigt die lokalen Zweige/Branches an und markiert den aktuell ausgecheckten.
  
-<code>git log --format=oneline</code>+  git remote -
 +zeigt die lokal definierten Remotes und zugehörige URLs an.
  
-<code>git log --format=short</code> +  git log 
- +  git show 
-<code>git show --format=short</code> +sind beides Befehlemit denen eine Übersicht über den Verlauf von Commits im Repository gewonnen werden kann.
- +
-Der Befehl <code>git status</code> zeigt anauf welchem Zweig man sich befindet.+
  
 +Die meisten git Befehle leisten viel mehr, als hier aufgeführt werden kann. Daher sei auch hier nocheinmal auf die [[https://git-scm.com/docs/|git-Dokumentation]] und ihre (sehr gute und hilfreiche) Suchfunktion verwießen.
  
 ===== Troubleshooting ===== ===== Troubleshooting =====
Zeile 135: Zeile 143:
 ==== Wenn der Hinweis ignoriert wurde und vorhandene Dateien geändert wurden, ist folgendes durchzuführen: ==== ==== Wenn der Hinweis ignoriert wurde und vorhandene Dateien geändert wurden, ist folgendes durchzuführen: ====
  
-Ein Update wird dann mit dem Hinweis abbrechen, dass lokale Änderungen durch das Update überschrieben würden und man diese entweder committen (was von FlexNow-Seite aus nicht erwünscht ist) oder diese "Stashen" soll. In diesem Fall ist ein Stash durchzuführen, d.h die veränderten Daten in einen Zwischenspeicher abzulegen.<code>git stash</code> Danach ist es nötig mit dem bereits erwähnten Befehl <code>git pull</code> ein Update zu holen und abschließend den Stash zu bereinigen. <code>git stash list</code> <code>git stash drop stash@{0}</code> Hinweise gibt es im [[https://git-scm.herokuapp.com/book/en/v2/Git-Tools-Stashing-and-Cleaning|GIT-Buch]].+Ein Update wird dann mit dem Hinweis abbrechen, dass lokale Änderungen durch das Update überschrieben würden und man diese entweder committen (was von FlexNow-Seite aus nicht erwünscht ist) oder diese "Stashen" soll. In diesem Fall bitte ein Stash durchzuführen, d.h die veränderten Daten in einen Zwischenspeicher abzulegen.<code>git stash</code> Danach ist es nötig mit dem bereits erwähnten Befehl <code>git pull</code> ein Update zu holen und abschließend den Stash zu bereinigen. <code>git stash list</code> <code>git stash drop stash@{0}</code> Hinweise gibt es im [[https://git-scm.herokuapp.com/book/en/v2/Git-Tools-Stashing-and-Cleaning|GIT-Buch]].
  
 +Alternativ kann, vor allem bei schwereren Beschädigungen am Repository, mit dem reset-Befehl gearbeitet werden:
 +  git reset --hard <commit>
 +bringt sowohl den HEAD als auch den Working-Tree (also die verwalteten Dateien) auf den Stand von <commit>.
  
 ==== Probleme mit Sonderzeichen im Passwort ==== ==== Probleme mit Sonderzeichen im Passwort ====
- 
 Falls ein Sonderzeichen im Passwort ist und der Zugang zum GIT-Server verweigert wird, muss das Passwort im lokalen Kunden-Repository in der Datei .../.git/config in Hochkommata gesetzt werden ([[https://stackoverflow.com/questions/32976119/git-ftp-config-settings-with-password-ending-in|Quelle]]) Falls ein Sonderzeichen im Passwort ist und der Zugang zum GIT-Server verweigert wird, muss das Passwort im lokalen Kunden-Repository in der Datei .../.git/config in Hochkommata gesetzt werden ([[https://stackoverflow.com/questions/32976119/git-ftp-config-settings-with-password-ending-in|Quelle]])
  
Zeile 148: Zeile 158:
  
 {{ :fn2:git_pull_error.png?nolink |}} {{ :fn2:git_pull_error.png?nolink |}}
- 
- 
-==== Link zum GitLab-Server ==== 
- 
-Der FTP-Server ist für Git nicht mehr verfügbar. 
-Deshalb muss in der Datei ''/.git/config'' der Bereich ''remote = "origin"'' folgende URL enthalten: 
- 
-<code>[remote "origin"] 
- url = https://gitlab.ihb-eg.de/fn2/fn2webapps.git</code> 
fn2/aktualisierung.txt · Zuletzt geändert: 2024/03/04 14:54 von christoph