Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Off Topic
  4. Grafana
  5. Schreibrechte auf grafana.ini in Docker

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.7k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.2k

Schreibrechte auf grafana.ini in Docker

Scheduled Pinned Locked Moved Grafana
67 Posts 6 Posters 3.2k Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • CodierknechtC Codierknecht

    @legro

    1. Logausgaben bitte hier in Code-Tags </> packen und nicht als Datei. So groß ist die ja nicht.

    2. Funktioniert bei mir einwandfrei, wenn ich jeweils ein leeres Verzeichnis mappe.
      Was genau willst Du an der grafana.ini manuell ändern?

    L Offline
    L Offline
    legro
    wrote on last edited by
    #42

    @codierknecht

    zu 1.

    grafana2
    date,stream,content
    2025/08/25 12:04:37,stdout,logger=settings t=2025-08-25T10:04:37.744409512Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:04:37,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:04:37,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:03:45,stdout,logger=settings t=2025-08-25T10:03:45.362410741Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:03:44,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:03:44,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:03:18,stdout,logger=settings t=2025-08-25T10:03:18.736400594Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:03:18,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:03:18,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:03:04,stdout,logger=settings t=2025-08-25T10:03:04.907764743Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:03:04,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:03:04,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:02:57,stdout,logger=settings t=2025-08-25T10:02:57.473460634Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:02:56,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:02:56,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:02:53,stdout,logger=settings t=2025-08-25T10:02:53.249727035Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:02:52,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:02:52,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:02:50,stdout,logger=settings t=2025-08-25T10:02:50.729829727Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:02:50,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:02:50,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:02:48,stdout,logger=settings t=2025-08-25T10:02:48.882208885Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:02:48,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:02:48,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:02:47,stdout,logger=settings t=2025-08-25T10:02:47.327149288Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:02:46,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:02:46,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:02:46,stdout,logger=settings t=2025-08-25T10:02:46.091829866Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:02:45,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:02:45,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    
    2025/08/25 12:02:44,stdout,logger=settings t=2025-08-25T10:02:44.735759481Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
    
    2025/08/25 12:02:43,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
    "
    2025/08/25 12:02:43,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
    

    zu 2.

    Ich möchte die Eintragen vornehmen, die nötig sind, Panels und Dashboards in der VIS von ioBroker anzeigen zu lassen. Zudem habe ich doch geschrieben, dass ich alles gelöscht habe - mehr noch - ich habe alle Verzeichnis neu angelegt.

    Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
    Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

    CodierknechtC 1 Reply Last reply
    0
    • L legro

      @codierknecht

      zu 1.

      grafana2
      date,stream,content
      2025/08/25 12:04:37,stdout,logger=settings t=2025-08-25T10:04:37.744409512Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:04:37,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:04:37,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:03:45,stdout,logger=settings t=2025-08-25T10:03:45.362410741Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:03:44,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:03:44,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:03:18,stdout,logger=settings t=2025-08-25T10:03:18.736400594Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:03:18,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:03:18,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:03:04,stdout,logger=settings t=2025-08-25T10:03:04.907764743Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:03:04,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:03:04,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:02:57,stdout,logger=settings t=2025-08-25T10:02:57.473460634Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:02:56,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:02:56,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:02:53,stdout,logger=settings t=2025-08-25T10:02:53.249727035Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:02:52,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:02:52,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:02:50,stdout,logger=settings t=2025-08-25T10:02:50.729829727Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:02:50,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:02:50,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:02:48,stdout,logger=settings t=2025-08-25T10:02:48.882208885Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:02:48,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:02:48,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:02:47,stdout,logger=settings t=2025-08-25T10:02:47.327149288Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:02:46,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:02:46,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:02:46,stdout,logger=settings t=2025-08-25T10:02:46.091829866Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:02:45,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:02:45,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      
      2025/08/25 12:02:44,stdout,logger=settings t=2025-08-25T10:02:44.735759481Z level=error msg="failed to parse \"/etc/grafana/grafana.ini\": open /etc/grafana/grafana.ini: no such file or directory"
      
      2025/08/25 12:02:43,stdout,"You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migrate-to-v51-or-later
      "
      2025/08/25 12:02:43,stdout,GF_PATHS_CONFIG='/etc/grafana/grafana.ini' is not readable.
      

      zu 2.

      Ich möchte die Eintragen vornehmen, die nötig sind, Panels und Dashboards in der VIS von ioBroker anzeigen zu lassen. Zudem habe ich doch geschrieben, dass ich alles gelöscht habe - mehr noch - ich habe alle Verzeichnis neu angelegt.

      CodierknechtC Online
      CodierknechtC Online
      Codierknecht
      Developer Most Active
      wrote on last edited by
      #43

      @legro

      Also zunächst mal ein paar Worte zu Docker:
      So ein Container ist als "Wegwerfartikel" konzeptioniert. Den zieht man hoch, macht was damit und wirft den anschließend wieder weg.
      Das ist dazu gedacht, "mal eben" eine Umgebung hochzuziehen und damit etwas anzustellen.

      Was man wiederverwenden möchte, wird über gemappte Verzeichnisse geregelt. Also indem man wie hier das Verzeichnis /var/lib/grafana extern mappt. Darin liegen dann z.B. die Plugins etc.

      Um die Einstellungen für "Panels in Vis" vorzunehmen, passt man üblicherweise die grafana.ini an ... das stimmt schon.
      Aber nicht in Docker-Containern!
      Hier werden die Einstellungen über Umgebungsvariablen vorgenommen, die man über das Compose als environment mitgibt.

      services:
        grafana:
          image: grafana/grafana
          container_name: grafana
          restart: unless-stopped
          ports:
            - '3000:3000'
          environment:
            - GF_SECURITY_COOKIE_SAMESITE=disabled
            - GF_SECURITY_ALLOW_EMBEDDING=true
          volumes:
            - /volume1/docker/grafana:/var/lib/grafana
      

      Damit kann man das Zeug immer wieder starten, verwerfen und komplett neu bauen, ohne dass man nach dem Start noch an Dateien im Container rumfummeln muss.

      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

      Proxmox 9.1.1 LXC|8 GB|Core i7-6700
      HmIP|ZigBee|Tasmota|Unifi
      Zabbix Certified Specialist
      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

      L 1 Reply Last reply
      0
      • OliverIOO OliverIO

        @legro

        ok ich habe deine konfiguration ausprobiert.
        sie passt vom format.

        ja den chown befehl muss doch sein, da grafana leider einen eigenen user/group verwendet und nicht wie sonst root oder 1000 verwendet.
        ok ist ein sicherheitsaspekt, macht das aber etwas schwieriger.

        bei mir war port 3000 auf dem host schon belegt, daher musste ich auf 3001:3000 ausweichen. evtl prüfst du das bei dir auch noch.

        danach habe ich auf der shell im container alle dateien kopiert

        cp -r /etc/grafana/* /etc/grafana1/
        

        die docker-compose datei geändert und neu gestartet.
        es funktioniert.

        L Offline
        L Offline
        legro
        wrote on last edited by
        #44

        @oliverio sagte in Schreibrechte auf grafana.ini in Docker:

        cp -r /etc/grafana/* /etc/grafana1/
        

        Das habe ich erfolgreich hinbekommen. Jetzt finde ich auf der Synology in dem Verzeichnis die gewünschten Konfigurationsdaten.

        die docker-compose datei geändert und neu gestartet.

        Hier weiß ich nicht so recht, was ich dazu alles tun muss. Kannst du mir dies bitte Schritt für Schritt beschreiben?

        Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
        Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

        OliverIOO 1 Reply Last reply
        0
        • L legro

          @oliverio sagte in Schreibrechte auf grafana.ini in Docker:

          cp -r /etc/grafana/* /etc/grafana1/
          

          Das habe ich erfolgreich hinbekommen. Jetzt finde ich auf der Synology in dem Verzeichnis die gewünschten Konfigurationsdaten.

          die docker-compose datei geändert und neu gestartet.

          Hier weiß ich nicht so recht, was ich dazu alles tun muss. Kannst du mir dies bitte Schritt für Schritt beschreiben?

          OliverIOO Offline
          OliverIOO Offline
          OliverIO
          wrote on last edited by OliverIO
          #45

          @legro

          Eigentlich hab ich dir das doch Schritt für Schritt oben beschrieben. Wenn die Dateien von grafana nach geafana1 kopiert worden sind liegen sie in deinem externen Ordner den du dann als normalen grafana einbindest, hier von oben kopiert:

          —-
          im anschluss änderst du im docker-compose das
          /etc/grafana1
          nach
          /etc/grafana

          und startest den container neu

          dann müsste er normal starten.
          dann kannst du die datei grafana.ini die sich in deinem lokalen verzeichnis auf der synology befindet bearbeiten.

          —-
          Bitte genau auf die Formulierungen
          IM Container
          und
          Lokaler Ordner/Verzeichnis
          achten

          Meine Adapter und Widgets
          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
          Links im Profil

          L 1 Reply Last reply
          0
          • CodierknechtC Codierknecht

            @legro

            Also zunächst mal ein paar Worte zu Docker:
            So ein Container ist als "Wegwerfartikel" konzeptioniert. Den zieht man hoch, macht was damit und wirft den anschließend wieder weg.
            Das ist dazu gedacht, "mal eben" eine Umgebung hochzuziehen und damit etwas anzustellen.

            Was man wiederverwenden möchte, wird über gemappte Verzeichnisse geregelt. Also indem man wie hier das Verzeichnis /var/lib/grafana extern mappt. Darin liegen dann z.B. die Plugins etc.

            Um die Einstellungen für "Panels in Vis" vorzunehmen, passt man üblicherweise die grafana.ini an ... das stimmt schon.
            Aber nicht in Docker-Containern!
            Hier werden die Einstellungen über Umgebungsvariablen vorgenommen, die man über das Compose als environment mitgibt.

            services:
              grafana:
                image: grafana/grafana
                container_name: grafana
                restart: unless-stopped
                ports:
                  - '3000:3000'
                environment:
                  - GF_SECURITY_COOKIE_SAMESITE=disabled
                  - GF_SECURITY_ALLOW_EMBEDDING=true
                volumes:
                  - /volume1/docker/grafana:/var/lib/grafana
            

            Damit kann man das Zeug immer wieder starten, verwerfen und komplett neu bauen, ohne dass man nach dem Start noch an Dateien im Container rumfummeln muss.

            L Offline
            L Offline
            legro
            wrote on last edited by legro
            #46

            @codierknecht sagte in Schreibrechte auf grafana.ini in Docker:

            @legro

            Also zunächst mal ein paar Worte zu Docker:

            Das ist mir bereits soweit alles klar.

            Um die Einstellungen für "Panels in Vis" vorzunehmen, passt man üblicherweise die grafana.ini an ... das stimmt schon.
            Aber nicht in Docker-Containern!
            Hier werden die Einstellungen über Umgebungsvariablen vorgenommen, die man über das Compose als environment mitgibt.

            services:
              grafana:
                image: grafana/grafana
                container_name: grafana
                restart: unless-stopped
                ports:
                  - '3000:3000'
                environment:
                  - GF_SECURITY_COOKIE_SAMESITE=disabled
                  - GF_SECURITY_ALLOW_EMBEDDING=true
                volumes:
                  - /volume1/docker/grafana:/var/lib/grafana
            

            Damit kann man das Zeug immer wieder starten, verwerfen und komplett neu bauen, ohne dass man nach dem Start noch an Dateien im Container rumfummeln muss.

            In der Tat, das ist sehr praktisch und ich bin froh, dass ich das mit dem compose verstanden habe.

            Nun zu den Einstellungen, die ich in der grafana.ini immer durchführe ..

            [auth.anonymous]
            enabled = true
            org_name = org_galegro
            org_role = Viewer
            
            [security]
            allow_embedding = true
            

            Wie sieht die compose.yaml für diesen Fall aus?

            Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
            Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

            CodierknechtC 1 Reply Last reply
            0
            • OliverIOO OliverIO

              @codierknecht

              Ja leider ist an dem Punkt die Dokumentation nicht so gut.
              Auch wissen wir nicht was er genau da ändern will.
              Wenn man auf folgender Seite die Beschreibung zur grafana.ini liest, sollte man tatsächlich jede Einstellung auch nur über Environment variablen verändern können.
              Das wäre dann noch einfacher wie die grafana.ini nach außen zu legen.
              Am Anfang der Seite sind ein paar wenige Beispiele von denen sich das Schema ableiten lässt

              • alles Großbuchstaben
              • beginnt immer mit GF
              • an 2. Position dann der sektionsname aus der ini
              • dann der eigentliche konfigurationsname
              • Trennung immer mit underscore _
                https://grafana.com/docs/grafana/latest/setup-grafana/configure-grafana/#configure-with-environment-variables

              Hier habe ich mal ein Beispiel einer docker-compose/stacks wo man sieht wie das aussehen kann.

              Spätestens hier würde ich den Container nicht mehr über einen Shell Befehl konfigurieren und starten, sondern nur noch über docker compose, sonst wird das unübersichtlich

              https://volkovlabs.io/blog/using-environment-variables-for-configuration-provisioning-and-dashboards-in-grafana-279661733416/#docker

              OliverIOO Offline
              OliverIOO Offline
              OliverIO
              wrote on last edited by OliverIO
              #47

              Lies dir das nochmal (sorgfältig) durch (inklusive link) und stelle dann die Frage nochmal

              @oliverio sagte in Schreibrechte auf grafana.ini in Docker:

              @codierknecht

              Ja leider ist an dem Punkt die Dokumentation nicht so gut.
              Auch wissen wir nicht was er genau da ändern will.
              Wenn man auf folgender Seite die Beschreibung zur grafana.ini liest, sollte man tatsächlich jede Einstellung auch nur über Environment variablen verändern können.
              Das wäre dann noch einfacher wie die grafana.ini nach außen zu legen.
              Am Anfang der Seite sind ein paar wenige Beispiele von denen sich das Schema ableiten lässt

              • alles Großbuchstaben
              • beginnt immer mit GF
              • an 2. Position dann der sektionsname aus der ini
              • dann der eigentliche konfigurationsname
              • Trennung immer mit underscore _
                https://grafana.com/docs/grafana/latest/setup-grafana/configure-grafana/#configure-with-environment-variables

              Hier habe ich mal ein Beispiel einer docker-compose/stacks wo man sieht wie das aussehen kann.

              Spätestens hier würde ich den Container nicht mehr über einen Shell Befehl konfigurieren und starten, sondern nur noch über docker compose, sonst wird das unübersichtlich

              https://volkovlabs.io/blog/using-environment-variables-for-configuration-provisioning-and-dashboards-in-grafana-279661733416/#docker

              Meine Adapter und Widgets
              TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
              Links im Profil

              1 Reply Last reply
              0
              • L legro

                @codierknecht sagte in Schreibrechte auf grafana.ini in Docker:

                @legro

                Also zunächst mal ein paar Worte zu Docker:

                Das ist mir bereits soweit alles klar.

                Um die Einstellungen für "Panels in Vis" vorzunehmen, passt man üblicherweise die grafana.ini an ... das stimmt schon.
                Aber nicht in Docker-Containern!
                Hier werden die Einstellungen über Umgebungsvariablen vorgenommen, die man über das Compose als environment mitgibt.

                services:
                  grafana:
                    image: grafana/grafana
                    container_name: grafana
                    restart: unless-stopped
                    ports:
                      - '3000:3000'
                    environment:
                      - GF_SECURITY_COOKIE_SAMESITE=disabled
                      - GF_SECURITY_ALLOW_EMBEDDING=true
                    volumes:
                      - /volume1/docker/grafana:/var/lib/grafana
                

                Damit kann man das Zeug immer wieder starten, verwerfen und komplett neu bauen, ohne dass man nach dem Start noch an Dateien im Container rumfummeln muss.

                In der Tat, das ist sehr praktisch und ich bin froh, dass ich das mit dem compose verstanden habe.

                Nun zu den Einstellungen, die ich in der grafana.ini immer durchführe ..

                [auth.anonymous]
                enabled = true
                org_name = org_galegro
                org_role = Viewer
                
                [security]
                allow_embedding = true
                

                Wie sieht die compose.yaml für diesen Fall aus?

                CodierknechtC Online
                CodierknechtC Online
                Codierknecht
                Developer Most Active
                wrote on last edited by
                #48

                @legro

                Embedding in Vis aus einem Grafana-Container:

                a01da09f-0ff6-4c84-ab7b-277ee80ced41-image.png

                services:
                  grafana:
                    image: grafana/grafana-oss
                    container_name: grafana
                    restart: unless-stopped
                    ports:
                      - '3000:3000'
                    environment:
                      - GF_SECURITY_COOKIE_SAMESITE=disabled
                      - GF_SECURITY_ALLOW_EMBEDDING=true
                      - GF_AUTH_ANONYMOUS_ENABLED=true
                      - GF_AUTH_ANONYMOUS_ORG_NAME=Main Org.
                      - GF_AUTH_ANONYMOUS_ORG_ROLE=Viewer
                    volumes:
                      - /volume1/docker/grafana/data:/var/lib/grafana
                
                

                "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                HmIP|ZigBee|Tasmota|Unifi
                Zabbix Certified Specialist
                Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                1 Reply Last reply
                1
                • OliverIOO OliverIO

                  @legro

                  Eigentlich hab ich dir das doch Schritt für Schritt oben beschrieben. Wenn die Dateien von grafana nach geafana1 kopiert worden sind liegen sie in deinem externen Ordner den du dann als normalen grafana einbindest, hier von oben kopiert:

                  —-
                  im anschluss änderst du im docker-compose das
                  /etc/grafana1
                  nach
                  /etc/grafana

                  und startest den container neu

                  dann müsste er normal starten.
                  dann kannst du die datei grafana.ini die sich in deinem lokalen verzeichnis auf der synology befindet bearbeiten.

                  —-
                  Bitte genau auf die Formulierungen
                  IM Container
                  und
                  Lokaler Ordner/Verzeichnis
                  achten

                  L Offline
                  L Offline
                  legro
                  wrote on last edited by legro
                  #49

                  @oliverio

                  Tut mir leid, aber vermutlich habe ich das noch immer nicht so richtig verstanden.

                  Ich habe /etc/grafana1 zu /etc/grafana in compose.yaml geändert. Anschließend habe ich einen Neustart des Containers ausgelöst.

                  Schaue ichanschließend in die Eigenschaften des Containers ..

                  c7dee637-7f5e-4bf6-835a-508a6128ea45-image.png

                  .. so ist das Mapping unverändert zu /etc/grafana1.

                  Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
                  Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

                  CodierknechtC 1 Reply Last reply
                  0
                  • L legro

                    @oliverio

                    Tut mir leid, aber vermutlich habe ich das noch immer nicht so richtig verstanden.

                    Ich habe /etc/grafana1 zu /etc/grafana in compose.yaml geändert. Anschließend habe ich einen Neustart des Containers ausgelöst.

                    Schaue ichanschließend in die Eigenschaften des Containers ..

                    c7dee637-7f5e-4bf6-835a-508a6128ea45-image.png

                    .. so ist das Mapping unverändert zu /etc/grafana1.

                    CodierknechtC Online
                    CodierknechtC Online
                    Codierknecht
                    Developer Most Active
                    wrote on last edited by Codierknecht
                    #50

                    @legro sagte in Schreibrechte auf grafana.ini in Docker:

                    Ich habe /etc/grafana1 zu /etc/grafana in compose.yaml geändert. Anschließend habe ich einen Neustart des Containers ausgelöst.

                    Warum per externer Datei? Nimm doch den eingebauten Editor.

                    2fcec7df-4986-441d-8fcd-087daac38bb9-image.png

                    Das Projekt muss danach neu erstellt werden.

                    "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                    Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                    HmIP|ZigBee|Tasmota|Unifi
                    Zabbix Certified Specialist
                    Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                    L 1 Reply Last reply
                    0
                    • CodierknechtC Codierknecht

                      @legro sagte in Schreibrechte auf grafana.ini in Docker:

                      Ich habe /etc/grafana1 zu /etc/grafana in compose.yaml geändert. Anschließend habe ich einen Neustart des Containers ausgelöst.

                      Warum per externer Datei? Nimm doch den eingebauten Editor.

                      2fcec7df-4986-441d-8fcd-087daac38bb9-image.png

                      Das Projekt muss danach neu erstellt werden.

                      L Offline
                      L Offline
                      legro
                      wrote on last edited by legro
                      #51

                      @codierknecht sagte in Schreibrechte auf grafana.ini in Docker:

                      Warum per externer Datei? Nimm doch den eingebauten Editor.

                      2fcec7df-4986-441d-8fcd-087daac38bb9-image.png

                      Das Projekt muss danach neu erstellt werden.

                      Wir müssen aufpassen, den Überblick nicht zu verlieren. Dein Vorschlag, alles über Umgebungsvariablen zu regeln, ist eine Lösung; der Vorschlag von @OliverIO beruht m.E. auf dem Versuch, /etc/grafana auf mein externes Verzeichnis ../grafana2/data zu mappen.

                      Wenn wir all das umgesetzt bekämen, hätten wir am Ende gar gleich zwei Lösungen für mein Problem.

                      Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
                      Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

                      OliverIOO 1 Reply Last reply
                      0
                      • L legro

                        @codierknecht sagte in Schreibrechte auf grafana.ini in Docker:

                        Warum per externer Datei? Nimm doch den eingebauten Editor.

                        2fcec7df-4986-441d-8fcd-087daac38bb9-image.png

                        Das Projekt muss danach neu erstellt werden.

                        Wir müssen aufpassen, den Überblick nicht zu verlieren. Dein Vorschlag, alles über Umgebungsvariablen zu regeln, ist eine Lösung; der Vorschlag von @OliverIO beruht m.E. auf dem Versuch, /etc/grafana auf mein externes Verzeichnis ../grafana2/data zu mappen.

                        Wenn wir all das umgesetzt bekämen, hätten wir am Ende gar gleich zwei Lösungen für mein Problem.

                        OliverIOO Offline
                        OliverIOO Offline
                        OliverIO
                        wrote on last edited by
                        #52

                        @legro
                        Na das mit den umgebungsvariablen hatte codierknecht und ich ziemlich am Anfang schon vorgeschlagen. Darauf bist du aber nicht eingegangen, weil ich davon ausgegangen bin das es dir nicht gefallen hat, bin ich dann den anderen Weg mit dir gegangen.

                        Ich gehe davon aus, das man den Text immer vollständig liest und bei Dingen die man da nicht versteht nachfragt.

                        Meine Adapter und Widgets
                        TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                        Links im Profil

                        L 2 Replies Last reply
                        1
                        • OliverIOO OliverIO

                          @legro
                          Na das mit den umgebungsvariablen hatte codierknecht und ich ziemlich am Anfang schon vorgeschlagen. Darauf bist du aber nicht eingegangen, weil ich davon ausgegangen bin das es dir nicht gefallen hat, bin ich dann den anderen Weg mit dir gegangen.

                          Ich gehe davon aus, das man den Text immer vollständig liest und bei Dingen die man da nicht versteht nachfragt.

                          L Offline
                          L Offline
                          legro
                          wrote on last edited by
                          #53

                          @oliverio sagte in Schreibrechte auf grafana.ini in Docker:

                          .., weil ich davon ausgegangen bin das es dir nicht gefallen hat, bin ich dann den anderen Weg mit dir gegangen.

                          Ich wusste zu dem Zeitpunkt noch nichts damit anzufangen.

                          Ich gehe davon aus, das man den Text immer vollständig liest und bei Dingen die man da nicht versteht nachfragt.

                          Dann hoffe ich mal, dass du auch meine letzte Antwort gelesen hast.😉

                          Warum sollte ich die Datei compose.yaml ändern? Nach der von dir vorgeschlagenen Änderung und dem Neustart des Containers ist noch immer /etc/grafana1 gemappt.

                          Muss/soll ich den Container löschen und neu erstellen?

                          Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
                          Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

                          CodierknechtC 1 Reply Last reply
                          0
                          • L legro

                            @oliverio sagte in Schreibrechte auf grafana.ini in Docker:

                            .., weil ich davon ausgegangen bin das es dir nicht gefallen hat, bin ich dann den anderen Weg mit dir gegangen.

                            Ich wusste zu dem Zeitpunkt noch nichts damit anzufangen.

                            Ich gehe davon aus, das man den Text immer vollständig liest und bei Dingen die man da nicht versteht nachfragt.

                            Dann hoffe ich mal, dass du auch meine letzte Antwort gelesen hast.😉

                            Warum sollte ich die Datei compose.yaml ändern? Nach der von dir vorgeschlagenen Änderung und dem Neustart des Containers ist noch immer /etc/grafana1 gemappt.

                            Muss/soll ich den Container löschen und neu erstellen?

                            CodierknechtC Online
                            CodierknechtC Online
                            Codierknecht
                            Developer Most Active
                            wrote on last edited by Codierknecht
                            #54

                            @legro sagte in Schreibrechte auf grafana.ini in Docker:

                            Muss/soll ich den Container löschen und neu erstellen?

                            Nimm dieses Docker-Compose:

                            services:
                              grafana:
                                image: grafana/grafana-oss
                                container_name: grafana
                                restart: unless-stopped
                                ports:
                                  - '3000:3000'
                                environment:
                                  - GF_SECURITY_COOKIE_SAMESITE=disabled
                                  - GF_SECURITY_ALLOW_EMBEDDING=true
                                  - GF_AUTH_ANONYMOUS_ENABLED=true
                                  - GF_AUTH_ANONYMOUS_ORG_NAME=Main Org.
                                  - GF_AUTH_ANONYMOUS_ORG_ROLE=Viewer
                                volumes:
                                  - /volume1/docker/grafana/data:/var/lib/grafana
                            

                            pack das in den Editor in der GUI, passe den Pfad an und beim Speichern wählst Du die Option "neu erstellen".

                            bf489291-70dd-4cb9-92df-b76808b7a2cf-image.png

                            Man muss da gar nicht an Dateien rumeditieren. Geht alles über das UI.

                            "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                            Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                            HmIP|ZigBee|Tasmota|Unifi
                            Zabbix Certified Specialist
                            Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                            L 1 Reply Last reply
                            0
                            • CodierknechtC Codierknecht

                              @legro sagte in Schreibrechte auf grafana.ini in Docker:

                              Muss/soll ich den Container löschen und neu erstellen?

                              Nimm dieses Docker-Compose:

                              services:
                                grafana:
                                  image: grafana/grafana-oss
                                  container_name: grafana
                                  restart: unless-stopped
                                  ports:
                                    - '3000:3000'
                                  environment:
                                    - GF_SECURITY_COOKIE_SAMESITE=disabled
                                    - GF_SECURITY_ALLOW_EMBEDDING=true
                                    - GF_AUTH_ANONYMOUS_ENABLED=true
                                    - GF_AUTH_ANONYMOUS_ORG_NAME=Main Org.
                                    - GF_AUTH_ANONYMOUS_ORG_ROLE=Viewer
                                  volumes:
                                    - /volume1/docker/grafana/data:/var/lib/grafana
                              

                              pack das in den Editor in der GUI, passe den Pfad an und beim Speichern wählst Du die Option "neu erstellen".

                              bf489291-70dd-4cb9-92df-b76808b7a2cf-image.png

                              Man muss da gar nicht an Dateien rumeditieren. Geht alles über das UI.

                              L Offline
                              L Offline
                              legro
                              wrote on last edited by
                              #55

                              @codierknecht sagte in Schreibrechte auf grafana.ini in Docker:

                              Nimm dieses Docker-Compose: ..

                              Nachdem ich nun um die Verwendung von Umgebungsvariablen weiß, will ich das Ganze auch verstehen. Was ich glaube verstanden zu haben ..

                              • Alle Variablen beginnen mit dem Präfix GF_.
                              • Danach folgt der Bereich oder Abschnitt aus der grafana.ini-Konfigurationsdatei, der verändert werden soll, in Großbuchstaben (z.B. SECURITY, SERVER, AUTH).
                              • Anschließend folgt der Name der Option aus der grafana.ini (ebenfalls in Großbuchstaben!) angefügt mit Unterstrichen.
                              • Alle Elemente werden stets mit Unterstrichen von einander getrennt notiert.

                              Beispiel: Somit sollte das Admin-Passwort in der Sektion [security] der grafana.ini heißen: GF_SECURITY_ADMIN_PASSWORD=<mein Passwort>

                              Ist das so richtig?

                              Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
                              Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

                              CodierknechtC 1 Reply Last reply
                              0
                              • L legro

                                @codierknecht sagte in Schreibrechte auf grafana.ini in Docker:

                                Nimm dieses Docker-Compose: ..

                                Nachdem ich nun um die Verwendung von Umgebungsvariablen weiß, will ich das Ganze auch verstehen. Was ich glaube verstanden zu haben ..

                                • Alle Variablen beginnen mit dem Präfix GF_.
                                • Danach folgt der Bereich oder Abschnitt aus der grafana.ini-Konfigurationsdatei, der verändert werden soll, in Großbuchstaben (z.B. SECURITY, SERVER, AUTH).
                                • Anschließend folgt der Name der Option aus der grafana.ini (ebenfalls in Großbuchstaben!) angefügt mit Unterstrichen.
                                • Alle Elemente werden stets mit Unterstrichen von einander getrennt notiert.

                                Beispiel: Somit sollte das Admin-Passwort in der Sektion [security] der grafana.ini heißen: GF_SECURITY_ADMIN_PASSWORD=<mein Passwort>

                                Ist das so richtig?

                                CodierknechtC Online
                                CodierknechtC Online
                                Codierknecht
                                Developer Most Active
                                wrote on last edited by Codierknecht
                                #56

                                @legro sagte in Schreibrechte auf grafana.ini in Docker:

                                Ist das so richtig?

                                So verstehe ich das auch. Die Doku ist da ein bisschen unübersichtlich.

                                Gib mir ein paar Minuten ... ich probiere das aus.

                                Edit
                                Sieht so aus, als würde das funktionieren :grin:

                                "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                                Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                                HmIP|ZigBee|Tasmota|Unifi
                                Zabbix Certified Specialist
                                Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                                1 Reply Last reply
                                1
                                • OliverIOO OliverIO

                                  @legro
                                  Na das mit den umgebungsvariablen hatte codierknecht und ich ziemlich am Anfang schon vorgeschlagen. Darauf bist du aber nicht eingegangen, weil ich davon ausgegangen bin das es dir nicht gefallen hat, bin ich dann den anderen Weg mit dir gegangen.

                                  Ich gehe davon aus, das man den Text immer vollständig liest und bei Dingen die man da nicht versteht nachfragt.

                                  L Offline
                                  L Offline
                                  legro
                                  wrote on last edited by
                                  #57

                                  @oliverio

                                  Nun möchte ich auch deinen Lösungsvorschlag verstehen. Könntest du mich bitte dabei unterstützen?

                                  Wenn ich das Ganze richtig verstanden habe ..

                                  • Es ist (warum auch immer) nicht möglich das Docker interne Verzeichnis /etc/grafana auf ein externes Verzeichnis auf der Synology (../grafana2/config) zu mappen.
                                  • Daher wird das in Docker nicht existierende interne Verzeichnis /etc/grafana1 auf das externe ../grafana2/config gemappt.
                                  • Nun kann man im Terminal mittels ..
                                    sudo docker exec -it grafana2 /bin/bash
                                    cp -r /etc/grafana/* /etc/grafana1/ den Inhalt in das externe Verzeichnis ../grafana2/config kopieren.
                                    Im der Terminal der Synology kann ich nun grafana.ini nach Belieben anpassen.

                                  So weit, so gut. Und nun?

                                  Ich sehe nun nur die Möglichkeit erneut im Terminal intern den Inhalt des externen Verzeichnisses nun umgekehrt nach /etc/granfana zu kopieren, wobei es in meinem Fall ausreicht, grafana.ini zu überschreiben/kopieren.

                                  Ich sehe keine Möglichkeit durch Änderungen von compose.yml das externe Verzeichnis auf das interne /etc/grafana zu mappen.

                                  Was habe ich ggf. noch immer nicht verstanden?.

                                  Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
                                  Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

                                  OliverIOO 1 Reply Last reply
                                  0
                                  • L legro

                                    @oliverio

                                    Nun möchte ich auch deinen Lösungsvorschlag verstehen. Könntest du mich bitte dabei unterstützen?

                                    Wenn ich das Ganze richtig verstanden habe ..

                                    • Es ist (warum auch immer) nicht möglich das Docker interne Verzeichnis /etc/grafana auf ein externes Verzeichnis auf der Synology (../grafana2/config) zu mappen.
                                    • Daher wird das in Docker nicht existierende interne Verzeichnis /etc/grafana1 auf das externe ../grafana2/config gemappt.
                                    • Nun kann man im Terminal mittels ..
                                      sudo docker exec -it grafana2 /bin/bash
                                      cp -r /etc/grafana/* /etc/grafana1/ den Inhalt in das externe Verzeichnis ../grafana2/config kopieren.
                                      Im der Terminal der Synology kann ich nun grafana.ini nach Belieben anpassen.

                                    So weit, so gut. Und nun?

                                    Ich sehe nun nur die Möglichkeit erneut im Terminal intern den Inhalt des externen Verzeichnisses nun umgekehrt nach /etc/granfana zu kopieren, wobei es in meinem Fall ausreicht, grafana.ini zu überschreiben/kopieren.

                                    Ich sehe keine Möglichkeit durch Änderungen von compose.yml das externe Verzeichnis auf das interne /etc/grafana zu mappen.

                                    Was habe ich ggf. noch immer nicht verstanden?.

                                    OliverIOO Offline
                                    OliverIOO Offline
                                    OliverIO
                                    wrote on last edited by OliverIO
                                    #58

                                    @legro

                                    • in /etc/grafana liegen für grafana wichtige dateien ohne die das system nicht startet
                                    • wenn du nun ein leeres verzeichnis auf deinem LOKALEN dateisystem mappst, dann ist das verzeichnis IM container ebenfalls leer, ergo system startet nicht
                                    • der zwischenschritt mit /etc/grafana1 legt das zunächst leere verzeichnis unter diesem namen IN DEN container, du kopierst die dateien, änderst das mapping wieder auf /etc/grafana, so sind nun alle notwendigen dateien für grafana unter /etc/grafana verfügbar + sie liegen auch in deinem LOKALEN verzeichnis in dem du die bearbeiten kannst.

                                    ein docker image besteht aus verschiedenen schichten/layers, die sich der reihe nach ergänzen aber auch überlagern können, so das am ende für das betriebssystem aber nur eine einzige sicht darauf besteht.

                                    ich habe mal einen blogartikel gefunden, der das etwas visuell darstellt
                                    https://iammathew.com/blog/understanding-docker-images/filesystem

                                    das verzeichnis /etc/grafana mit seinen dateien ist nachdem du dein lokales verzeichnis da drauf gemountet hast immer noch da, da es aber von dem mount zu deinem lokalen leeren verzeichnis überlagert wird, halt für das betriebssystem leer und ohne die dateien mag grafana halt nicht starten.

                                    um notwendige dateien vollautomatisch auch in einem leeren gemounteten Verzeichnis nach aussen bereitzustellen, müsste der imageersteller etwas machen (bei container start prüfen ob alle notwendigen dateien da sind und die fehlenden kopieren) das machen aber viele nicht.

                                    wie schon gesagt, die grafana leute haben eher den environment weg eingeschlagen.

                                    Meine Adapter und Widgets
                                    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                                    Links im Profil

                                    L 1 Reply Last reply
                                    1
                                    • OliverIOO OliverIO

                                      @legro

                                      • in /etc/grafana liegen für grafana wichtige dateien ohne die das system nicht startet
                                      • wenn du nun ein leeres verzeichnis auf deinem LOKALEN dateisystem mappst, dann ist das verzeichnis IM container ebenfalls leer, ergo system startet nicht
                                      • der zwischenschritt mit /etc/grafana1 legt das zunächst leere verzeichnis unter diesem namen IN DEN container, du kopierst die dateien, änderst das mapping wieder auf /etc/grafana, so sind nun alle notwendigen dateien für grafana unter /etc/grafana verfügbar + sie liegen auch in deinem LOKALEN verzeichnis in dem du die bearbeiten kannst.

                                      ein docker image besteht aus verschiedenen schichten/layers, die sich der reihe nach ergänzen aber auch überlagern können, so das am ende für das betriebssystem aber nur eine einzige sicht darauf besteht.

                                      ich habe mal einen blogartikel gefunden, der das etwas visuell darstellt
                                      https://iammathew.com/blog/understanding-docker-images/filesystem

                                      das verzeichnis /etc/grafana mit seinen dateien ist nachdem du dein lokales verzeichnis da drauf gemountet hast immer noch da, da es aber von dem mount zu deinem lokalen leeren verzeichnis überlagert wird, halt für das betriebssystem leer und ohne die dateien mag grafana halt nicht starten.

                                      um notwendige dateien vollautomatisch auch in einem leeren gemounteten Verzeichnis nach aussen bereitzustellen, müsste der imageersteller etwas machen (bei container start prüfen ob alle notwendigen dateien da sind und die fehlenden kopieren) das machen aber viele nicht.

                                      wie schon gesagt, die grafana leute haben eher den environment weg eingeschlagen.

                                      L Offline
                                      L Offline
                                      legro
                                      wrote on last edited by legro
                                      #59

                                      @oliverio

                                      Vielen Dank für deine Rückmeldung.

                                      Mittlerweile konnte ich anhand einiger Quellen ebenfalls eine Antwort finden - durch die hier geführte Diskussion wusste ich schließlich, nach was ich suchen muss. Demnach darf das externe Verzeichnis, das auf das interne /etc/grafana gemappt werden soll, nicht leer sein, sondern muss bereits die korrekte Struktur beinhalten.

                                      Damit wird die oben ausgegebene Fehlermeldung (grafana.ini nicht gefunden) verständlich.

                                      Dein Vorschlag ist also goldrichtig. Indem man /etc/grafana auf das externe Verzeichnis kopiert, kann bei einer Neuinstallation das externe Verzeichnis auf das interne /etc/grafana gemappt werden.

                                      Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
                                      Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

                                      OliverIOO L 2 Replies Last reply
                                      0
                                      • L legro

                                        @oliverio

                                        Vielen Dank für deine Rückmeldung.

                                        Mittlerweile konnte ich anhand einiger Quellen ebenfalls eine Antwort finden - durch die hier geführte Diskussion wusste ich schließlich, nach was ich suchen muss. Demnach darf das externe Verzeichnis, das auf das interne /etc/grafana gemappt werden soll, nicht leer sein, sondern muss bereits die korrekte Struktur beinhalten.

                                        Damit wird die oben ausgegebene Fehlermeldung (grafana.ini nicht gefunden) verständlich.

                                        Dein Vorschlag ist also goldrichtig. Indem man /etc/grafana auf das externe Verzeichnis kopiert, kann bei einer Neuinstallation das externe Verzeichnis auf das interne /etc/grafana gemappt werden.

                                        OliverIOO Offline
                                        OliverIOO Offline
                                        OliverIO
                                        wrote on last edited by
                                        #60

                                        @legro

                                        genau

                                        Meine Adapter und Widgets
                                        TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                                        Links im Profil

                                        1 Reply Last reply
                                        0
                                        • L legro

                                          @oliverio

                                          Vielen Dank für deine Rückmeldung.

                                          Mittlerweile konnte ich anhand einiger Quellen ebenfalls eine Antwort finden - durch die hier geführte Diskussion wusste ich schließlich, nach was ich suchen muss. Demnach darf das externe Verzeichnis, das auf das interne /etc/grafana gemappt werden soll, nicht leer sein, sondern muss bereits die korrekte Struktur beinhalten.

                                          Damit wird die oben ausgegebene Fehlermeldung (grafana.ini nicht gefunden) verständlich.

                                          Dein Vorschlag ist also goldrichtig. Indem man /etc/grafana auf das externe Verzeichnis kopiert, kann bei einer Neuinstallation das externe Verzeichnis auf das interne /etc/grafana gemappt werden.

                                          L Offline
                                          L Offline
                                          legro
                                          wrote on last edited by legro
                                          #61

                                          @Alle

                                          Hier nun eine kleine Zusammenfassung aus all den hier im Thread zusammengetragenen Ideen. Vielen Dank an alle, die hier tatkräftig mitgeholfen haben.

                                          Die Installation von Grafana im Container Manager (Docker) einer Synology erfordert einige Vorkehrungen. Der bevorzugte Weg sollte die Verwendung einer sog. compose.yml Datei sein, die im Wesentlichen eine Art Bauanleitung für die gewünschte Installation darstellt. Im Folgenden wird auch nur diese Lösung beschrieben. Die Installationen über compose.yml werden als Projekte realisiert.

                                          Da nach jedem Neustart der Synology oder des Containers alle Daten verloren gehen, muss man dafür Sorge tragen, dass die Konfigurationsdaten in /etc/grafana (insbesondere grafana.ini) und die in /var/lib/grafana mit den Panels und Dashboards außerhalb des Containers in einem externen Verzeichnis auf der Synology gesichert werden. Dabei sind drei Fälle zu unterscheiden ..

                                          • Nur die Daten in /var/lib/grafana werden persistent in einem externen Verzeichnis auf der Synology gespeichert. Der Inhalt der Datei grafana.ini wird über Umgebungsvariablen angepasst.
                                          • Sowohl das Verzeichnis mit den Konfigurationsdaten /etc/grafana als auch jenes mit den Daten /var/lib/grafana werden in externen Verzeichnissen auf der Synology persistent gespeichert.
                                          • Statt das gesamte interne Verzeichnis /etc/grafana zu mappen, wird nur die Datei grafana.ini gemappt. (Wird hier nicht dokumentiert)

                                          Die im Folgenden vorausgesetzte Verzeichnisstruktur auf der Synology, welche die persistente Daten aufnehmen soll, sieht folgendermaßen aus ..

                                          .. /docker/grafana/config
                                          .. /docker/grafana/data

                                          Diese Verzeichnisse sollten mit Zugriffsrechten für Everyone für Lesen und Schreiben versehen sein. Der oft zu findende Hinweis, chown -R 472:472 /volume2/docker/grafana zu verwenden, ist leider nicht zielführend.

                                          1.Methode:

                                          Das nachfolgende Beispiel zeigt die nötigen Anpassungen für die Einbindung der Panels und Dashboards in die VIS von ioBroker, wobei ggf. nötige Anpassungen der Datei grafana.ini über Umgebungsvariablen bereitgestellt werden ..

                                          services:
                                            grafana:
                                              image: grafana/grafana-oss
                                              container_name: grafana
                                              restart: unless-stopped
                                              ports:
                                                - '3000:3000'
                                              environment:
                                                - GF_SECURITY_COOKIE_SAMESITE=disabled
                                                - GF_SECURITY_ALLOW_EMBEDDING=true
                                                - GF_AUTH_ANONYMOUS_ENABLED=true
                                                - GF_AUTH_ANONYMOUS_ORG_NAME=Main Org.
                                                - GF_AUTH_ANONYMOUS_ORG_ROLE=Viewer
                                              volumes:
                                                - /volume2/docker/grafana/data:/var/lib/grafana
                                          

                                          Die Syntax zum Aufbau der Umgebungsvariablen ..

                                          • Alle Variablen beginnen mit dem Präfix GF_.
                                          • Danach folgt der Bereich oder Abschnitt aus der grafana.ini-Konfigurationsdatei, der verändert werden soll, in Großbuchstaben (z.B. SECURITY, SERVER, AUTH).
                                          • Anschließend folgt der Name der Option aus der grafana.ini (ebenfalls in Großbuchstaben!) angefügt mit Unterstrichen.
                                          • der Wert der jeweiligen Variable wird mit = eingefügt.
                                          • Alle Elemente werden stets mit Unterstrichen von einander getrennt notiert.

                                          ein Beispiel: Das Admin-Passwort in der Sektion [security] der grafana.ini wird gesetzt mit: GF_SECURITY_ADMIN_PASSWORD=<mein Passwort>

                                          2.Methode

                                          Hier lautet die compose.yml wie folgt ..

                                          services:
                                            grafana:
                                              image: grafana/grafana-oss
                                              container_name: grafana
                                              restart: unless-stopped
                                              ports:
                                                - '3000:3000'
                                              volumes:
                                                - /volume2/docker/grafana/data:/var/lib/grafana
                                                - /volume2/docker/grafana/config:/etc/grafana
                                          

                                          Leider funktioniert das Ganze so nicht ohne Weiteres. Das externe Verzeichnis ../grafana/config darf nicht leer sein, sondern muss bereits eine gültige Struktur, wie sie in einem internen Verzeichnis /etc/grafana vorliegt, enthalten.

                                          Bleibt die Frage, wie man das config Verzeichnis korrekt gefüllt bekommt. Hier ein mögliches Vorgehen ..

                                          • Man verwendet für eine temporäre Installation die compose.yml mit folgendem Inhalt ..
                                          services:
                                            grafana:
                                              image: grafana/grafana-oss
                                              container_name: grafana
                                              restart: unless-stopped
                                              ports:
                                                - '3000:3000'
                                              volumes:
                                                - /volume2/docker/grafana/data:/var/lib/grafana
                                                - /volume2/docker/grafana/config:/etc/grafana0
                                          

                                          Das Verzeichnis /etc/grafana0 ist (normalerweise) in keinem Image von Grafana vorhanden. Es dient sozusagen als Vorlagenspeicher für das spätere /etc/grafana. Obwohl das Verzeichnis intern nicht existiert, kann es im externen Verzeichnis config auf der Synology gefüllt werden. Hierzu ..

                                          • verbindet man sich über das Terminal via ..
                                            sudo docker exec -it grafana /bin/bash
                                            .. mit Grafana im Container Manager, wobei grafana dem Namen des Grafana-Containers entspricht.
                                          • Im Terminal kopiert man nun mittels
                                            cp -r /etc/grafana/* /etc/grafana0/ den Inhalt von ../grafana/config in das externe Verzeichnis.

                                          Der letzte Schritt sorgt dafür, dass das externe Verzeichnis ../docker/grafana/config mit korrekten Daten der Standardkonfiguration von Grafana gefüllt wurde.

                                          Nun gilt es den Grafana-Container wieder zu löschen und man kann anschließend mittels ..

                                          services:
                                            grafana:
                                              image: grafana/grafana-oss
                                              container_name: grafana
                                              restart: unless-stopped
                                              ports:
                                                - '3000:3000'
                                              volumes:
                                                - /volume2/docker/grafana/data:/var/lib/grafana
                                                - /volume2/docker/grafana/config:/etc/grafana
                                          

                                          .. die gewünschte Installation erzeugen, bei der nun das interne Verzeichnis /var/bin/grafana auf das externe ../docker/grafana/data und das interne /etc/grafana auf das externe Verzeichnis ../docker/grafana/config gemappt wurde.

                                          Meine Empfehlung

                                          Ich bevorzuge grundsätzlich die 2. Methode, die es erlaubt, die Datei grafana.ini komfortabel mit dem Editor der Synology zu bearbeiten.

                                          Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
                                          Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

                                          L CodierknechtC 2 Replies Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          787

                                          Online

                                          32.4k

                                          Users

                                          81.5k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe