Benutzer-Werkzeuge

Webseiten-Werkzeuge


projekte:docker:portainer:start

Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen Revision Vorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
projekte:docker:portainer:start [2022/11/15 10:12]
admin
projekte:docker:portainer:start [2022/12/07 09:51] (aktuell)
admin
Zeile 2: Zeile 2:
  
 Portainer bietet eine grafische Oberfläche zur Verwaltung des Docker Swarm. Portainer bietet eine grafische Oberfläche zur Verwaltung des Docker Swarm.
 +
 +===== Vorbereitung =====
 +
 +Zuerst brauchen wir ein Datenverzeichnis für Portainer auf unserem NFS-Share:
 +  mkdir /docker/data/volumes/portainer
 +
 +===== Laden der YML Datei =====
  
 Portainer (dockerman01): Portainer (dockerman01):
  
 <code> <code>
-  curl -L https://downloads.portainer.io/portainer-agent-stack.yml -o portainer-agent-stack.yml+  curl -L https://downloads.portainer.io/ce2-16/portainer-agent-stack.yml -o portainer-agent-stack.yml
 </code> </code>
-Damit holt man sich erstmal das YML Manifest welches im Prinzip eine Docker Compose Datei ist.+Damit holt man sich erstmal das YML Manifest welches im Prinzip eine Docker Compose Datei ist. Diese werden wir noch ein bisschen anpassen. Interessant ist das ce2-16 (Community Edition) in der URL da es auch eine ee (Enterprise Edition) Version gibt für die man allerdings Lizenzen braucht. 
 + 
 + 
 +===== Konfiguration von Portainer ===== 
 <code> <code>
 version: '3.2' version: '3.2'
Zeile 14: Zeile 25:
 services: services:
   agent:   agent:
-    image: portainer/agent:2.11.1+    image: portainer/agent:latest
     volumes:     volumes:
       - /var/run/docker.sock:/var/run/docker.sock       - /var/run/docker.sock:/var/run/docker.sock
Zeile 26: Zeile 37:
  
   portainer:   portainer:
-    image: portainer/portainer-ce:2.11.1+    image: portainer/portainer-ce:latest
     command: -H tcp://tasks.agent:9001 --tlsskipverify     command: -H tcp://tasks.agent:9001 --tlsskipverify
     ports:     ports:
Zeile 33: Zeile 44:
       - "8000:8000"       - "8000:8000"
     volumes:     volumes:
-      - portainer_data:/data+      - /docker/data/volumes/portainer:/data
     networks:     networks:
       - agent_network       - agent_network
Zeile 46: Zeile 57:
     driver: overlay     driver: overlay
     attachable: true     attachable: true
 +</code>
  
 +Ich habe das volume gändert da ich für jeden Container ein eigenes Verzeichnis für die persistenten Daten habe:
 +  volumes:
 +    - portainer_data:/data
 +in
 +  volumes:
 +    - /docker/data/volumes/portainer:/data
 +Dann kann am Ende die Definition des Docker Volumes gelöscht werden, diese beiden Zeilen kommen ersatzlos weg:
 volumes: volumes:
   portainer_data:   portainer_data:
-</code> 
  
 +Ebenso habe ich bei den beiden image: Angaben die Versionsnummer auf "latest" geändert um immer die aktuelle Version zu bekommen.
  
 +Anschliessend kann Portainer geladen und gestartet werden:
 +
 +===== Laden und Starten =====
  
 <code> <code>
   docker stack deploy -c portainer-agent-stack.yml portainer   docker stack deploy -c portainer-agent-stack.yml portainer
 </code> </code>
 +
 +Jetzt muss man nur noch einen Moment warten bis die Portainer Container gestartet sind. Direkt nach dem Deploy sieht das noch so aus:
 +<code>
 +root@dockerman01:/docker/data/compose/portainer# docker service ls
 +ID             NAME                  MODE         REPLICAS   IMAGE                           PORTS
 +sb392p1tmj3v   portainer_agent       global       0/       portainer/agent:latest          
 +lb32q69txxhd   portainer_portainer   replicated   0/       portainer/portainer-ce:latest   *:8000->8000/tcp, *:9000->9000/tcp, *:9443->9443/tcp
 +</code>
 +Das heisst die Services sind bekannt, es laufen 0 von 4 Portainer Agenten und 0 von einem Portainer Server. Die Inhalte der Container werden gerade im Hintergrund geladen und dann gestartet. Bei mir hat das so ca. eine Minute gedauert aber das hängt ntürlich auch von der Internetgeschwindigkeit ab da diese aus dem Internet geholt werden.
 +
 +Irgendwann sieht das dann so aus und Portainer ist installiert und läuft:
 +<code>
 +root@dockerman01:/docker/data/compose/portainer# docker service ls
 +ID             NAME                  MODE         REPLICAS   IMAGE                           PORTS
 +sb392p1tmj3v   portainer_agent       global       4/       portainer/agent:latest          
 +lb32q69txxhd   portainer_portainer   replicated   1/       portainer/portainer-ce:latest   *:8000->8000/tcp, *:9000->9000/tcp, *:9443->9443/tcp
 +</code>
 +
 +===== Aufruf im Browser =====
 +
 +Und jetzt kann man endlich per https://172.17.200.24:9443 auf Portainer zugreifen und einen Benutzer und Passwort einrichten:
 +
 +{{:projekte:docker:portainer:docker-portainer-001.png|}}
 +Danach bekommt man eine erste Übersicht über den Docker Swarm
 +{{:projekte:docker:portainer:docker-portainer-002.png|}}
 +
 +Sollte man beim ersten Start zu lange warten bis man Portainer aufruft, z.B. weil man ein Wiki pflegt, kann es zu folgender Fehlermeldung kommen:
 +
 +{{:projekte:docker:portainer:docker-portainer-003.png|}}
 +
 +Dann einfach den Portainer Container neu starten:
 +
 +<code>
 +root@dockerman02:~# docker container ls
 +CONTAINER ID   IMAGE                           COMMAND                  CREATED          STATUS          PORTS                          NAMES
 +abc2e16a8abe   portainer/portainer-ce:latest   "/portainer -H tcp:/…"   33 seconds ago   Up 16 seconds   8000/tcp, 9000/tcp, 9443/tcp   portainer_portainer.1.9go806v5r708c9ngdrce4sfiq
 +168559a04656   portainer/agent:latest          "./agent"                38 seconds ago   Up 32 seconds                                  portainer_agent.n4u23ksil3wqdp4ee4iz5n43j.6djkwavvrzzomp8b9k5yepdne
 +</code>
 +Und mit der ID des containers diesen neu starten:
 +
 +  docker container restart abc2e16a8abe
  
  
projekte/docker/portainer/start.1668503577.txt.gz · Zuletzt geändert: 2022/11/15 10:12 von admin