Seit ich festgestellt habe, dass sich die von uns vorbereitete Anwendung erheblich vergrößert hat, habe ich beschlossen, eine völlig neue Methode zur Automatisierung des Prozesses ihrer Einführung zu finden. Es war wichtig für mich, eine Lösung zu finden, die es ermöglicht, neue Funktionen isoliert zu aktivieren.
Einführung
Die Entdeckung einer einfacheren Methode der Prozessautomatisierung würde meine Arbeit und die Arbeit meiner gesamten Belegschaft erheblich verbessern. Team. Ich dachte: "Warum nicht Docker verwenden?"
Während der Vorbereitungsphase habe ich zwei Setups erstellt: eines für die Front-End-Anwendung und das andere für die API. Unten sehen Sie eine Präsentation dessen, was ich während des Entwicklungsprozesses gelernt habe.
Das erste Problem
Ich möchte ein geklontes Repository im Container haben, also habe ich einen ssh-Schlüssel über den ADD-Befehl im Dockerfile hinzugefügt:
ADD ~/.ssh/testowy
Und bam! Die Datei wird nicht gefunden. Warum?
Nehmen wir an, dass wir die folgende Ordnerstruktur haben:
docker/
|-- stuff/
|-- test.txt
|-- Dockerfile
server/
|-- data
|-- setup.yml
Befehl ausführen bauen
im login-queue
und Sie können nur Dateien aus dem lokalen Ordner und seinen lokalen Unterordnern hinzufügen, z. B. Material.
Wenn Sie die Server
werden Sie eine Meldung erhalten: "Kontext kann nicht vorbereitet werden"
Dockerignore
Haben Sie sich jemals gefragt, warum das Bild so lange braucht, um aufgebaut zu werden? Vielleicht haben Sie nicht .dockerignore
, um Dateien zu ignorieren, die im Bild nicht benötigt werden. Die Website .git
sollte automatisch entfernt werden, ebenso wie alle temporären Dateien.
Reihenfolge der Befehle im Dockerfile
Docker speichert jede Zeile in Form einer Dockerdatei und nach der Erstellung wird jede Zeile als Schicht gespeichert. Es ist sehr wichtig, die Reihenfolge der einzelnen Befehle nicht zu oft zu ändern.
VON ubuntu
RUN apt-get install -y software-properties-common python
RUN add-apt-repository ppa:chris-lea/node.js
RUN echo "deb http://us.archive.ubuntu.com/ubuntu/ präzises Universum" >> /etc/apt/sources.list
RUN apt-get update
RUN apt-get install -y nodejs
RUN apt-get install -y nodejs=0.6.12~dfsg1-1ubuntu1
RUN mkdir /var/www
ADD app.js /var/www/app.js
CMD ["/usr/bin/node", "/var/www/app.js"]
Wenn Sie z. B. die letzte Zeile im Dockerfile ändern, werden alle vorherigen Zeilen aus dem Cache heruntergeladen, während die letzte Zeile geändert wird. Wenn Sie die Zeile Nr. 4 ersetzen, werden alle Zeilen ab der Zeile 4 bis zum Ende geändert. Aus diesem Grund ist es sinnvoll, Befehle, die nicht geändert werden sollen, an den Anfang der Datei zu stellen.
Kopieren von Dateien in ein Image
Es lohnt sich, darüber nachzudenken, wofür ein bestimmtes Bild verwendet werden soll. Wenn Sie es benötigen, um einen Dienst einmal zu starten, kopieren Sie einfach die Code Inhalt direkt auf das Bild übertragen:
COPY . /workdir
Das macht es leider unmöglich, Dateien zu bearbeiten, und jedes Mal, wenn Sie Ihren Code bearbeiten wollen, müssen Sie das Bild neu erstellen.
Wenn Sie MacOS verwenden und das erstellte Image für die Entwicklung nutzen wollen, müssen Sie diese Angelegenheit etwas anders angehen. Wenn Sie Volumes verwenden, müssen Sie sich darauf einstellen, dass dies eine extrem langsame Lösung ist (z.B. wird das Kopieren einer Datei vom Host in den Container mit einer Geschwindigkeit von 4,5 MB/s durchgeführt, während das Kopieren innerhalb des Containers mit einer 10-20x höheren Geschwindigkeit erfolgt). Glücklicherweise, wie Sie sehen können unter LinkDas Problem ist bekannt, und seine Lösung ist das Hauptanliegen des Teams, das für die Entwicklung von Docker für Mac zuständig ist.
Wie können Sie Docker in dieser Situation für die Entwicklung nutzen?
Sie können es für externe Dienste, z.B. Redis/PSQL/Elasticsearch nutzen oder fertige Lösungen verwenden, die rsync anbieten: https://github.com/brikis98/docker-osx-dev
Zusammenfassend
Wenn Sie ein großes Team haben und eine neue Funktion testen wollen, ist Docker das ideale Werkzeug! Aber würde ich es für einen Produktionsstart eines Servers verwenden? Ich bin noch nicht ganz überzeugt...
Außerdem empfehle ich einige herausragende Artikel: