[10]: https://git-scm.com/downloads ![TBZ Banner](../../x_gitres/tbz_logo.png) # Inhaltsverzeichnis KN02 Challenge A) [TOC]
## Intro Beachten Sie die [allgemeinen Informationen zu den Abgaben](../Abgaben.md). ## Ausgangslage: verwenden Sie FÜR den folgenden Challenge (bestehend aus zwei Labs) das AWS Academy *"**Learner Lab**"*. Ab jetzt arbeiten Sie **immer** im **Learner Lab** - **Ausser explizit anders angegeben.** - Der erste Teil-Challenge heisst **EC2 Einstieg**. Dieses Lab ist der erste Kompetenznachweis dieses Challenges (Details unten) - Das zweite Teil-Challenge heisst **S3 Einstieg**. Dieses Lab ist der zweite Kompetenznachweis dieses Challenges (Details unten). - Führen Sie beide Labs durch und achten Sie auf die jeweiligen Punkte unter **Leistungsnachweis** ## Challenges ### 1. Teil-Challenge: EC2 Einstieg Führen Sie alle Tasks durch. Sie erstellen die Screenshots der verschiedenen Bereiche für Ihre Abgabe **nachdem** Sie **alle** Schritte des Challenges durchgeführt haben. #### 1. Task: Erstellen und Benennen einer EC2-Instanz **Schritt 1: Navigieren Sie zum EC2-Service** - Gehen Sie zur **AWS Management Console**. - Wählen Sie im **Services**-Menü den Bereich **Compute** und dann **EC2**. **Schritt 2: Instanz starten** - Klicken Sie auf die Schaltfläche **Launch instance** in der Mitte der Seite. - Wählen Sie **Launch instance** aus dem Dropdown-Menü. **Schritt 3: Benennen Sie die Instanz** - Geben Sie im Feld unter **Name and tags** den Namen `Web Server 1` ein. - Dieser Name wird als ein Tag gespeichert, bei dem der "Key" `Name` und der "Value `Web Server 1` ist. **Hinweis zu Tags** - Tags helfen Ihnen, Ihre AWS-Ressourcen auf verschiedene Weise zu kategorisieren, z. B. nach Zweck, Eigentümer oder Umgebung. - Dies ist besonders nützlich, wenn Sie viele Ressourcen desselben Typs haben, da Sie eine bestimmte Ressource schnell anhand der vergebenen Tags identifizieren können. - Jeder Tag besteht aus einem **Key** und einem **Value**, die Sie selbst definieren. - Der **Name** ist einfach ein weiteres Tag. Der Schlüssel für dieses Tag ist `Name`, und der Wert lautet `Web Server 1`. #### 2. Task: Anwendungs- und Betriebssystem-Images **Schritt 4: Wählen Sie eine AMI aus, um die Instanz zu erstellen** - In der Liste der verfügbaren **Quick Start AMIs** bleibt die standardmäßig ausgewählte **Amazon Linux AMI** ausgewählt. - Behalten Sie ebenfalls das standardmäßig ausgewählte **Amazon Linux 2023 AMI x86_64 (HVM)** bei. - Der Typ des ausgewählten **Amazon Machine Image (AMI)** bestimmt das Betriebssystem (OS), das auf der gestarteten EC2-Instanz läuft. In diesem Fall haben Sie **Amazon Linux 2023** als Gastbetriebssystem ausgewählt. #### 3. Task: Wählen Sie einen Instanztyp **Schritt 5: Geben Sie einen Instanztyp an** - Im **Instance type**-Panel bleibt die standardmäßig ausgewählte **t2.micro**-Instanz ausgewählt. - Der **Instance Type** definiert die Hardware-Ressourcen, die der Instanz zugewiesen werden. Dieser Instanztyp verfügt über **1 virtuelle CPU** (vCPU) und **1 GiB Speicher**. #### Ziel der Übung :bell: Erste Hands-on Erfahrung mit dem AWS Service **EC2** (Elastic Compute Cloud) ##### Leistungsnachweis - [ ] HTML-Seite, inkl. URL - [ ] Liste der EC2-Instanzen - [ ] Details der *Web Server*-Instanz (öffentliche IP sichtbar) - [ ] Security-Group: Liste der Inbound-Regeln. Beachten Sie ausserdem die [allgemeinen Informationen zu den Abgaben](../../Abgaben.md). #### b) 2. Lab - S3 Einstieg Führen Sie alle Schritte durch. Sie erstellen die Screenshots der verschiedenen Bereiche für Ihre Abgabe **nachdem** Sie **alle** Schritte des Challenges durchgeführt haben. #### Ziel der Übung :bell: Erste Hands-on Erfahrung mit dem AWS Service **S3** (Object Storage) ##### Leistungsnachweis - [ ] Liste der Buckets. - [ ] HTML-Seite, inkl. URL. - [ ] Liste der Dateien im Bucket. - [ ] Eigenschaften von "Static website hosting". Beachten Sie ausserdem die [allgemeinen Informationen zu den Abgaben](../../Abgaben.md).


---- ALLES WAS HIER KOMMT, AM ENDE LÖSCHEN ### B) Zugriff mit SSH-Key #### Ausgangslage: Wechseln Sie nun den Kurs und verwenden Sie *"**Learner Lab**"*. Ab jetzt arbeiten Sie **immer** im **Learner Lab** - **Ausser explizit anders angegeben.** Unter [Quellen](./KN02.md#quellen) finden Sie ein Dokument, welches die Unterschiede zwischen Passwort und SSH-Key beschreibt. Lesen Sie sich **kurz** ein, wenn Sie möchten. Wir werden grundsätzlich **kein Passwort** verwenden, sondern **immer** SSH Keys. Sie werden nun gemäss der folgenden Anleitung eine EC2-Instanz und **zwei** Keypairs erstellen. Danach weisen Sie dieser EC2-Instanz einen der beiden Key pair Namen zu. Sobald die Instanz verfügbar ist, überprüfen Sie, ob Sie sich mit beiden Keys darauf einloggen können. #### Anleitung: Erstellen Sie nun eine neue **Ubuntu**-Instanz in AWS mit den Standard-Einstellungen und erstellen Sie dann **zwei Key pairs** wie folgt: - Ubuntu Server 22.04 AMI (Amazon Machine Image) auswählen. - Achten auf **Free tier eligible**. Auswahl AMI (Amazon Machine Image), **Free tier eligible** | :-------------------------:| ![keypair1](./x_res/02_os_800.png) | - Bei "Key pair" erstellen Sie **zwei** Key-Value Pairs! Geben Sie Namen wie **\-1** und & **\-2**. Create new Key pair | Felder ausfüllen / anwählen :-------------------------:|:-------------------------: ![keypair1](./x_res/01a_Keypair_400.png) | ![keypair2](./x_res/01b_Keypair_400.png) - Stellen Sie sicher, dass Sie **beide Schlüssel** herunterladen. - Nachdem beide Keys erstellt wurden, wählen Sie bei "Key pair" dann den **ersten** Key aus. Belassen sie die restlichen Parameter so wie sie bereits eingestellt sind. Scrollen Sie bis ganz nach unten und klicken Sie auf **Launch instance**. Speicherort der privaten (und öffentlichen) Schlüssel muss ein Pfad sein, der eingeschränkte Rechte hat (nur Ihr persönlicher Account). Normalerweise wird der Pfad `C:\Users\\.ssh` verwendet. Der Befehl für den Zugriff sieht nun folgendermassen aus. Der Parameter -o verhindert, dass Sie ein Timeout kriegen. --- ```bash ssh @ -i \.pem -o ServerAliveInterval=30 # Standard-Benutzername ist ubuntu! # Beispiel: ssh ubuntu@121.12.3.1 -i c:\Users\calisto\.ssh\Calisto-1.pem -o ServerAliveInterval=30 ``` --- Zeigen Sie, dass sie sich **nur** mit **dem ausgewählten** Schlüssel einloggen können. **Hinweis**: AWS speichert ihren privaten Schlüssel **nicht**. Sie können den nicht wiederherstellen. Auf dem Ubuntu-Server liegt immer nur der öffentliche Schlüssel. Seien Sie also vorsichtig und verlieren Sie den Schlüssel nicht. #### Ziel der Übung :bell: Sie verstehen, wie Key pairs erstellt und angewendet werden. Einer wird nicht funktionieren. Überlegen Sie sich, weshalb das so ist und wie die Authentifizierung durchgeführt wird. Wo werden die Keys (Private / Public) abgelegt? ##### Leistungsnachweis - [ ] Screenshot mit dem ssh-Befehl und des Resultats unter Verwendung des **ersten** Schlüssels. - [ ] Screenshot mit dem ssh-Befehl und des Resultats unter Verwendung des **zweiten** Schlüssels. - [ ] Screenshot der Instanz-Detail (oder Liste), so dass der verwendete Schlüssel sichtbar ist. - [ ] Differenziert und nachvollziehbar im persönlichen Repository dokumentiert. - [ ] Fachgespräch mit Coach. Beachten Sie ausserdem die [allgemeinen Informationen zu den Abgaben](../Abgaben.md).
---- ### C) Installation von Web- und Datenbankserver #### Ausgangslage: Via SSH auf EC2-Instanz zugreifen und sämtliche Kommandos für das Setup des Webservers mit DB-Zugriff **manuell** (imperativ) der Reihe nach ausführen. Verwenden Sie die Instanz aus Aufgabe B) und gehen Sie wie folgt vor: #### Ports checken, Rule ergänzen (Security Group) - Stellen Sie sicher, dass die dazu notwendigen Ports in der ausgewählten Security-Group offen sind: - 22 für SSH Zugriff (sollte bereits vorhanden sein) - 80 für HTTP Zugriff (dazu müssen sie in der ausgewählten Security Group noch eine Inbound rule erstellen - gleich wie beim ersten Lab, siehe Bild unten) Inbound rule für HTTP hinzufügen | :-------------------------:| ![keypair1](./x_res/02_sg_http_800.png) | #### SSH-Verbindung aufbauen - Bauen Sie von Ihrem Laptop aus eine SSH-Verbindung auf Ihre EC2-Instanz auf (via Terminalfenster auf ihrem Laptop mit SSH auf die EC2-Instanz zugreifen). Kommandos auf Ihrer EC2-Instanz der letzten Übung auszuführen: **1.** Connect to instance | **2.** SSH Client auswählen :-------------------------:|:-------------------------: ![connect1](./x_res/03d_connect_400.png) | ![connect2](./x_res/03e_connect_400.png) - Führen Sie wie folgt sämtliche Kommandos für das Setup des Webservers mit DB-Zugriff **manuell** (imperativ) der Reihe nach aus. - `sudo apt update` auf. Dieser Befehl aktualisiert die Pakete/Software. - `sudo apt install apache2`. Dieser Befehl installiert den Apache Webserver. - `sudo apt install php`. Dieser Befehl installiert den PHP Applikationsserver. - `sudo apt install libapache2-mod-php`. Dieser Befehl installiert die PHP-Erweiterung für Apache. - `sudo apt install php-mysqli`. Dieser Befehlt installiert das PHP-Modul, um Datenbank-Abfragen zu erstellen. - `sudo apt install mariadb-server`. Dieser Befehl installiert den Datenbankserver. - `sudo mysql -sfu root -e "GRANT ALL ON *.* TO 'admin'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;"`. - `sudo systemctl restart mariadb.service`. Dieser Befehl startet den DB Server neu. - `sudo systemctl status mariadb.service`. Dieser Befehl checkt, ob der DB Server läuft. Falls Anzeige grün **active (running)**, dann ok. - `sudo systemctl restart apache2`. Dieser Befehl startet den Webserver neu. - `sudo systemctl status apache2`. Dieser Befehl checkt, ob der Webserver läuft. Falls Anzeige grün **active (running)**, dann ok. - `cd ~`. Dieser Befehl stellt sicher, dass Sie sich in ihrem Home-Verzeichnis befinden - `git clone https://gitlab.com/ser-cal/m346-scripts.git`. Diesen Befehl sollten Sie bereits beherrschen. - `sudo cp ./m346-scripts/KN01/*.php /var/www/html/`. Dieser Befehl kopiert die beiden PHP-Dateien in das Verzeichnis des Webservers. - Rufen Sie von ihrem Rechner nun die folgenden Seiten auf: - *http://[Ihre-IP]/index.html*. Diese URL zeigt ihnen die Informationen von Apache an. Wenn die Seite funktioniert, zeigt dies, dass Apache installiert wurde und funktioniert. - *http://[Ihre-IP]/info.php*. Diese URL zeigt ihnen die Informationen von PHP an. Wenn diese Seite funktioniert, zeigt dies, dass das PHP-Modul funktioniert und Sie nun dynamische Seiten hosten können. - *http://[Ihre-IP]/db.php*. Diese URL zeigt ihnen die Datenbank-Benutzer. Wenn diese Seite funktioniert, zeigt es Ihnen, dass die Datenbank-Verbindung funktioniert. #### Ziel der Übung :bell: **Verständnisaufbau** für den Unterschied zwischen **imperativer** und **deklarativer** Plattformentwicklung. Bei dieser Übung setzen Sie auf einer bestehenden EC2-Instanz einen Webserver mit Datenbankanbindug auf. Sie installieren dazu **imperativ** (Eingabe einzelner Kommandos per Tastatur) folgende Software: - Apache Webserver - PHP und PHP-Erweiterung für Apache - PHP-Modul für Datenbankabfragen - Datenbankserver (MariaDB)
...des weiteren:
- erstellen Sie einen DB-Benutzer (inkl. Passwort) - restarten anschliessend den DB-Server - ...und den den Webserver Alle Commands schön der Reihe nach, sonst gibt es Probleme. Falls Sie **100** weitere Instanzen so aufsetzen müssten, würden Sie sämtliche Schritte 100x wiederholen :grimacing:. Gut also, dass das **imperative** Vorgehen vom **deklarativen** Vorgehen - auch **IaC** (Infrastructure as Code) genannt - abgelöst wird. Wie das geht, erfahren Sie schon bald :smiley:. ##### Leistungsnachweis - [ ] Erstellen Sie Screenshots der **drei** Webseiten (mit sichtbaren URLs). - [ ] Differenziert und nachvollziehbar im persönlichen Repository dokumentiert. - [ ] Fachgespräch mit Coach. Beachten Sie ausserdem die [allgemeinen Informationen zu den Abgaben](../Abgaben.md). ##### Beispiel-Abgabe: - Screenshots der drei URLs: Apache | PHP | DB-User :---:|:---:|:---:| ![Apache](./x_res/03a_apache_300.png) | ![PHP](./x_res/03b_apache_300.png) | ![User](./x_res/03c_user_300.png)
--- ### Quellen Thorntech: [Passwords vs. SSH keys - what's better for authentication?](https://thorntech.com/passwords-vs-ssh)
--- > [⇧ **Zurück zu KN02**](./Readme.md) --- > [⇧ **Zurück zur Hauptseite**](https://gitlab.com/ser-cal/M346) ---