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

    NUT package (2.8.0 and below)

    Scheduled Pinned Locked Moved UPS Tools
    1.2k Posts 128 Posters 5.5m Views 67 Watching
    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.
    • N Offline
      n3by
      last edited by

      dennypage just to let you know that your script is working great until now, and I made your changes in nut.inc so it will survive a reboot or UPS parameter changes till package upgrade/reinstall.

      In case anybody else will need it; just make the appropriate changes for you in the line with "blazer_usb-ActiveJet.pid";
      you can find your "driver_usb-upsname.pid" in /var/db/nut/ when NUT is running…

      credit go to dennypage !

      part with changes I made in:
      /usr/local/pkg/nut/nut.inc

      function nut_write_rcfile($driver) {
      	nut_check_var_db();
      	$start .= "echo starting NUT";
      	$start .= "\n	if [ -f /var/run/upsdrvctl_loop.pid ]";
      	$start .= "\n	then";
      	$start .= "\n		kill -9 `cat /var/db/nut/upsdrvctl_loop.pid`";
      	$start .= "\n		rm /var/run/upsdrvctl_loop.pid";
      	$start .= "\n	fi";
      	$start .= "\n	/usr/bin/killall -q -9 upsmon";
      	$start .= "\n	/usr/bin/killall -q -9 upsd";
      	$start .= "\n	/usr/bin/killall -q -9 upsdrvctl";
      	if (isset($driver)) {
      		$start .= "\n	/usr/bin/killall -q -9 $driver";
      	}
      
      	/* Service status keys off upsmon, so start it first. */
      	$start .= "\n	/usr/local/sbin/upsmon";
      	if (isset($driver)) {
      		$start .= "\n	/usr/local/sbin/upsdrvctl start &";
      		$start .= "\n	(";
      		$start .= "\n		while true";
      		$start .= "\n		do";
      		$start .= "\n			sleep 15";
      		$start .= "\n			kill -0 `cat /var/db/nut/blazer_usb-ActiveJet.pid` > /dev/null 2>&1 && continue";
      		$start .= "\n			/usr/local/sbin/upsdrvctl start";
      		$start .= "\n		done";
      		$start .= "\n	) &";
      		$start .= "\n	echo $! > /var/db/nut/upsdrvctl_loop.pid";
      		/* Since we are starting the driver in backgroud, give it a moment to start. */
      		$start .= "\n	sleep 1";
      		$start .= "\n	/usr/local/sbin/upsd -u root";
      	}
      	$start .= "\n	return 0";
      
      	$stop .= "echo stopping NUT";
      	$stop .= "\n	if [ -f /var/db/nut/upsdrvctl_loop.pid ]";
      	$stop .= "\n	then";
      	$stop .= "\n		kill -9 `cat /var/db/nut/upsdrvctl_loop.pid`";
      	$stop .= "\n		rm /var/db/nut/upsdrvctl_loop.pid";
      	$stop .= "\n	fi";
      	$stop .= "\n	/usr/bin/killall -q upsmon";
      	if (isset($driver)) {
      		$stop .= "\n	/usr/bin/killall -q upsd";
      		$stop .= "\n	/usr/bin/killall -q upsdrvctl";
      		$stop .= "\n	/usr/bin/killall -q $driver";
      	}
      	$stop .= "\n	return 0";
      
      	write_rcfile(array(
      		"file" => "nut.sh",
      		"start" => $start,
      		"stop" => $stop
      		)
      	);
      

      Thank you very much for help to all that got involved to solve this/my problem !
      and
      Merry Christmas !

      1 Reply Last reply Reply Quote 0
      • dennypageD Offline
        dennypage
        last edited by

        @n3by:

        In case anybody else will need it; just make the appropriate changes for you in the line with "blazer_usb-ActiveJet.pid";
        you can find your "driver_usb-upsname.pid" in /var/db/nut/ when NUT is running…

        I forgot about the ups name in the pid file. It had to be something stupid.

        On the system I was testing on the ups is named "ups" and the driver name is "usbhid-ups". This results in a pid file named "usbhid-ups-ups.pid". I think I'll change the name of the ups to prevent this sort of mistake in the future. :)

        1 Reply Last reply Reply Quote 0
        • E Offline
          endy66
          last edited by

          Yesterday i saw in my pfsense, that there is an update for the nut package (2.7.4_3). Is it save to hit the update button, or will the custom Settings be lost after the update?

          Best Regards

          1 Reply Last reply Reply Quote 0
          • dennypageD Offline
            dennypage
            last edited by

            What version of the nut package are you currently running? If you are already running 2.7.4, then there should no issue with the update. If you are running a version prior to 2.7.4, then the settings will be converted from the old package to the new package, and may require attention. See the beginning of this thread for more information. If you are still unsure, post some information about your settings.

            The current version is 2.7.4_4

            1 Reply Last reply Reply Quote 0
            • E Offline
              endy66
              last edited by

              @dennypage:

              What version of the nut package are you currently running? If you are already running 2.7.4, then there should no issue with the update. If you are running a version prior to 2.7.4, then the settings will be converted from the old package to the new package, and may require attention. See the beginning of this thread for more information. If you are still unsure, post some information about your settings.

              The current version is 2.7.4_4

              Thank you for the answer. I'm using the Version 2.7.4_3. Do i Need to save some Settings? I have set custom Parameters on the following fileds:

              • Extra Arguments to Driver (optional
              • Additional configuration lines for upsd.conf
              • Additional configuration lines for upsd.users

              Best Regards

              1 Reply Last reply Reply Quote 0
              • dennypageD Offline
                dennypage
                last edited by

                @endy66:

                Thank you for the answer. I'm using the Version 2.7.4_3. Do i Need to save some Settings?

                In moving from 2.7.4_3 to 2.7.4_4 there is nothing special you need to do. The settings will all be maintained.

                1 Reply Last reply Reply Quote 0
                • E Offline
                  endy66
                  last edited by

                  @dennypage:

                  @endy66:

                  Thank you for the answer. I'm using the Version 2.7.4_3. Do i Need to save some Settings?

                  In moving from 2.7.4_3 to 2.7.4_4 there is nothing special you need to do. The settings will all be maintained.

                  Perfect, thank you!

                  1 Reply Last reply Reply Quote 0
                  • A Offline
                    athurdent
                    last edited by

                    Thanks for this nice package, works fine and look great!

                    Forgive me for being slightly OT, but is it normal for a UPS to stay at 100% Charging? It's my first UPS ever and running like this for 2 days now (EATON 3S 550). Shouldn't it stop charging when it's at 100%?

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

                      That's Eaton special.

                      1 Reply Last reply Reply Quote 0
                      • A Offline
                        athurdent
                        last edited by

                        @doktornotor:

                        That's Eaton special.

                        So this is normal with EATON and I don't have to get it exchanged?

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

                          Yes, it happens with any Eaton I tried. Whether or not it's charging, NFC. The package only reports what's reported by firmware.

                          1 Reply Last reply Reply Quote 0
                          • A Offline
                            athurdent
                            last edited by

                            Thanks, doc! :)

                            1 Reply Last reply Reply Quote 0
                            • P Offline
                              poluket
                              last edited by

                              Hello,

                              sorry for my English :)

                              I think that I have the same problem than ecfx-xunil but I am a newbie.

                              PFsense version : 2.3.3 amd 64

                              NUT package version 2.7.4_4

                              I have an UPS FSP EP 2000

                              I use the nutdrv_qx driver. (without custom option)

                              it work fine but after a time, I have this message "Failed to retrieve status". I click on top to restart the service on the gui and i have again the value.

                              I have seen your message but I don't understand what to do to resolve the problem.

                              I need to chage the code?

                              Thank you  for your help.

                              1 Reply Last reply Reply Quote 0
                              • dennypageD Offline
                                dennypage
                                last edited by

                                Have you checked the system log? In Status / System Logs / System / General, look for messages matching "ups" or "nut".

                                1 Reply Last reply Reply Quote 0
                                • P Offline
                                  poluket
                                  last edited by

                                  thank you for your help :)

                                  the logs when I have the problem (newest entries on top):

                                  Mar 7 13:48:30 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:48:25 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:48:25 	kernel 		ugen3.2: <inno tech="">at usbus3
                                  Mar 7 13:48:22 	kernel 		ugen3.2: <inno tech="">at usbus3 (disconnected)
                                  Mar 7 13:48:20 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:48:17 	upsd 	90750 	Can't connect to UPS [UPS-Local-USB] (nutdrv_qx-UPS-Local-USB): No such file or directory
                                  Mar 7 13:48:15 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:48:14 	kernel 		ugen3.2: <inno tech="">at usbus3
                                  Mar 7 13:48:11 	kernel 		ugen3.2: <inno tech="">at usbus3 (disconnected)
                                  Mar 7 13:48:10 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:48:05 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:48:02 	kernel 		ugen3.2: <inno tech="">at usbus3
                                  Mar 7 13:48:00 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:48:00 	kernel 		ugen3.2: <inno tech="">at usbus3 (disconnected)
                                  Mar 7 13:47:55 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:47:51 	kernel 		ugen3.2: <inno tech="">at usbus3
                                  Mar 7 13:47:50 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:47:48 	kernel 		ugen3.2: <inno tech="">at usbus3 (disconnected)
                                  Mar 7 13:47:45 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:47:40 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:47:40 	kernel 		ugen3.2: <inno tech="">at usbus3
                                  Mar 7 13:47:37 	kernel 		ugen3.2: <inno tech="">at usbus3 (disconnected)
                                  Mar 7 13:47:35 	upsmon 	80446 	Communications with UPS UPS-Local-USB lost
                                  Mar 7 13:47:35 	upsmon 	80446 	Poll UPS [UPS-Local-USB] failed - Driver not connected
                                  Mar 7 13:47:33 	nutdrv_qx 	96269 	Permissions problem: Input/output error</inno></inno></inno></inno></inno></inno></inno></inno></inno></inno> 
                                  

                                  and after a service reboot:

                                  Mar 7 14:00:49 	upsd 	41029 	User monuser@::1 logged into UPS [UPS-Local-USB]
                                  Mar 7 14:00:49 	upsd 	41029 	Connected to UPS [UPS-Local-USB]: nutdrv_qx-UPS-Local-USB
                                  Mar 7 14:00:48 	nutdrv_qx 	41173 	Startup successful
                                  Mar 7 14:00:47 	upsd 	41029 	Startup successful
                                  Mar 7 14:00:47 	upsd 	40900 	Can't connect to UPS [UPS-Local-USB] (nutdrv_qx-UPS-Local-USB): No such file or directory
                                  Mar 7 14:00:47 	upsd 	40900 	listening on 127.0.0.1 port 3493
                                  Mar 7 14:00:47 	upsd 	40900 	listening on ::1 port 3493
                                  Mar 7 14:00:46 	upsmon 	39909 	Startup successful
                                  Mar 7 14:00:46 	upsd 	90750 	Signal 15: exiting
                                  Mar 7 14:00:46 	upsd 	90750 	mainloop: Interrupted system call
                                  Mar 7 14:00:46 	upsd 	90750 	User monuser@::1 logged out from UPS [UPS-Local-USB]
                                  Mar 7 14:00:46 	upsmon 	80446 	Signal 15: exiting 
                                  

                                  I have found this:

                                  https://www.nas4free.org/forums/viewtopic.php?t=946
                                  In port #17, he change the pollinterval to 10/15. Maybe a solution?

                                  https://forums.freenas.org/index.php?threads/2-issues-behaviours-with-attached-and-identified-ups.24033/
                                  or use a script with cron …

                                  like he say: "I would be very happy to know that there's another/better solution."

                                  thank for read my message

                                  1 Reply Last reply Reply Quote 0
                                  • dennypageD Offline
                                    dennypage
                                    last edited by

                                    Earlier in this thread:

                                    https://forum.pfsense.org/index.php?topic=115349.msg679431#msg679431

                                    1 Reply Last reply Reply Quote 0
                                    • P Offline
                                      poluket
                                      last edited by

                                      ok, thanks

                                      I will put the nut and usp on my linux server

                                      thank you for your time

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

                                        I just wanted to repeat a tip that dennypage (thanks!) mentioned earlier which seems to have helped me with my Eaton 5S repeatedly losing and reestablishing connection every few minutes on NUT 2.7.4_4 (haven't tried this UPS on earlier versions).

                                        Changing the poll interval to 10 worked around my issue. I think the default value is something ridiculous like 2 which in my case catches the very brief flakiness in the USB connection.

                                        Using the GUI, add the advanced setting "pollinterval=10" to ups.conf

                                        1 Reply Last reply Reply Quote 0
                                        • C Offline
                                          cozkramer
                                          last edited by

                                          I'm not sure if this is the right spot, but if not please correct location.

                                          I've got a TrippLite Smart2200 connected with Nut running on Pf 2.4 using tripplite_usb, and ever since I've started using Nut the UPS runs a self-test once or twice a day..  Anyone have any thoughts or suggestions?  I have no problems with a self test once a month or even once a week, but daily just kills the ups..

                                          Thanks!

                                          1 Reply Last reply Reply Quote 0
                                          • dennypageD Offline
                                            dennypage
                                            last edited by

                                            NUT itself doesn't invoke self-tests on a schedule. This is done by the UPS itself.

                                            There are usually configuration parameters that can be viewed and modified in the UPS. The complete list of NUT variables can be found here. Note that a given UPS model will generally only offer a small subset of these variables. Use the upsrw command to discover the list of variables you can modify. For your particular issue, the variable you are looking to modify is ups.test.interval.

                                            Further information on running commands can be found here. Be careful.

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