-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Deployment in Kopfzeile ausgelagert (Testweise erst als Kopie; admin/…
…Deployment bei Erfolg entfernen).
- Loading branch information
Showing
41 changed files
with
19,304 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,124 @@ | ||
# Datenmigration | ||
|
||
Neue Schemata oder vorhandene Schemata in der Datenbank des SVWS-Servers anlegen. | ||
|
||
## Download von Testdaten | ||
|
||
Für Testzwecke und Schulungen werden anonymisierte Datenbanken verschiedener Schulformen vorgehalten. | ||
Zu bestimmten Datenbanken sind auch passende Lupo Dateien etc. vorhanden, um sich passende Testfälle anzusehen. | ||
**Die Daten sind vollständig anonymisiert!** | ||
|
||
|
||
[https://github.com/SVWS-NRW/SVWS-TestMDBs](https://github.com/SVWS-NRW/SVWS-TestMDBs) | ||
|
||
## Übersicht | ||
|
||
Es gibt mehrer Möglichkeiten ein Schemata in der Datenbank anzulegen bzw. zu befüllen: | ||
|
||
+ per Admin-Webclient | ||
+ per Swagger UI | ||
+ per Curl Befehl | ||
+ per Shell Skript | ||
+ aus einer SQLite Datensicherung | ||
+ aus einem SQL-Dump | ||
|
||
## Benutzung des Admin-Webclient | ||
|
||
![adminclient.png](./graphics/adminclient.png) | ||
|
||
Melden Sie sich mit root und dem Kennwort an der MariaDB an. | ||
Sie können auch einen anderen Datenbankuser wählen, dieser sieht dann die vorhandenen Datenbanken entsprechnd seiner Rechte. | ||
|
||
Im Adminclient können je nach Rechtevergabe des Datenbankusers folgende Arbeiten erledigt werden: | ||
|
||
- Datenbankschema für SVWS anlegen und in die svwsconfig.json aufnehmen | ||
- Datenbank mit Schulnummer initialisieren | ||
- Schild-NRW2 Datenbank in Schema migrieren | ||
- SQLite-Backup ausführen | ||
- SQLite-Backup wieder einspielen | ||
- Datenbankschema löschen | ||
|
||
## Einfügen per SwaggerUI | ||
|
||
Eine Übersicht über die Web-Services bietet die SwaggerUI. | ||
Hier kann man über *Try it Out* -- Buttons jeweils die Services ausprobieren bzw. benutzen. | ||
Die Swagger UI aufrufen: | ||
|
||
```bash | ||
https://<YourServerDomainName>/debug/ | ||
``` | ||
|
||
![SwaggerUI.png](./graphics/Swagger-01.png) | ||
|
||
|
||
|
||
**Achtung:** Um auf der SwaggerUI diesen Service bzw. die mit "Root" gekennzeichneten Services nutzen zu können, muss man sich zuerst authentisieren, indem man auf ein rechts abgebildetes Schloss klickt. | ||
|
||
|
||
Hier nun den User `root` der MariaDB-Installation und das entsprechende Passwort angeben. | ||
|
||
|
||
**Hinweis** Möchte man andere "nicht root - Services" nutzen, so muss man sich mit dem SchILD-NRW 3.0-Benutzer bzw. SVSW-Benutzer anmelden. | ||
|
||
|
||
|
||
Dann unter dem Abschnitt | ||
-> "SchemaRoot /api/schema/root/migrate/mdb/{schema}" | ||
-> *Try it Out*-Button | ||
drücken, so dass man diese Ansicht erhält: | ||
|
||
|
||
|
||
![SwaggerUI.png](./graphics/Swagger-02.png) | ||
|
||
|
||
|
||
|
||
|
||
Anschließend die folgenden Einträge unter der Maske ausfüllen: | ||
|
||
+ **schema**: Hier steht der Name, der auch auf der Anmeldemaske dargestellt wird, z.B. Testschule. | ||
+ **Databasefile**: Hier können Sie z.B. eine SchILD-NRW 2.0-MDB-Datenbank aus der o.g. SVWS-TestMDBs einstellen. | ||
+ **databasePassword**: Hier das SchILD-NRW 2.0 Access-Passwort angeben. | ||
+ **SchemaUsername**: Einen beliebigen Usernamen angeben, z.B. svwsadmin, der bei der Einrichtung des Schemas auf der Datenbank für dieses Schema GRANT-Rechte erhält. | ||
|
||
Es kann auch ein schon existierender Benutzer genommen werden. | ||
Falls ein schon existierender Benutzer verwendet wird, muss das anschließend abgefragte Passwort natürlich passen. | ||
|
||
++ **SchemaUserPasswort**: Passwort der o.g. (neu angelegte) MariaDB Users. | ||
|
||
|
||
# Schemata per Curl erstellen | ||
|
||
```bash | ||
--user "%1:%2" -k -X POST "https://localhost/api/schema/root/migrate/mdb/%3" | ||
-H "accept: application/json" | ||
-H "Content-Type: multipart/form-data" | ||
-F "databasePassword=%4" | ||
-F "schemaUsername=%5" | ||
-F "schemaUserPassword=%6" | ||
-F "database=@%7" | ||
``` | ||
|
||
+ %1: Benutzer der Datenbank mit GRAND-Rechten zum Anlegen neuer Datenbanken | ||
+ %2: Passwort der o.g. Benutzers | ||
+ %3: Name der neu anzulegenden Datenbank - Achtung: existierende Datenbanken werden überschrieben! | ||
+ %4: Das allseits bekannte SchILD-NRW 2.0 - Passwort, um die MDB-Datenbank zu öffnen. | ||
+ %5: Der neue MariaDB User für die neue Datenbank (Schuldatenbankadmin im Backend) | ||
+ %6: Passwort der o.g. Benutzers | ||
+ %7: vollständiger Pfad zur MDB auf dem Server - MIT @ davor! | ||
|
||
|
||
Beispiel: | ||
```bash | ||
curl --user "root:mariabd_root_pw" -k -X "POST" "https://server.svws-nrw.de/api/schema/root/migrate/mdb/svwsdb" \ | ||
-H "accept: application/json" \ | ||
-H "Content-Type: multipart/form-data" \ | ||
-F "databasePassword=kannManWissen" \ | ||
-F "schemaUsername=svwsuser" \ | ||
-F "schemaUserPassword=svwsadmin_PW" \ | ||
-F "database=@/root/SVWS-TestMDBs/GOST_Abitur/Abi-Test-Daten-01/GymAbi.mdb" | ||
``` | ||
|
||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,170 @@ | ||
# Docker-Container | ||
|
||
Der SVWS-Server kann als Container betrieben werden. Dies eignet sich insbesondere für die folgenden beisen Szenarien: | ||
|
||
* Betrieb einer SVWS-Umgebung für Produktiv- oder Test-Betrieb [per docker-compose](#svws-umgebung-mit-docker-compose-starten) | ||
* Betrieb einer SVWS-Umgebung für die Entwicklung und Deployment [per Gradle](#svws-umgebung-mit-gradle-starten) | ||
|
||
Die SVWS-Container-Images sind unter Docker (docker engine, docker desktop) lauffähig. Ein Betrieb unter anderen Container-Umgebungen wie z.B. | ||
[Podman](https://podman.io/), [Kubernetes](https://kubernetes.io/de/), [OpenShift](https://www.redhat.com/de/technologies/cloud-computing/openshift) | ||
ist grundsätzlich möglich, jedoch noch nicht getestet (Stand 27.09.2024). | ||
|
||
Im Git-Repository von SVWS befinden sich [Beispiele, Scripte und Image-Definitionen](https://github.com/SVWS-NRW/SVWS-Server/tree/dev/deployment/docker) | ||
zum Aufbau von Docker-basierten SVWS-Umgebungen. | ||
|
||
|
||
## Systemvoraussetzungen | ||
Für die lokale Inbetriebnahme ist eine Installation von [Docker-Desktop](https://docs.docker.com/desktop/) auf dem Entwickler-PC notwendig. | ||
Bitte die [Nutzungsbedingungen](https://www.docker.com/legal/docker-subscription-service-agreement) der Fa. Docker Inc. für Docker Desktop beachten! | ||
|
||
### Beispiel: Installation Docker-Umgebung in Debian 12 | ||
|
||
```bash | ||
## Install Docker on Debian 12 | ||
apt update && apt upgrade -y | ||
apt install -y apt-transport-https ca-certificates zip p7zip-full curl gnupg-agent software-properties-common net-tools | ||
curl -fsSL https://download.docker.com/linux/debian/gpg | apt-key add - | ||
add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/debian $(lsb_release -cs) stable" | ||
apt update && apt install -y docker-ce docker-ce-cli containerd.io | ||
service docker status --no-pager | ||
``` | ||
|
||
## SVWS-Umgebung mit docker-compose starten | ||
|
||
Die SVWS-Umgebung kann über die Konsole des verwendeten Betriebssystems mittels docker-compose gestartet werden. | ||
Beispiele zur dazu obligatorischen docker-compose.yml und .env Datei befinden sich im [Github-Repository](https://github.com/SVWS-NRW/SVWS-Server/tree/dev/deployment/docker/example) . | ||
|
||
### Beipiel: aktuellen Testserver im Docker Container | ||
|
||
```bash | ||
# Arbeitsverzeichnis anlegen | ||
mkdir ~/docker && mkdir ~/docker/svws && cd ~/docker/svws | ||
# | ||
# download docker-comose.yml, .env, etc. | ||
wget https://github.com/SVWS-NRW/SVWS-Dokumentation/tree/main/Deployment/Docker/svws-docker-example.zip | ||
7z x svws-docker-example.zip | ||
# | ||
# SVWS Docker initialisieren | ||
docker compose up | ||
``` | ||
|
||
Es werden nun Services für eine komplette SVWS-Umgebung gestartet: Datenbank, SVWS-Anwendung (Backend, Frontend). Ebenso sind die Volumes für den Keystore gemounted. | ||
|
||
Achtung: Diese Umgebung ist nicht für Produktivbetrieb geeignet, dazu muss die [Konfiguration der SVWS-Umgebung](#konfiguration-der-svws-umgebung) individuell angepasst werden! | ||
|
||
Nach dem Start kann der SVWS-Server über den Port 8443 erreicht werden. | ||
Auf die Datenbank kann standardmäßig nicht außerhalb der Docker-Umgebung zugegriffen werden (not bound). | ||
Intern nutzt die Datenbank den Port 3306. Für den Zugriff von SchILD 3 ist ein Port-Binding auch außerhalb von Docker nötig, | ||
dies wird über die Angabe eines Port-Mappings (ports) Eintrag in der Datei erreicht. | ||
In diesem Beispiel wird der Port 3306 im Container auf den Port 13306 auf dem Host abgebildet.: | ||
|
||
Beispiel: | ||
```yaml | ||
... | ||
services: | ||
mariadb: | ||
... | ||
ports: | ||
- "3306:13306" | ||
... | ||
``` | ||
|
||
|
||
## SVWS-Umgebung mit Gradle starten | ||
|
||
Im folgenden wird der Ansatz beschrieben, die SVWS-Images für die Entwicklung lokal zu betreiben. Dieser Ansatz bietet in der Entwicklung folgende Vorteile: | ||
* Keine Notwendigkeit einer lokalen Installation von MariaDB | ||
* Schnelles Rampup von SVWS-Datenbanken mit Testdaten | ||
* Einfaches Zurücksetzen und Wiederherstellen der SVWS-Datenbanken auf definierte Zustände. | ||
Dies ist insbesondere für die Ausführung von automatisierten API- und Integrationstests mit Abhängigkeit zu Testdaten hilfreich. | ||
|
||
Es existieren vordefinierte Gradle-Tasks, mit denen eine komplette Umgebung, bestehend aus der SVWS-Anwendung und einer SVWS-Datenbank, aus der Entwicklungsumgebung heraus gestartet werden können. | ||
|
||
Start einer Umgebung aus der Console: | ||
```bash | ||
./gradlew :deployment:docker:dockerComposeUp | ||
``` | ||
|
||
Die Gradle-Tasks nutzen [docker-compose](https://docs.docker.com/compose/) in der Version 3. | ||
|
||
Achtung: Vor dem Start der SVWS-Umgebung muss zunächst die [Konfiguration der SVWS-Umgebung](#konfiguration-der-svws-umgebung) individuell angepasst werden. | ||
|
||
|
||
## Ausgewählte Services einer SVWS-Umgebung starten | ||
Es besteht die Möglichkeit, nur einzelne ausgewählte Services einer SVWS-Umgebung über Docker zu betreiben. Also z.B. nur eine Datenbank oder nur die SVWS-Anwendung. | ||
|
||
Beispiel "nur Datenbank": | ||
```bash | ||
docker compose start mariadb | ||
``` | ||
|
||
Beispiel "nur SVWS-Anwendung": | ||
```bash | ||
docker compose start svws | ||
``` | ||
|
||
|
||
## Konfiguration der SVWS-Umgebung | ||
Die Konfiguration der Docker-basierten SVWS-Umgebung erfolgt über Umgebungsvariablen. | ||
Die Werte dieser Variablen werden in der Datei [.env](https://github.com/SVWS-NRW/SVWS-Server/blob/dev/deployment/docker/example/svws%2Bdb%2Binit/.env) definiert. | ||
Hier ein Beispiel: | ||
```bash | ||
INIT_SCRIPTS_DIR=/etc/app/svws/init-scripts | ||
TESTDB_PASSWORD=your-testdb-pw | ||
MARIADB_ROOT_PASSWORD=your-mariadb-root-pw | ||
MARIADB_DATABASE=your-svws-db-schema-name | ||
MARIADB_HOST=mariadb | ||
MARIADB_USER=your-mariadb-user | ||
MARIADB_PASSWORD=your-mariadb-pw | ||
MARIADB_DATA_DIR=/var/lib/mysql/data | ||
MARIADB_LOG_DIR=/var/lib/mysql/log | ||
SVWS_TLS_KEYSTORE_PATH=/etc/app/svws/conf/keystore | ||
SVWS_TLS_KEYSTORE_PASSWORD=your-keystore-pw | ||
SVWS_TLS_KEY_ALIAS=your-keystore-key-alias | ||
``` | ||
|
||
| Variable | Beschreibung | | ||
| ----------- | ----------- | | ||
| INIT_SCRIPTS_DIR | [Optional] Pfad zu einem Verzeichnis im SVWS-Container für Initialisierungsskripts. Alle Shell-Skripts in diesem Verzeichnis werden beim Hochfahren des SVWS-Containers ausgeführt. So können z.B. [automatische Testdatenimporte](#automatische-initialisierung-beim-start-testdatenimporte) in den Boot-Prozess integriert werden. | | ||
| TESTDB_PASSWORD | [Optional] Passwort der Testdatenbank (MS Access, SqlLite), das im Rahmen der [automatische Testdatenimporte](#automatische-initialisierung) verwendet werden soll. | | ||
| MARIADB_ROOT_PASSWORD | Passwort, das für den Root-User der MariaDB-Instanz verwendet werden soll | | ||
| MARIADB_DATABASE | Name des Datenbankschemas, mit dem sich der SVWS-Server verbindet (z.B. "gymabi") | | ||
| MARIADB_HOST | Name des Hosts, auf dem die SVWS-Datenbank läuft. Im Falle der Docker-Umgebung entspricht dieser Wert dem Service-Namen von docker-compose (also "mariadb"). | | ||
| MARIADB_USER | Datenbank-Benutzer, unter dem sich der SVWS-Server mit der Datenbank verbindet. | | ||
| MARIADB_PASSWORD | Passwort des Datenbank-Benutzers, unter dem sich der SVWS-Server mit der Datenbank verbindet. | | ||
| MARIADB_DATA_DIR | Pfad zum Daten-Verzeichnis innerhalb der MariaDB-Instanz. Wird benötigt, um die Daten im Datenbank-Container auf einem Volume zu sichern (volume mount). Pfad hängt von dem verwendeten MariaDB Basis-Image ab. | | ||
| MARIADB_LOG_DIR | Pfad zum Log-Verzeichnis innerhalb der MariaDB-Instanz. Wird benötigt, um die Logs im Datenbank-Container auf einem Volume zu sichern (volume mount). Pfad hängt von dem verwendeten MariaDB Basis-Image ab. | | ||
| SVWS_TLS_KEYSTORE_PATH | Unter diesem Pfad erwartet der SVWS den Java-Keystore für die Terminierung von SSL am Server | | ||
| SVWS_TLS_KEYSTORE_PASSWORD | Passwort des Keystores | | ||
| SVWS_TLS_KEY_ALIAS | Alias des zu verwendenden Keys im Keystore | | ||
|
||
|
||
### Weitergehende, individuelle Konfigurationen | ||
Weitergehende und individuelle Konfigurationen können in der `docker-compose.yml` vorgenommen werden. Die Konfigurationsmöglichkeiten sind den Dokumentationen der verwendeten Basis-Images zu entnehmen: | ||
|
||
* [MariaDB](https://github.com/docker-library/docs/blob/master/mariadb/README.md) | ||
* [Eclipse Temurin](https://github.com/docker-library/docs/tree/master/eclipse-temurin) | ||
|
||
## Automatische Initialisierung beim Start, Testdatenimporte | ||
Es besteht die Möglichkeit, beim Start der SVWS-Container die Datenbank mit Testdaten zu initialisieren. Es existiert ein [Beispiel-Script](https://github.com/SVWS-NRW/SVWS-Server/blob/dev/testing/svws/init-scripts/001import-test-db.sh) für den Import einer Testdatenbank im Git-Repository. | ||
|
||
Funktionsweise: Beim Start der SVWS-Container wird der Inhalt des Ordners [init-scripts](https://github.com/SVWS-NRW/SVWS-Server/tree/dev/testing/svws/init-scripts) in den SVWS-Container eingebunden (per volume mount). Alle Shell-Scripts (*.sh) in diesem Ordner werden durch das Start-Script des Containers im Anschluss ausgeführt. | ||
|
||
### Aktivierung der automatischen Initialisierung | ||
Umgebungsvariable `INIT_SCRIPTS_DIR` muss gesetzt sein (vgl. [Konfiguration der SVWS-Umgebung](#Konfiguration-der-SVWS-Umgebung)). Sofern eine Testdatenbank importiert wird, muss zusätzlich das Passwort `TESTDB_PASSWORD` für die Quelldatenbank angegeben werden. | ||
|
||
Datei [./deployment/docker/example/svws+db+init/.env](https://github.com/SVWS-NRW/SVWS-Server/blob/dev/deployment/docker/example/svws%2Bdb%2Binit/.env): | ||
```bash | ||
INIT_SCRIPTS_DIR=/etc/app/svws/init-scripts | ||
TESTDB_PASSWORD=your-testdb-pw | ||
#... | ||
``` | ||
|
||
### Deaktivierung der automatischen Initialisierung | ||
Umgebungsvariable `INIT_SCRIPTS_DIR` muss auskommentiert sein (vgl. [Konfiguration der SVWS-Umgebung](#Konfiguration-der-SVWS-Umgebung)). | ||
|
||
Datei [./deployment/docker/example/svws+db+init/.env](https://github.com/SVWS-NRW/SVWS-Server/blob/dev/deployment/docker/example/svws%2Bdb%2Binit/.env): | ||
```bash | ||
#INIT_SCRIPTS_DIR=/etc/app/svws/init-scripts | ||
#... | ||
``` |
Binary file not shown.
Oops, something went wrong.