Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    RRD Graphs on Embedded - CF Issue?

    Scheduled Pinned Locked Moved webGUI
    20 Posts 6 Posters 17.2k Views
    Loading More Posts
    • 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.
    • M Offline
      MindTwist
      last edited by

      Hi databeestje,

      The issue is not about installing pfSense on a CF card, but on what to do so the RRD graph information won't get lost when a cold reboot/power out happens! :)

      1 Reply Last reply Reply Quote 0
      • D Offline
        databeestje
        last edited by

        fabifri asked for a solution to get the full install on a CF. So it's perfectly valid.

        1 Reply Last reply Reply Quote 0
        • GruensFroeschliG Offline
          GruensFroeschli
          last edited by

          I think a friend run into a similar problem recently.
          I think he solved it by temporarily mounting the filesystem as read/write.

          I'll ask him the next time i see him if he could post his solution.

          We do what we must, because we can.

          Asking questions the smart way: http://www.catb.org/esr/faqs/smart-questions.html

          1 Reply Last reply Reply Quote 0
          • M Offline
            MindTwist
            last edited by

            databeestje, fabifri was trying to install the full version on a CF card because he was also having lost RRD information due to power losses.

            I really do not know how many read/write cycles a CF card can sustain before passing out, but I do not think installing the full version on a CF card is a good solution for that. The RRD data on a normal installation is probably written to disk at least once a minute, which would ammount to at least 525600 extra writes every year on the card. CF cards are cheap, yeah, so it probably is not such a big deal to just throw an extra CF card every once in a while before your current CF dies, but I am sure the embedded version must exist for a reason.

            By saving the RRD data with a cron job you can choose how often you want to do it, so if the power goes out you won't lose much data. Once a day? Every 12h? Hourly? It will probably be just easier than installing the full version on a CF card.

            Thx!

            1 Reply Last reply Reply Quote 0
            • GruensFroeschliG Offline
              GruensFroeschli
              last edited by

              mount -o rw /cf/ ; /usr/bin/tar -czf /cf/conf/rrd.tgz -C /var/db/rrd/*.rrd ; mount -o ro /cf

              We do what we must, because we can.

              Asking questions the smart way: http://www.catb.org/esr/faqs/smart-questions.html

              1 Reply Last reply Reply Quote 0
              • M Offline
                MindTwist
                last edited by

                Thanks, I will give that a try. Maybe the command I am running /usr/bin/tar -czf /cf/conf/rrd.tgz -C /var/db/rrd/*.rrd from the WebGUI is working ok but not working from a cron job for whatever permissions reason. I will try changing the cron job to mount -o rw /cf/ ; /usr/bin/tar -czf /cf/conf/rrd.tgz -C /var/db/rrd/*.rrd ; mount -o ro /cf and see how that works out! :D

                1 Reply Last reply Reply Quote 0
                • M Offline
                  MindTwist
                  last edited by

                  I think that didn't do the trick for me. Not only the cron job still is doing nothing, but now I can not even do it by hand like I used to, dang… I created the cron job with mount -o rw /cf/ ; /usr/bin/tar -czf /cf/conf/rrd.tgz -C /var/db/rrd/*.rrd ; mount -o ro /cf yesterday at 17:23, restarted pfSense, and now my rrd.tgz has timestamp 17:23, the cron job has done nothing.

                  And doing a /usr/bin/tar -czf /cf/conf/rrd.tgz -C /var/db/rrd/*.rrd now does nothing at all either, I guess the directory/file is readonly… Not even if I do a mount -o rw /cf/ by hand before. Oh well :(

                  		 <minute>0</minute>
                  			<hour>1,7,13,19</hour>
                  			<mday>*</mday>
                  			<month>*</month>
                  			<wday>*</wday>
                  			<who>root</who>
                  			<command></command>mount -o rw /cf/ ; /usr/bin/tar -czf /cf/conf/rrd.tgz -C /var/db/rrd/*.rrd ; mount -o ro /cf 
                  
                  
                  1 Reply Last reply Reply Quote 0
                  • M Offline
                    MindTwist
                    last edited by

                    Ok, that sucked. I would advise anyone to NOT try the command I tried above as a cron job, lol…

                    You end up with everything being readonly on /conf , so the RRD info does not get saved at all (not even on reboot), and I was not even able to restore one of the old config.xml I kept around, since it was giving me the following error:

                    Warning: copy(/conf/config.xml): failed to open stream: Read-only file system in /etc/inc/config.inc on line 1172 
                    

                    Now, what I end up doing was doing a mount -o rw /cf/ from the command prompt, and just deleting the /conf/config.xml. Luclily, pfSense is smarter than me, and it detected that the config file was gone, and restored one of the old ones. After rebooting, I was then able to restore a config.xml from the WebGUI.

                    So, a new gap on my RRD graphs due to lost data, and I still do not have a way of saving the RRD data at least once a day, except doing it once in a while from the command prompt… :(

                    1 Reply Last reply Reply Quote 0
                    • S Offline
                      spock521
                      last edited by

                      I was having similar issues some time ago and I never found any working solution on these forums but after some experimentation I figured out a way to make this work (atleast for me). So in case someone else is trying to do the same I thought I'd share my solution (hopefully it will help someone).

                      Add this cron-entry to the configuration file:

                      <minute>0</minute>
                        <hour>3,15</hour>
                        <mday></mday>
                        <month>
                      </month>
                        <wday></wday>
                        <who>root</who>
                        <command></command>echo "RRD Graphs: Backup started." | logger; /etc/rc.conf_mount_rw ; /usr/bin/tar -czf /cf/conf/rrd.tgz -C /var/db/rrd/
                      .rrd ; /etc/rc.conf_mount_ro ; echo "RRD Graphs: Backup complete." | logger

                      I don't know if this is a proper way to do it, but it's the only way I found to work (manually remounting the CF read-write complains about permissions etc.). And it havent caused me any problems or side-effects so far.

                      1 Reply Last reply Reply Quote 0
                      • L Offline
                        littlekp
                        last edited by

                        I'm just struggling with the lost RRD data on my 1.2 version.
                        Thanks for the info about the reason of lost data.
                        Next Time I will do the clean boot rather than just turn it off by the power button. :P

                        1 Reply Last reply Reply Quote 0
                        • M Offline
                          MindTwist
                          last edited by

                          I was out all movember and hadn't been able to try it, check out the results, and post back until now, but the cron job as above by spock521 works great for me too.
                          Thanks!

                          1 Reply Last reply Reply Quote 0
                          • First post
                            Last post
                          Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.