4.9
(7)

Eigenen Docker Container erstellen

Erstellt / aktualisiert

wichtige Informationen...

Affiliate - Offenlegung

Auf meiner Seite verwende ich sogenannte Affiliate-Links, diese sind mit einem gekennzeichnet, damit du diese auch direkt erkennen kannst.
Sobald du über so einen Link das Produkt kaufen würdest, erhalte ich möglicherweise eine Provision vom jeweiligen Anbieter. Außerdem entstehen für Dich natürlich keine zusätzlichen Kosten!
Mich unterstützt du damit aber enorm und trägst dazu bei, dass es auch in Zukunft weitere Guides und Vorstellungen von mir hier geben wird.

Ich empfehle nur Tools / PlugIns / Anbieter / Produkte, hinter denen ich auch wirklich stehe, bzw. bei denen ich auch einen Mehrwert sehe.

DarkWolfCave.de ist Teilnehmer des Amazon-Partnerprogramms, das zur Bereitstellung eines Mediums für Webseiten konzipiert wurde, mittels dessen durch die Platzierung von Partner-Links zu Amazon.de Entgelte verdient werden können.


ACHTUNG! Bitte lesen!

Du benutzt das hier Gezeigte natürlich, wie immer, auf eigenes Risiko!
Ich habe alles selbst durchgeführt und mir mein System nicht zerschossen oder sonst irgendwelche negativen Auffälligkeiten bemerkt.

Aber dennoch… Backups sind immer gut….
Für WordPress-Backups am besten mit UpdraftPlus

Ich übernehme keine Haftung für Schäden jeglicher Art am System, der Hardware oder der Katze…. :-P


DarkWolfCave.de

Eigenen Docker Container erstellen: Schritt-für-Schritt Anleitung

In diesem Artikel dreht sich alles darum, wie du deinen eigenen Docker Container erstellen kannst. Wenn du ein Tech-Enthusiast bist und daher vielleicht eine eigene Entwicklungsumgebung nutzen möchtest, bist du hier genauso richtig wie jeder andere der gerade erst in die Welt der Containerisierung einsteigt.
Ich werde dir Schritt für Schritt erklären, wie du deine eigene Entwicklungs-Containerumgebung einrichten kannst. Also los geht’s, lass uns deinen eigenen Docker Container erstellen!

DarkWolfCave.de

Eigenen Docker Container erstellen – Was brauchen wir?

Natürlich muss auf deinem Server oder Raspberry Pi der Docker Dienst installiert sein und auch Portainer ist sehr hilfreich – allerdings optional.
Solltest du bisher noch kein Docker nutzen, empfehle ich dir erst einmal folgenden Artikel von mir durchzugehen:

Raspberry-pi-docker-ohne-probleme-installieren

Eigene Entwicklungsumgebung in einem Docker Container

Bevor wir starten und einen eigenen Container (Image) erstellen, mit dem wir dann weiter experimentieren und ihn anpassen können, hier ein kleiner Hinweis zur Begrifflichkeit:

Wenn ich im Folgenden von “dev-env” spreche, meine ich damit “development environment” – also eine Entwicklungsumgebung.

Wozu du letztendlich deinen eigenen Docker Container erstellen willst, bzw. danach nutzen möchtest, ist grundsätzlich nicht wichtig. Ich möchte dir lediglich aufzeigen, wie du einen solchen Container generell erstellen kannst.
Sobald du die Schritte dahinter – die wirklich nicht sehr kompliziert sind – verstanden hast, wirst du auch in der Lage dazu sein, deinen eigenen Docker Container nach deinen Bedürfnissen anzupassen!

Starten wir mit der folgende Ausgangslage:
Wir erstellen einen Docker-Container zum Entwickeln weiterer Python-Applikationen, die später in einem eigenen Docker-Image eingebunden werden.
Dies dient als Grundlage, um direkt in einem Docker Container entwickeln zu können.

Das Ganze läuft bei mir auf folgenden Komponenten:

Werbung

Affiliate – Links

DarkWolfCave.de ist Teilnehmer des Amazon-Partnerprogramm, das zur Bereitstellung eines Mediums für Webseiten konzipiert wurde, mittels dessen durch die Platzierung von Partner-Links zu Amazon.de Entgelte verdient werden können.

Wir nutzen wie immer einen Raspberry Pi (ich mag ihn einfach…) und erstellen uns erst einmal eine Ordnerstruktur – in meinem Fall speichere ich alles unter dem angemeldeten User/tutorials/eigene_docker_container/dev-env.
Wenn du diesem Beispiel folgen möchtest, musst du dich lediglich auf deinen Raspberry mit einem Terminal und deinem User verbinden.

Mit mkdir ~/tutorials/eigene_docker_container/dev-env erstellst du dann im Home-Verzeichnis die entsprechenden Ordner.

Wechsel jetzt mit cd ~/tutorials/eigene_docker_container/dev-env in das neu angelegte Verzeichnis.

Hier erstellen wir direkt zwei leere Dateien. Beachte dabei unbedingt, dass die Datei “Dockerfile” genauso – also großes D – genannt wird:

touch Dockerfile
touch requirements.txt

Ich werde dieses Image später dazu nutzen, ein paar Applikationen unter Python zu entwickeln. Daher füge ich erst einmal ein paar grundlegende Anforderungen hinzu. Sollte ich im Laufe des Entwickelns feststellen, dass ich noch andere Python Bibliotheken benötige, wird dies direkt dokumentiert und später genauso in ein finales Image eingebunden.
Also bearbeiten wir die requirements.txt, fügen folgendes hinzu und speichern die Änderungen:

Flask==2.0.1
requests==2.26.0
tabulate

Als Nächstes bearbeiten wir das, aktuell noch leere, Dockerfile und tragen ein paar Dinge dort ein. Es handelt sich um diverse Build-Befehle. Für mehr Informationen schaue bitte in die offizielle Dokumentation.

# Verwenden eines offiziellen Basisimage für Python 3.11
FROM python:3.11

# hier legen wir das Arbeitsverzeichnis innerhalb des Containers fest
WORKDIR /app

# Kopieren der requirements.txt in den Container
COPY requirements.txt requirements.txt

# Jetzt installieren wir alles aus der requirements.txt
RUN pip install -r requirements.txt

# Bibliotheken updaten und ein paar Entwicklertools hinzufügen (hier git und build-essential was ein Metapaket ist, das grundlegende Entwicklertools wie Compiler und Bibliotheken enthält)
RUN apt-get update && apt-get install -y \
    build-essential \
    git \
    && rm -rf /var/lib/apt/lists/*

Jetzt erstellen wir ein Image mit:

docker build -t dev-env-container:v1 .

Du kannst grundsätzlich direkt über das Terminal den Container starten oder den Weg über Portainer nutzen.

Terminal-Variante:

docker run --name dev-env-container -it dev-env-container:v1 bash

Der Befehl startet und verbindet dich direkt mit dem Container.
Du solltest dann im Prompt /app# sehen (dein festgelegtes Arbeitsverzeichnis).
Mit exit verlässt und beendest du den Container wieder.

Du wirst hier einen groben Überblick finden.
Allerdings biete ich dir auch noch etwas mehr Support an:

  • Du benötigst persönlichen Support
  • Du möchtest von Beginn an Unterstützung bei deinem Projekt
  • Du möchtest ein hier vorgestelltes Plugin durch mich installieren und einrichten lassen
  • Du würdest gerne ein von mir erstelltes Script etwas mehr an deine Bedürfnisse anpassen

Für diese Punkte und noch einiges mehr habe ich einen limitierten
VIP-Patreon Tarif
eingerichtet. Falls er dir dort zurzeit nicht angeboten wird,
kontaktiere mich bitte über Discord und wir finden eine Lösung!

Container über Portainer bereitstellen

Einfach den Namen des Images bei “Create Container” unter “Image” eintragen.
Und nicht durch das docker.io irritieren lassen. Da Portainer ja lokal auf unsere Images zugreift, findet er unser neu Erstelltes auch entsprechend und sucht nicht bei docker.io.
Hast du das Image nicht auf dem System erstellt, wo auch Portainer läuft, müsstest du noch entsprechend eine neue Registry erstellen. Dies wäre aber ein eigenes Thema und wird heute hier nicht behandelt.

image 208

Wir geben noch den Port an, da ich auch eine WebGui bereitstellen möchte und diese über den entsprechenden Port erreicht werden soll. Beispielhaft nehmen wir zum Testen den Port 5666.
Weiterhin auf jeden Fall unter dem Punkt “Advanced container settings” und “Console” die Auswahl “Interactive & TTY” auswählen

eigenen Docker Container erstellen

Mit Container verbinden

Diesen können wir über Portainer oder unser LinuxTerminal erreichen.

Für das Terminal:

docker exec -it dev-env-container /bin/bash

#mit exit kannst du den Container wieder verlassen

Für Portainer:

In der Portainer GUI auf “Container Übersicht“, und dann den kleinen Button klicken. Ein weiterer Klick auf Connect und du befindest dich in einem Terminal wieder.
Damit dies funktioniert musst du aber bei dem Deployment zuvor die Option “Interactive & TTY” unter dem Punkt “Advanced container settings” und “Console” ausgewählt haben.

image 209

Wenn du meiner Anleitung gefolgt bist, solltest du dich jetzt innerhalb deines Containers im Pfad /app befinden. Dieser ist natürlich noch komplett leer.

Allerdings haben wir ja python installiert. Dies startest du mit python und befindest dich in der entsprechenden Prompt-Umgebung. Mit exit() kannst du es verlassen.

In deinem eigenen Docker Container kannst du jetzt herumexperimentieren, Scripts entwickeln usw.

Bedenke aber: mit der normalen Installation sind alle Container Inhalte flüchtig, und entsprechend wieder weg, sobald du deinen Container neu aufsetzen würdest. Bei einem einfachen Stopp und Neustart bleiben deine nachträglich hinzugefügten Daten in der Regel (gibt Ausnahmen) erhalten.

Du kannst allerdings persistente Volumes außerhalb des Containers erstellen und mit dem ‘Inneren’ verbinden. Diese Thematik wurde bereits in meinen Artikeln zu Docker- und Portainer-Installationen behandelt.

Wie geht es jetzt weiter?

In diesem Artikel ging es in erster Linie darum, dir zu zeigen wie du einen eigenen Container aus Images erstellen, an deine Bedürfnisse anpassen, und als eigenes Image einbinden kannst.

Was du jetzt benötigst musst du selbst wissen. Beispielsweise als Basis ein Ubuntu-Image und dann erweitern mit Mysql-Server, Apache usw.
Du kannst alles wie oben beschrieben über das Dockerfile entsprechend einbinden.

Ich hoffe ich konnte dir ein wenig helfen und bin auch für weitere Fragen gerne für dich da. Schreibe in den Kommentaren oder schaue bei Discord vorbei.

Kurze Zusammenfassung

  • auf deinem Raspberry eine Ordnerstruktur erstellen wo du alles für deinen eigenen Docker Container speichern kannst
  • dort zwei Dateien erstellen:
    touch Dockerfile
    touch requirements.txt
  • in requirements.txt kommen alle Python-Abhängigkeiten hinein
  • in Dockerfile alle Build-Befehle
  • Build erstellen mit: docker build -t dev-env-container:v1 .
  • Container über Terminal bereitstellen: docker exec -it dev-env-container /bin/bash
  • Im Container weiteres zum testen nachinstallieren. Alles was benötigt wird am besten direkt in das Dockerfile eintragen (oder requirements.txt falls es sich um Python Abhängigkeiten handelt)
  • Final mit allem zufrieden und hoffentlich dokumentiert?
    Dann wieder ein neues Build erstellen (v1.1 oder so)
    usw.
FAQ - Frequently Asked Questions DarkWolfCave

FAQ´s

Docker ist eine Container-Plattform, die es ermöglicht, Anwendungen und deren Abhängigkeiten in isolierten Umgebungen, sogenannten Containern, zu verpacken und auszuführen. Diese Container sind leichtgewichtige, tragbare und konsistente Einheiten, die eine reibungslose Bereitstellung von Anwendungen über verschiedene Umgebungen hinweg ermöglichen.

Dieser Artikel zeigt, wie du deinen eigenen Docker Container erstellen kannst. Ob du ein erfahrener Tech-Enthusiast mit einer eigenen Entwicklungsumgebung bist oder gerade erst in die Welt der Containerisierung einsteigst, hier findest du eine detaillierte Anleitung, um deine eigene Entwicklungs-Containerumgebung einzurichten.

Auf deinem Server oder Raspberry Pi muss der Docker-Dienst installiert sein. Portainer ist hilfreich, aber optional. Falls du bisher noch kein Docker nutzt, wird ein empfohlener Artikel bereitgestellt, den du vorab durchgehen kannst.

Wenn im Folgenden von “dev-env” die Rede ist, bezieht sich dies auf “development environment” – also eine Entwicklungsumgebung.

Du hast weitere Fragen oder benötigst Hilfe? Gerne versuche ich im Rahmen meiner Möglichkeiten dich zu unterstützen. Dafür kannst du hier die Kommentar-Sektion (nicht vergessen Antworten zu abonnieren) nutzen oder du schaust auf meinem Discord-Kanal vorbei.

Avatar-Foto

Ich bin ein 1977 geborener Technik-Nerd. Mein erster Gefährte in der digitalen Welt war ein C64, der den Grundstein für meine Leidenschaft für Technologie legte. So wurde mein Hobby zum Beruf, und ich begann eine Ausbildung zum IT-Systemelektroniker. Selbst in meiner knappen Freizeit widme ich mich weiterhin meiner Leidenschaft fürs Gaming, verschiedene Programmiersprachen und andere IT-bezogene Themen. Ansonsten mag ich Hunde und bin fasziniert von Wölfen!

Gefällt dir der Beitrag?
Hinterlasse gerne ein paar Sterne!

Wie hilfreich war dieser Beitrag für Dich?

Klicke auf die Sterne um zu bewerten!

Durchschnittliche Bewertung 4.9 / 5. Anzahl Bewertungen: 7

Bisher keine Bewertungen! Sei der Erste, der diesen Beitrag bewertet.

Es tut uns leid, dass der Beitrag für dich nicht hilfreich war!

Lasse uns diesen Beitrag verbessern!

Wie können wir diesen Beitrag verbessern?

Abonnieren
Benachrichtige mich bei
guest
0 Kommentare
Neueste
Älteste
Inline Feedbacks
Alle Kommentare anzeigen
Inhalt