Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. English
  3. ioBroker general
  4. How to lower disk writes (for extending life of an sd card)

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    16
    1
    959

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    690

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.0k

How to lower disk writes (for extending life of an sd card)

Geplant Angeheftet Gesperrt Verschoben ioBroker general
states.jsonwrite interval
16 Beiträge 5 Kommentatoren 2.0k Aufrufe 3 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • apollon77A apollon77

    @Tomasz-Nowak sagte in How to lower disk writes (for extending life of an sd card):

    My RPi3 won't be powered off so keeping all in memory is fine and if reboot happens I don't care about states or its history - they would be just read from devices(es) again.

    I don't know if it is really that easy as soon as you have more complex scripts with "Non device states". If you choose that way then you need to make sure that all your scripts can work with "missing" "outdated" state values ... this will be likely hard when you do not only use device values, but also logical values.
    So when you increase it that much - know what you are doing and which effects it has!!

    paul53P Offline
    paul53P Offline
    paul53
    schrieb am zuletzt editiert von
    #6

    @apollon77 sagte:

    this will be likely hard when you do not only use device values, but also logical values.

    A reboot / killing of ioBroker immediately writes the states from RAM to the file. Only in case of a system crash (power failure) such a long time is problematic.

    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

    apollon77A 1 Antwort Letzte Antwort
    0
    • paul53P paul53

      @apollon77 sagte:

      this will be likely hard when you do not only use device values, but also logical values.

      A reboot / killing of ioBroker immediately writes the states from RAM to the file. Only in case of a system crash (power failure) such a long time is problematic.

      apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #7

      @paul53 ... or a process crash (yes there is come code that tries to write it also when crashing) ... but :-) (e.g. a SIGTERM because of OOM might also not write values).

      It is all about "knowing what one is doing"

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      1 Antwort Letzte Antwort
      0
      • Tomasz NowakT Offline
        Tomasz NowakT Offline
        Tomasz Nowak
        schrieb am zuletzt editiert von Tomasz Nowak
        #8

        @paul53 , @apollon77
        Thanks for your hints, guys. For now I'm just handling Ecovacs Deebot vacuuming robot (and Daikin aircon soon, probably) over MQTT with no logic within ioBroker. So I hope I don't risk any house disaster with that setting

        @paul53, I've created an issue, thanks.

        1 Antwort Letzte Antwort
        0
        • DutchmanD Offline
          DutchmanD Offline
          Dutchman
          Developer Most Active Administrators
          schrieb am zuletzt editiert von
          #9

          just as suggestion, to avoid load read/write loads on storage and move the to Memory isn't Redis providing more efficient state handling here ?

          1 Antwort Letzte Antwort
          0
          • Tomasz NowakT Offline
            Tomasz NowakT Offline
            Tomasz Nowak
            schrieb am zuletzt editiert von
            #10

            I thought about it but AFAIK Redis also needs to write to disk / sd card. I have relatively small number of states so I believe creating yet another docker instance for Redis would be kind of overkill in my case.

            MicM 1 Antwort Letzte Antwort
            0
            • Tomasz NowakT Tomasz Nowak

              I thought about it but AFAIK Redis also needs to write to disk / sd card. I have relatively small number of states so I believe creating yet another docker instance for Redis would be kind of overkill in my case.

              MicM Offline
              MicM Offline
              Mic
              Developer
              schrieb am zuletzt editiert von Mic
              #11

              @Tomasz-Nowak
              I am using Redis successfully for several months. I have installed it on the same system (Debian) on which ioBroker is installed - but no Raspberry experience (I am using a Zotac barebone with Proxmox), though.
              See: https://github.com/ioBroker/ioBroker.js-controller#state-and-objects-databases-and-files
              Also, see: https://redis.io/topics/persistence
              You may want to look into it again, but not sure how the performance is gonna be on a Raspberry.

              Tomasz NowakT 1 Antwort Letzte Antwort
              0
              • MicM Mic

                @Tomasz-Nowak
                I am using Redis successfully for several months. I have installed it on the same system (Debian) on which ioBroker is installed - but no Raspberry experience (I am using a Zotac barebone with Proxmox), though.
                See: https://github.com/ioBroker/ioBroker.js-controller#state-and-objects-databases-and-files
                Also, see: https://redis.io/topics/persistence
                You may want to look into it again, but not sure how the performance is gonna be on a Raspberry.

                Tomasz NowakT Offline
                Tomasz NowakT Offline
                Tomasz Nowak
                schrieb am zuletzt editiert von
                #12

                @Mic
                I've read that before. They say good for many objects such has 10000 for performance reasons. I have like 50 objects :)
                And I don't want make it more complex (you don't install another services in docker instance, you need another docker)

                1 Antwort Letzte Antwort
                0
                • DutchmanD Offline
                  DutchmanD Offline
                  Dutchman
                  Developer Most Active Administrators
                  schrieb am zuletzt editiert von Dutchman
                  #13

                  guys wait ...., don't ix performance and io topics please :)

                  we are discussing write access to storage, Redis works in memory so less write on disk/card was my hypothese :)

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • DutchmanD Dutchman

                    guys wait ...., don't ix performance and io topics please :)

                    we are discussing write access to storage, Redis works in memory so less write on disk/card was my hypothese :)

                    paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von
                    #14

                    @Dutchman sagte:

                    Redis works in memory so less write on disk/card

                    Per default Redis writes every 5 minutes to disk/card.

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    DutchmanD 1 Antwort Letzte Antwort
                    0
                    • paul53P paul53

                      @Dutchman sagte:

                      Redis works in memory so less write on disk/card

                      Per default Redis writes every 5 minutes to disk/card.

                      DutchmanD Offline
                      DutchmanD Offline
                      Dutchman
                      Developer Most Active Administrators
                      schrieb am zuletzt editiert von
                      #15

                      @paul53 sagte in How to lower disk writes (for extending life of an sd card):

                      @Dutchman sagte:

                      Redis works in memory so less write on disk/card

                      Per default Redis writes every 5 minutes to disk/card.

                      Better than every 30 seconds 🤷‍♂️

                      MicM 1 Antwort Letzte Antwort
                      0
                      • DutchmanD Dutchman

                        @paul53 sagte in How to lower disk writes (for extending life of an sd card):

                        @Dutchman sagte:

                        Redis works in memory so less write on disk/card

                        Per default Redis writes every 5 minutes to disk/card.

                        Better than every 30 seconds 🤷‍♂️

                        MicM Offline
                        MicM Offline
                        Mic
                        Developer
                        schrieb am zuletzt editiert von
                        #16

                        @Dutchman sagte in How to lower disk writes (for extending life of an sd card):

                        Better than every 30 seconds 🤷‍♂️

                        Exactly, and the default value can certainly be increased to whatever is needed. I would give Redis a try.
                        Also,
                        @Tomasz-Nowak sagte in How to lower disk writes (for extending life of an sd card):

                        They say good for many objects such has 10000 for performance reasons

                        I would assume this statement in the documentation was just made for the ease of use of ioBroker in general: Without like Redis, typically ioBroker's performance is good if you have way less than 10000+ objects. You are having a different use case (limited disc r/w per period). Not sure how the performance (like CPU and memory usage) of Redis is on a Raspberry, but I guess pretty low.

                        1 Antwort Letzte Antwort
                        0
                        Antworten
                        • In einem neuen Thema antworten
                        Anmelden zum Antworten
                        • Älteste zuerst
                        • Neuste zuerst
                        • Meiste Stimmen


                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        648

                        Online

                        32.6k

                        Benutzer

                        82.0k

                        Themen

                        1.3m

                        Beiträge
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                        ioBroker Community 2014-2025
                        logo
                        • Anmelden

                        • Du hast noch kein Konto? Registrieren

                        • Anmelden oder registrieren, um zu suchen
                        • Erster Beitrag
                          Letzter Beitrag
                        0
                        • Home
                        • Aktuell
                        • Tags
                        • Ungelesen 0
                        • Kategorien
                        • Unreplied
                        • Beliebt
                        • GitHub
                        • Docu
                        • Hilfe