Inhaltsverzeichnis

Portainer Stack Installation

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):

  curl -L https://downloads.portainer.io/ce2-16/portainer-agent-stack.yml -o portainer-agent-stack.yml

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

version: '3.2'

services:
  agent:
    image: portainer/agent:latest
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
      - /var/lib/docker/volumes:/var/lib/docker/volumes
    networks:
      - agent_network
    deploy:
      mode: global
      placement:
        constraints: [node.platform.os == linux]

  portainer:
    image: portainer/portainer-ce:latest
    command: -H tcp://tasks.agent:9001 --tlsskipverify
    ports:
      - "9443:9443"
      - "9000:9000"
      - "8000:8000"
    volumes:
      - /docker/data/volumes/portainer:/data
    networks:
      - agent_network
    deploy:
      mode: replicated
      replicas: 1
      placement:
        constraints: [node.role == manager]

networks:
  agent_network:
    driver: overlay
    attachable: true

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:

portainer_data:

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

  docker stack deploy -c portainer-agent-stack.yml portainer

Jetzt muss man nur noch einen Moment warten bis die Portainer Container gestartet sind. Direkt nach dem Deploy sieht das noch so aus:

root@dockerman01:/docker/data/compose/portainer# docker service ls
ID             NAME                  MODE         REPLICAS   IMAGE                           PORTS
sb392p1tmj3v   portainer_agent       global       0/4        portainer/agent:latest          
lb32q69txxhd   portainer_portainer   replicated   0/1        portainer/portainer-ce:latest   *:8000->8000/tcp, *:9000->9000/tcp, *:9443->9443/tcp

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:

root@dockerman01:/docker/data/compose/portainer# docker service ls
ID             NAME                  MODE         REPLICAS   IMAGE                           PORTS
sb392p1tmj3v   portainer_agent       global       4/4        portainer/agent:latest          
lb32q69txxhd   portainer_portainer   replicated   1/1        portainer/portainer-ce:latest   *:8000->8000/tcp, *:9000->9000/tcp, *:9443->9443/tcp

Aufruf im Browser

Und jetzt kann man endlich per https://172.17.200.24:9443 auf Portainer zugreifen und einen Benutzer und Passwort einrichten:

Danach bekommt man eine erste Übersicht über den Docker Swarm

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:

Dann einfach den Portainer Container neu starten:

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

Und mit der ID des containers diesen neu starten:

docker container restart abc2e16a8abe