- Update to version 2.8.0 For more see NEWS and UPGRADING in /usr/share/doc/packages/nut. * NUT now supports more i2c and modbus devices, as well as libusb-1.0 support as an alternative to earlier libusb-0.1 (so new dependency-based categories of packages for drivers may be due). * NUT Python modules and scripts (e.g. NUT-Monitor variants) should work with python-2.7 and with python-3.x, so covering historic distro releases as well as new ones (and so your distro can deliver one or both, probably in several packages with different dependencies in the latter case). * NUT provides revised reference systemd and SMF service unit definitions, including support of drivers wrapped into individual service instances with varying dependencies based on different media required (networked stack, USB stack, etc.), and many daemons include -F option for running "in foreground" to avoid extra forking after one already done by a service framework - you may want to use those in your packaged deliverables. * NUT newly provides the "nut-driver-enumerator" script and service, which allows it to follow edition of ups.conf and dynamically define+(re)start and stop+undefine service instances for drivers - there are several ways it can be integrated for different use-cases. * Yhere are several new configuration keywords and CLI options - so while new NUT builds should work with old configs and scripts, the opposite is not necessarily true (old binaries may reject configurations taking advantage of new features). * There are several new protocol keywords - but old and new NUT daemons (data server and clients) should be able to communicate both ways. * It is assumed that API/ABI changes may require third-party NUT clients (library consumers of libnutclient, libupsclient, libnutscan... -- their version info was bumped accordingly) to get rebuilt, in order to work with the new NUT release in a stable fashion. * The dummy-ups driver used in automated testing now processes *.dev filename patterns once and does not loop, like it still does for *.seq and other files (by default). * USB code is now more strict about logical minimum/maximum ranges for data reported from devices, and some devices were already found to make mistakes - so there is also a mechanism for turning a blind eye to known issues and fix-up such report descriptors to produce intended sane values. * New documentation page docs/config-prereqs.txt highlights packaged dependencies installable on a large range of platforms to build as much of NUT as possible (incidentally, ones NUT CI farm uses to test every iteration). - Remove upstreamed and obsolete patches: * nut-doc-cables.patch * nut-systemd-dirs.patch * nut-upssched.patch * nutscanner-ftbfs.patch * openssl-1_1.patch * reproducible.patch * use-pkg-config-gdlib.diff - Source is no longer GPG signed, so keyring is not needed anymore * nut.keyring - Unused additional source file removed (was added as a source, but not packaged) * nut.sleep - Don't install Solaris init files univited (PR# * nut-Solaris-init-files.patch OBS-URL: https://build.opensuse.org/request/show/1062385 OBS-URL: https://build.opensuse.org/package/show/hardware/nut?expand=0&rev=101
COnfiguration and use of NUT in SuSE NUT in openSUSE comes in several packages: - nut - The core package. It features UPS monitoring and network UPS management. and two additional packages: - nut-drivers-net - two additional drivers for network communication of UPS daemons. You will need for advanced configuration (e. g. if you want to manage shutdown of more computers sharing the same UPS). - nut-cgi provides support for monitoring UPS web pages using apache web browser. Predefined address is http://localhost/nut/index.html nut Configuration NUT is pre-configured to use a local or remote UPS as far as possible. But it still requires a minimal manual configuration before the first use. This document contains: - How to configure local or remote UPS (mandatory reading). - How to configure to suspend to disk (optional reading). - What to do in environment with possible service timeouts (optional reading). The default setup uses one local UPS. You have to define UPS type in file /etc/ups/ups.conf. It requires only few adoptions before you can start the service: * Configuration of a locally connected UPS: In /etc/ups/ups.conf: - Go to the [myups] section at the end of the file. - Set driver key to the driver name supporting your UPS. (see /usr/lib/ups/driver/ for possible drivers. Each driver has a man page. Many USB UPSes are usbhid-ups.) - Set port key to the device your UPS is connected to, e.g. /dev/ttyS0 for first serial port (COM1) or /dev/usb/hiddev0 for USB HID UPS. - Adjust desc key as you want. Start the service: - "/etc/init.d/upsd start" * Configuration of a UPS connected to a remote machine: In /etc/ups/ups.conf: - Comment out or remove the [myups] section at the end of the file. In /etc/ups/upsmon.conf: - Find the uncommented MONITOR line followed by "myups@localhost" and change it to: MONITOR myups@remote_machine 1 upsslave remote_password slave Where: remote_machine is a hostname of the remote machine. remote_password is the password used for upsslave on the remote machine (you can find it in the remote file /etc/ups/upsd.users). In /etc/ups/hosts.conf: - Find the uncommented MONITOR line followed by "myups@localhost". - Change the hostname from "localhost" to the hostname of the remote machine. - Change the description as you want. In the remote /etc/ups/upsd.conf: - Add a rule for the remote clients relevant to your network or your needs. Standard local networks are: 10.0.0.0/8, 172.16.0.0/12 and 192.168.0.0/16 ACL my_network 192.168.0.0/16 ACCEPT my_network In the remote /etc/ups/upsd.users: - Find the line allowfrom for upsslave user. - Add your local machine name to the allowfrom list. In the remote SuSE firewall: - Enable nut (Network UPS Tools) service (port 3493), e. g. by "YaST2 firewall". Start the service: - "/etc/init.d/upsd start" on both local and remote machines. - If you have edited configuration of a running server, run "/etc/init.d/upsd reload" * Test the configuration using upsc or upslog: - "upsc myups@localhost" Should display information about the UPS status. - "upslog -s myups@localhost -l -" Should display UPS status log every 30 seconds. (Press Ctrl-C keys to stop upslog). Notes: - Predefined user upsmaster There are two predefined users - upsmaster and upsslave. The passwords for them are generated during the installation (see the "password" lines in /etc/ups/upsd.users). User upsmaster has privileges to shut down master machine (default for local UPS), upsslave has privileges to shut down slave machines. If you change it, or add another user, don't forget to adopt the MONITOR lines in upsmon.conf on all machines using this user and password combination to connect to the upsd. Suspend to disk If you want to configure nut to do suspend to disk instead of shutdown you should: - Verify, that suspend to disk works correctly with your desktop: sudo systemctl hibernate (You can lose your unsaved data, if your computer does not support suspend.) - Change SHUTDOWNCMD in /etc/ups/upsmon.conf to: SHUTDOWNCMD "/usr/bin/systemctl hibernate" - Verify, that your UPS provides reasonable grace period to complete suspend in all situations. Environment with possible service timeouts In some environments, there is no guarantee, that the machine will correctly shut down, either because other machines providing critical services are already down or because some services (e. g. squid) are stopping too long and battery power is not sufficient. In this case, you can prefer incorrect but fast shutdown. To fix this problem, you need to do: - Copy upsd-early-powerdown script to your /etc/init.d/ directory. - Edit following lines: Replace "FIXME scripts which should not stop before powerdown" by an appropriate init script list. Replace "FIXME scripts which should stop before powerdown" by an appropriate init script list. - Start YaST Runlevel Editor and enable this meta-service in runlevels, where you want to apply early shutdown.
Description
Languages
Shell
85.1%
Standard ML
14.9%