Mustek PoweMust 1000 USB unter Debian Sarge

Da ich die doch leider etwas häufigen Stromausfälle hier satt war, habe ich mir vor einer Woche eine USV geholt - Mustek PoweMust 1000 USB. Eine Unterbrechungsfreie Strom Versorgung. Welch tolles Wort. Naja, nach einigem Rumgewarte wegen UPS (United Parcel Service, obwohl UPS im englischen auch Uninterruptible power supply, also USV, bedeutet) hatte ich das Ding dann hier und probierte sie erstmal an meiner Sid Workstation aus.

Die USV besitzt sowohl einen USB, als auch einen Seriellen Anschluss. Beim näherem Betrachten bemerkt man, dass der USB auch nur ein Serial-toUSB Converter ist, und dann auch noch von der Sorte, dessen Treiber ich nicht im Kernel hatte (den Treiber gibts aber, hab den halt nur ned reinkompiliert gehabt). Also an RS323 angeschlossen und weitergeschaut. Mustek liefert eine CD mit, wo sich auch Tools für Linux befinden. Die Installation schlägt (leider) fehl, da das Install-Script versucht Java vn der CD zu starten, anstatt das Java von meinem System zu nehmen. [Interessante Anmerkung an der Stelle: vor dem versuchten Java-Start, kam kein Hinweis auf die Sun-Lizenz - dürfen die das?]
Naja, auf jeden fall hab ich mir dann die networkupstools (2.0.4) installiert (apt-get install nut) und die wollen dann eingerichtet werden.

/etc/nut/ups.conf:
[mustek]
driver = megatec
port = /dev/ttyS0
desc = "PowerMust"

Das sagt aus, dass es eine USV namens "mustek" gibt, sie den megatec Treiber braucht und an ttyS0 hängt. Dabei ist zu beachten, dass man chown root:nut /dev/ttyS0 ausgeführt hat, denn sonst hat der Treiber nicht genug Rechte gleich.

/ect/nut/upsd.conf:
ACL all 0.0.0.0/0
ACL localhost 127.0.0.1/32

ACCEPT localhost
REJECT all

Erlaube localhost, verbiete alles Andere.

/etc/nut/upsd.users:
[nut]
password = nut
allowfrom = localhost
upsmon master

User mit dem Namen "nut" und dem Passwort "nut" darf von localhost (dabei ist localhost der Name des ACLs in upsd.conf) upsmon master sein.

/etc/nut/upsmon.conf
RUN_AS_USER nut
MONITOR mustek@localhost 1 nut nut master
MINSUPPLIES 1
SHUTDOWNCMD "/sbin/shutdown -h +0"
POLLFREQ 5
POLLFREQALERT 5
HOSTSYNC 15
DEADTIME 15
POWERDOWNFLAG /etc/killpower
RBWARNTIME 43200
NOCOMMWARNTIME 300
FINALDELAY 5

Da hab ich grad keine Lust, die einzelonen Optionen zu beschreiben - RTFM =)

Nach einem /etc/init.d/nut start lief dann auch alles, ich sah in /bar/log/daemon.log die Meldungen des upsmon, wenn ich Strom abgezogen hab, und die USV auf Akku lief, etc. Per upsc mustek@localhost konnte ich die USV dann auch händisch abfragen.

Die USV funktioniert also. Jetzt der große Schritt: die soll eigentlich an meinen Router/Fileserver und die dort stehenden Netgear WLAN Gedönse und das Motorolla Cable Modem.

Hab also die USV rübergeschleppt und angeschlossen. Konfiguration wie oben übernommen und promt ging es nicht. Problem war, dass unter Sarge nut 2.0.1 und nicht 2.0.4 wie unter Sid ist, und da es keinen megatec Treiber gibt, aber den powermust, also driver = powermust in die ups.conf und schon konnte das Dingen starten. Damit ich nicht händisch nach jedem Reboot (der ab jetzt nicht so oft vorkommen sollte) die Rechte von /duv/ttyS0 ändern muss, hab ich udev noch eine kleine tolle Regel geschenkt.

/etc/udev/rules.d/local.rules:
KERNEL="ttyS0", GROUP="nut"

Das wars. Jetzt wird ttyS0 beim Boot der Gruppe nut zugewiesen, wo nut dann alles lesen kann. Ahja, aus sicherheitsgrüden sollte man noch ein chmod 640 /etc/nut/* und ein chown root:nut /etc/nut/* machen. Nun kann der User root die Dateien ändern, aber der User nut nur lesen - für den Fall der Fälle falls es in nut je ein remote Exploit oder ähnliches geben sollte.

Comments

Leander wrote on 2007-05-08 00:02:

danke für dein HowTo,

Btw. klaro dürfen die Java unter die Sun Lizenz stellen ;-) Sun Microsystems hats schließelich erfunden und umgesetzt ;-)

Grüße,

LeoLinux

Zhenech wrote on 2007-05-08 01:17:

Ne so war das nicht gemeint mit der Sun-Lizenz. Java ist (derzeit noch, das ist sich ja am ändern) unter eine proprietären Lizenz, man darf es Weitergeben, aber nicht ändern und man muss AFAIK den User die Lizenz vorm Nutzen lesen lassen… Das tut zB Debian in ihren Java Paketen, aber Mustek nicht, aber mich solls im Endeffekt nicht stören.

Send your comments to evgeni+blogcomments@golov.de and I will publish them here (if you want).