Zeile 1: |
Zeile 1: |
− | Siehe [[oldCt:Linux-Tipps]]
| + | |
| | | |
| == Linux und andere Betriebssysteme == | | == Linux und andere Betriebssysteme == |
Zeile 92: |
Zeile 92: |
| === Arch Linux === | | === Arch Linux === |
| [[Arch Linux]] ist ein sog. [[Rolling Release]] und enthält sehr aktuelle Software, allerdings mit dem Nachteil, dass sie auch nicht immer besonders tief getestet wurde. | | [[Arch Linux]] ist ein sog. [[Rolling Release]] und enthält sehr aktuelle Software, allerdings mit dem Nachteil, dass sie auch nicht immer besonders tief getestet wurde. |
| + | |
| + | |
| + | === ChromeOS === |
| + | |
| + | Das Google-Betriebssystem ChromeOS basiert ebenfalls auf Linux. Es kann inzwischen auch [[Android]]-Apps ausführen. |
| + | |
| + | 2018 hat Google die Initiative ergriffen und versucht, [[ChromeOS auf dem Tablet]] zu offerieren. Bisher (Anfang 2020) scheint das noch nicht den Massenmarkt zu erreichen. |
| | | |
| === Schnellstart-Linux === | | === Schnellstart-Linux === |
Zeile 143: |
Zeile 150: |
| ==== RPM ==== | | ==== RPM ==== |
| * Das [http://xinux.de/docs/linux/rpm/ RPM-Buch] bietet eine Anleitung zum "Redhat Package Manager" inklusive dem Bau von Paketen. | | * Das [http://xinux.de/docs/linux/rpm/ RPM-Buch] bietet eine Anleitung zum "Redhat Package Manager" inklusive dem Bau von Paketen. |
| + | |
| + | === Orchestrierungswerkzeuge === |
| + | |
| + | Es gibt eine Menge Tools, um die Konfiguration von Rechnern aus der Ferne (halb-)automatisch zu erledigen, z.B.: |
| + | |
| + | * [[Ansible]] |
| + | * [[Chef]] |
| + | * [[Puppet]] |
| | | |
| === Sound === | | === Sound === |
Zeile 200: |
Zeile 215: |
| ===== Weiteres Beispiel für einen Menüeintrag ===== | | ===== Weiteres Beispiel für einen Menüeintrag ===== |
| | | |
− | | + | <pre> |
| menuentry 'UbuntuLinux Generic Current auf Platte mit Bezeichnung Ubun10LTS' --class ubuntu --class gnu-linux --class gnu --class os { | | menuentry 'UbuntuLinux Generic Current auf Platte mit Bezeichnung Ubun10LTS' --class ubuntu --class gnu-linux --class gnu --class os { |
| recordfail | | recordfail |
| insmod ext2 | | insmod ext2 |
− | search --no-floppy --label Ubun10LTS --set root | + | search --no-floppy --label --set root Ubun10LTS |
| linux /vmlinuz root=LABEL=Ubun10LTS ro quiet splash | | linux /vmlinuz root=LABEL=Ubun10LTS ro quiet splash |
| initrd /initrd.img | | initrd /initrd.img |
− | } | + | } |
− | | + | </pre> |
| | | |
| ===== /boot/grub.cfg aktualisieren ===== | | ===== /boot/grub.cfg aktualisieren ===== |
Zeile 215: |
Zeile 230: |
| an und schreibt sie in <code>/boot/grub/grub.cfg</code> mittels | | an und schreibt sie in <code>/boot/grub/grub.cfg</code> mittels |
| sudo update-grub | | sudo update-grub |
| + | |
| + | |
| + | ===== Vorschau auf GRUB-Menü ===== |
| + | |
| + | Das Menü, das GRUB beim Booten anbieten wird, kann mit dem Emulator angezeigt werden: |
| + | sudo aptitude install grub-emu |
| + | grub-emu |
| + | |
| + | Um es wieder zu beenden, muss man im Fenster, von dem aus man grub-emu gestartet hat (also nicht das Vorschaufenster) ein <code>c</code> und dann ein <code>exit</code> eingeben.<ref>Vgl. https://unix.stackexchange.com/questions/405515/how-to-preview-my-grub-menu-without-rebooting</ref> |
| | | |
| ===== ISO-File booten ===== | | ===== ISO-File booten ===== |
Zeile 224: |
Zeile 248: |
| Um nur für den nächsten Bootvorgang ein anderes Betriebssystem zu booten, kann man | | Um nur für den nächsten Bootvorgang ein anderes Betriebssystem zu booten, kann man |
| sudo grub-reboot x | | sudo grub-reboot x |
− | aufrufen, wobei x die Nummer oder die genaue Bezeichnung des "menuentry"-Eintrags in der <code>grub.cfg</code> ist. | + | aufrufen, wobei x die Nummer <small>(erster Eintrag hat die 0 nicht die 1)</small> oder die genaue Bezeichnung des "menuentry"-Eintrags in der <code>grub.cfg</code> ist. |
| | | |
| Wichtig ist dabei, dass in <code>/etc/default/grub</code> steht, dass | | Wichtig ist dabei, dass in <code>/etc/default/grub</code> steht, dass |
Zeile 255: |
Zeile 279: |
| * [http://www.rodsbooks.com/efi-bootloaders/index.html Beschreibung verschiedener EFI-Bootloader] für Linux | | * [http://www.rodsbooks.com/efi-bootloaders/index.html Beschreibung verschiedener EFI-Bootloader] für Linux |
| * [https://wiki.archlinux.org/index.php/UEFI UEFI-Grundlagen] für ArchLinux | | * [https://wiki.archlinux.org/index.php/UEFI UEFI-Grundlagen] für ArchLinux |
| + | * [https://help.ubuntu.com/community/UEFI UEFI-Hilfe für Ubuntu] |
| | | |
| ===== GRUB2 ===== | | ===== GRUB2 ===== |
Zeile 291: |
Zeile 316: |
| chainloader /EFI/microsoft/BOOT/bootmgfw.efi | | chainloader /EFI/microsoft/BOOT/bootmgfw.efi |
| } | | } |
| + | |
| + | ====== Booteintrag für nächsten Reboot ====== |
| + | |
| + | Für den nächsten Boot kann man den Booteintrag folgendermaßen auswählen |
| + | sudo grub-reboot 2 |
| + | |
| + | Statt der 2 (die für den 3. Menüeintrag) steht kann man natürlich auch eine andere Nummer angeben oder aber den Menüeintrag-Titel, wie er der Datei /boot/grub.cfg zu entnehmen ist. |
| | | |
| ===== ELILO ===== | | ===== ELILO ===== |
Zeile 349: |
Zeile 381: |
| Siehe zu Service-Templates (z.B. mehrere Konsolen, auf die mittels (Strg-)Alt-F1, (Strg-)Alt-F2 ... zugegriffen werden kann und auf denen jeweils getty läuft): | | Siehe zu Service-Templates (z.B. mehrere Konsolen, auf die mittels (Strg-)Alt-F1, (Strg-)Alt-F2 ... zugegriffen werden kann und auf denen jeweils getty läuft): |
| * http://0pointer.de/blog/projects/instances.html | | * http://0pointer.de/blog/projects/instances.html |
| + | |
| + | === Ruhezustand === |
| + | |
| + | Probiere |
| + | sudo pm-hibernate |
| + | oder |
| + | sudo systemctl hibernate |
| + | |
| + | Siehe auch zu den Voraussetzungen wie /etc/initramfs-tools/conf.d/resume: |
| + | * https://forums.bunsenlabs.org/viewtopic.php?id=4305 |
| | | |
| ==== Automatischen Ruhezustand verhindern ==== | | ==== Automatischen Ruhezustand verhindern ==== |
Zeile 354: |
Zeile 396: |
| Systemd ist standardmäßig so eingestellt, dass es bei geschlossenem Laptop-Deckel in den Ruhezustand geht. Dies lässt sich in der <code>/etc/systemd/login.conf</code> vermeiden:<ref>http://unix.stackexchange.com/questions/52643/how-to-disable-auto-suspend-when-i-close-laptop-lid</ref> | | Systemd ist standardmäßig so eingestellt, dass es bei geschlossenem Laptop-Deckel in den Ruhezustand geht. Dies lässt sich in der <code>/etc/systemd/login.conf</code> vermeiden:<ref>http://unix.stackexchange.com/questions/52643/how-to-disable-auto-suspend-when-i-close-laptop-lid</ref> |
| HandleLidSwitch=ignore | | HandleLidSwitch=ignore |
− |
| |
| | | |
| === Weiteres === | | === Weiteres === |
Zeile 363: |
Zeile 404: |
| == Herunterfahren == | | == Herunterfahren == |
| | | |
| + | === im Init-System === |
| Mit einer GUI-Umgebung wie Gnome oder KDE lässt sich der Rechner einfach durch Drücken des Soft-Power-Off-Buttons herunterfahren (meist noch mit einer Rückfrage auf dem Bildschirm). Will man dem normalen User in der Shell etwas ähnliches erlauben, sollte man in <code>/etc/inittab</code> folgende Zeile einfügen/ändern: | | Mit einer GUI-Umgebung wie Gnome oder KDE lässt sich der Rechner einfach durch Drücken des Soft-Power-Off-Buttons herunterfahren (meist noch mit einer Rückfrage auf dem Bildschirm). Will man dem normalen User in der Shell etwas ähnliches erlauben, sollte man in <code>/etc/inittab</code> folgende Zeile einfügen/ändern: |
| | | |
| ca:12345:ctrlaltdel:/sbin/shutdown -t1 -a -h now | | ca:12345:ctrlaltdel:/sbin/shutdown -t1 -a -h now |
| + | |
| + | === mittels Magic-SysRq === |
| + | Siehe |
| + | * [https://www.heise.de/ix/heft/Letzte-Rettung-4054884.html iX-Artikel zur Magic-SysRq-Rettung] |
| | | |
| == Tastatur == | | == Tastatur == |
Zeile 452: |
Zeile 498: |
| synclient TouchPadOff=1 | | synclient TouchPadOff=1 |
| kann das Klicken durch Tippen auf das TouchPad abgeschaltet werden. Siehe dazu auch [http://forum.ubuntuusers.de/topic/ubuntu-12-04-mouseklicks-touchpad-deaktivieren/#post-4381662 diesen Thread]. | | kann das Klicken durch Tippen auf das TouchPad abgeschaltet werden. Siehe dazu auch [http://forum.ubuntuusers.de/topic/ubuntu-12-04-mouseklicks-touchpad-deaktivieren/#post-4381662 diesen Thread]. |
| + | |
| + | === Maus nicht erkannt beim Starten === |
| + | |
| + | Bei Linux Mint 19.1 und dem Motherboard [[ASRock B360 Pro4]] wird evtl die USB-Maus (in meinem Fall Microsoft Optical Mouse) beim Systemstart nicht erkannt. Hier könnte der Kernelparameter <code>i8042.nopnp</code> helfen.<ref>Vgl. http://lightrush.ndoytchev.com/random-1/i8042quirkoptions</ref> |
| | | |
| == RS232 Schnittstelle == | | == RS232 Schnittstelle == |
Zeile 468: |
Zeile 518: |
| === LIRC === | | === LIRC === |
| | | |
− | Die Signale der [http://www.sbprojects.com/knowledge/ir/ Infrarot]-Fernbedienungen konnten früher nur über [http://www.lirc.org LIRC] empfangen werden, heutzutage kann der Kernel selbst viele Signale direkt als Tastatur-Ereignisse verarbeiten. LIRC hat aber weiterhin Sinn, z.B. wenn man bei der Konfiguration flexibler sein will oder wenn ein IR-Empfänger oder eine IR-Fernbedienung noch nicht vom Kernel unterstützt wird.<ref>Vgl. http://www.lirc.org/html/configuration-guide.html</ref> | + | Die Signale der [http://www.sbprojects.com/knowledge/ir/ Infrarot]-Fernbedienungen konnten früher nur über [http://www.lirc.org LIRC] empfangen werden, heutzutage kann der Kernel selbst viele Signale direkt als Tastatur-Ereignisse verarbeiten.<ref>Siehe [http://atterer.org/mythtv-xmbc-remote-control-without-lirc] .</ref> LIRC hat aber weiterhin Sinn, z.B. wenn man bei der Konfiguration flexibler sein will oder wenn ein IR-Empfänger oder eine IR-Fernbedienung noch nicht vom Kernel unterstützt wird.<ref>Vgl. http://www.lirc.org/html/configuration-guide.html</ref> |
| | | |
| Mit LIRC kann man auch die vom Kernel unterstützten IR-Geräte nutzen; dabei geht man den Umweg über das Linux-Input-System. | | Mit LIRC kann man auch die vom Kernel unterstützten IR-Geräte nutzen; dabei geht man den Umweg über das Linux-Input-System. |
| | | |
− | Siehe
| + | Mit |
− | * [http://www.lirc.org/html/configuration-guide.html Ausführliche Anleitung und Erläuterung der LIRC-Funktionsweise]
| + | ir-keytable |
| + | können die installierten IR-Receiver angezeigt werden. Eingabegeräte ganz allgemein lassen sich auch mit |
| + | cat /proc/bus/input/devices |
| + | anzeigen. |
| | | |
− | == Prozessverwaltung ==
| + | Mit |
| + | sudo ir-keytable --device /dev/input/event10 -t |
| + | kann man testen, ob überhaupt Signale ankommen (event10 durch den auf den IR-Empfänger passenden event setzen, siehe oben ir-keytable). Das sudo kann weggelassen werden, indem man den Benutzer der Gruppe <code>input</code> zuweist:<ref>Vgl. http://www.lirc.org/html/devinput.html</ref> |
| + | sudo adduser USER input |
| | | |
− | === nohup ===
| + | Zunächst gibt man beim Testen alle unterstützten Protokolle an: |
− | * Mit dem Befehl <code>nohup</code> kann man Prozesse starten, die nicht beendet werden, wenn die Shell verlassen wird. Die Standardausgabe <code>stdout</code> wird nach <code>nohup.out</code> im aktuellen Verzeichnis umgeleitet (kann z.B. mit <code>cat nohup.out</code> angesehen werden.
| + | ir-keytable -p jvc,rc-5,rc-6,other -t |
| | | |
− | === cron ===
| + | Dann setzt man das korrekte Protokoll, indem hinter -p die übrigen Protokolle weggelassen werden. |
| + | Außerdem kopiert man eine Kernel-Keymap nach /etc/rc_keymap, bearbeitet sie gegebenenfalls <small>([http://atterer.org/mythtv-xmbc-remote-control-without-lirc siehe dazu die Key codes( MythTV) ] und die [http://kodi.wiki/view/Keyboard_controls Standardbelegung der Tastatur unter Kodi])</small> und liest sie dann ein |
| + | sudo cp /lib/udev/rc_keymaps/tt_1500 /etc/rc_keymaps/meine_keymap |
| + | sudo ir-keytable -p jvc -c -w /etc/rc_keymaps/meine_keymap |
| | | |
− | ==== crontab ====
| + | Hier mal meine Beispiel-Tabelle <code>/etc/rc_keymaps/meine_tt</code> für die Nutzung einer alten Technotrend-Fernbedienung für [[Kodi]]: |
− | * Mit dem Befehl <code>crontab</code> lassen sich Prozesse zu einem bestimmten Zeitpunkt ausführen. Anleitungen finden sich z.B. bei [http://de.wikipedia.org/wiki/Cron Wikipedia], [http://www.newbie-net.de/anleitung_cron.html Newbie-Net]. Mit
| + | <pre> |
− | crontab -l
| + | # table tt_1500, type: RC5 |
− | wird die <code>crontab</code> des aktuellen Benutzers ausgegeben. Mit
| + | 0x1501 KEY_POWER |
| + | 0x1502 KEY_SHUFFLE |
| + | 0x1503 KEY_1 |
| + | 0x1504 KEY_2 |
| + | 0x1505 KEY_3 |
| + | 0x1506 KEY_4 |
| + | 0x1507 KEY_5 |
| + | 0x1508 KEY_6 |
| + | 0x1509 KEY_7 |
| + | 0x150a KEY_8 |
| + | 0x150b KEY_9 |
| + | 0x150c KEY_0 |
| + | 0x150d KEY_UP |
| + | 0x150e KEY_LEFT |
| + | 0x150f KEY_ENTER |
| + | 0x1510 KEY_RIGHT |
| + | 0x1511 KEY_DOWN |
| + | 0x1512 KEY_C |
| + | 0x1513 KEY_BACKSPACE |
| + | 0x1514 KEY_RED |
| + | 0x1515 KEY_GREEN |
| + | 0x1516 KEY_YELLOW |
| + | 0x1517 KEY_BLUE |
| + | 0x1518 KEY_MUTE |
| + | 0x1519 KEY_TEXT |
| + | 0x151a KEY_MODE |
| + | 0x1521 KEY_OPTION |
| + | 0x1522 KEY_E |
| + | 0x1523 KEY_CHANNELUP |
| + | 0x1524 KEY_CHANNELDOWN |
| + | 0x1525 KEY_VOLUMEUP |
| + | 0x1526 KEY_VOLUMEDOWN |
| + | 0x1527 KEY_SETUP |
| + | 0x153a KEY_RECORD |
| + | 0x153b KEY_SPACE |
| + | 0x153c KEY_X |
| + | 0x153d KEY_REWIND |
| + | 0x153e KEY_PAUSE |
| + | 0x153f KEY_FORWARD |
| + | </pre> |
| | | |
− | crontab -e
| + | Mit |
− | kann die <code>crontab</code> geändert werden. Eine Crontab-Datei enthält Zeilen mit normalerweise sechs durch Leerzeichen getrennte Spalten: | + | ir-keytable --read |
− | * Minuten
| + | kann man sich die eingelesenen Keycodes anzeigen lassen. |
− | * Stunden
| |
− | * Tage
| |
− | * Monate
| |
− | * Wochentage
| |
− | * Auszuführender Befehl / Datei
| |
− | Beispiel:
| |
− | 2 3 * * * cp src backup
| |
− | @reboot echo "hallo"
| |
− | */10 * * * * echo "schon wieder"
| |
| | | |
− | In der ersten Zeile wird der cron-Dämon angewiesen, immer um 3:02 Uhr morgens an jedem Tag die Datei <code>src</code> nach <code>backup</code> zu kopieren. In der zweiten Zeile wird bei jedem Boot-Vorgang ein "hallo" per Mail(?) an den jeweiligen Benutzer geschickt. Die letzte Zeile wird alle 10 Minuten ausgeführt. Zu den weiteren "@-Zeiten" siehe http://library.linode.com/linux-tools/utilities/cron.
| + | Hier ist mit dem reinen Kernel-Treiber Schluss. |
| | | |
− | ==== /etc/cron.weekly u.a. ====
| + | Man kann es sich aber auch komplizierter machen und LIRC installieren: |
| + | sudo aptitude install lirc |
| + | |
| + | Die /etc/lirc/hardware.conf bekommt folgenden Inhalt:<ref>Vgl. [http://forum.kodi.tv/showthread.php?tid=101151 ir-keytable or: How I Learned to Stop Worrying about the LIRC Kernel] </ref> |
| + | LOAD_MODULES=true |
| + | DRIVER="devinput" |
| + | DEVICE="/dev/input/event6" |
| + | event6 muss dabei an den mit |
| + | ir-keytable |
| + | Gerätenamen angepasst werden. '''Achtung:''' Nach einem Neustart kann der IR-Receiver einem anderen eventXXX zugeordnet sein. |
| | | |
− | Ausführbare Dateien in den Verzeichnissen <code>/etc/cron.daily</code>, <code>/etc/cron.weekly</code> und <code>/etc/cron.monthly</code> werden von <code>anacron</code> und/oder <code>cron</code> periodisch ausgeführt.
| |
| | | |
− | Gegenüber der <code>crontab</code>-Methode ergibt sich daraus ein Vorteil bei Rechnern, die nicht 24 Stunden im Betrieb sind. Bei [[Debian]] muss dafür jedoch anacron nachinstalliert werden (als root):
| + | Für die /etc/lirc/lircd.conf greift man auf die devinput-Datei zurück: |
− | aptitude install anacron | + | sudo cp -av /usr/share/lirc/remotes/devinput/lircd.conf.devinput /etc/lirc/lircd.conf |
| | | |
− | Die Dateinamenskonvention in den Verzeichnissen <code>/etc/cron.daily</code> etc. ist recht restriktiv. Siehe dazu die [[man]]-pages von <code>run-parts</code>. Um zu sehen, ob das eigene Skript die Namenskonvention einhält, kann man
| + | Danach müssen noch [https://github.com/xbmc/xbmc/blob/Jarvis/system/Lircmap.xml Lircmap.xml] in <code>~/.kodi/userdata/</code> und die [https://github.com/xbmc/xbmc/blob/master/system/keymaps/remote.xml remote.xml] (jeweils auf korrektes Release/github-Branch achten)<ref>Siehe http://kodi.wiki/view/Keymap.xml#Remote_Buttons</ref> in <code>~/.kodi/userdata/keymaps/</code> hineinkopiert werden, möchte man [[Kodi]] nutzen. Dabei ist in die Lircmap.xml in das device-Attribut des remote-Elements korrekt zu setzen. Beispiel: |
− | run-parts --test /etc/cron.daily | + | <remote device="/dev/input/event6"> |
− | ausführen. Es wird eine Liste derjenigen Skripte ausgegeben, die die Namenskonvention einhält.
| |
| | | |
− | == Benutzerverwaltung ==
| |
| | | |
− | === neuer Benutzer === | + | Da [[udev]] insbesondere bei mehreren IR-Receivern immer wieder eine andere Gerätenummer (eventXX) zuweist, sollte man mit einer eigenen udev-Regel einen symbolischen Link erstellen. Dazu legt man eine Datei <code>/etc/udev/rules.d/10-infrared.rules</code> an und gibt ihr folgenden Inhalt: |
| + | ACTION=="add", SUBSYSTEM=="input", ATTRS{name}=="ITE8713 CIR transceiver", SYMLINK+="input/infrared" |
| | | |
− | * Einen neuen Benutzer legt man am Besten mit <code>adduser NEUERNUTZER </code> an. Im Gegensatz zu <code>useradd </code> wird dabei gleich ein /home-Verzeichnis angelegt. Ein Passwort wird dabei auch gleich abgefragt.
| + | Hilfe zum Finden der korrekten Attribute für den eigenen IR-Empfänger erhält man mit |
| + | udevadm info -a -n /dev/input/event7 |
| + | wobei natürlich event7 mit dem korrekten eventXX aus dem Aufruf von <code>ir-keytable</code> ersetzt werden muss. |
| | | |
− | === Benutzer-Nummer ===
| |
| | | |
− | * Die [http://www.unixtutorial.org/2008/01/how-to-find-uid-in-unix/ UID findet man mit dem Befehl <code>id</code>].
| + | Mit |
| + | sudo udevadm test /devices/virtual/rc/rc0/input7/event7 |
| + | kann man die udev-Regel testen. |
| | | |
| + | sudo udevadm trigger |
| + | löst den udev-Zuweisungsvorgang aus (genauso wie beim Neustart). |
| + | |
| + | Mit |
| + | ls -als /dev/input/infrared |
| + | kann man sehen, ob man erfolgreich war. |
| + | |
| | | |
− | === Konsolen-Benutzer ohne Passwort ===
| |
− | * Für einen Benutzer ohne Passwort (beim Login auf Shell-Ebene muss man nur den Login-Namen, aber kein Passwort eingeben)<ref>Vergleiche http://onlyubuntu.blogspot.com/2008/06/howto-enable-empty-password-login-in.html.</ref> legt man ihn in folgenden zwei Schritten an:
| |
− | adduser userWithoutPassword
| |
− | passwd -d userWithoutPassword
| |
| | | |
− | === AutoLogin auf Konsole === | + | Siehe |
| + | * [http://www.lirc.org/html/configuration-guide.html Ausführliche Anleitung und Erläuterung der LIRC-Funktionsweise] |
| + | * [https://marklodato.github.io/2013/10/24/how-to-use-lirc.html LIRC-Anleitung von Mark Lodato] inkl. Abklemmen der Kernel-Funktionalität über xorg.conf.d-Dateien |
| + | * [https://www.mythtv.org/wiki/User_Manual:IR_control_via_evdev MythTV-Anleitung zu ir-keytable] |
| + | * [http://forum.kodi.tv/showthread.php?tid=101151 IR-Remote nur über Kernel, nicht über LIRC] |
| + | * [http://forum.kodi.tv/showthread.php?tid=104541 Ausführliche Erklärung von LIRC in mehreren Forumsbeiträgen] |
| | | |
− | ==== AutoLogin unter SysV ==== | + | ==== InputLirc ==== |
− | Ein automatisches Login erreicht man mit dem Paket [http://wiki.ubuntuusers.de/autologin rungetty]:
| |
− | aptitude install rungetty
| |
| | | |
| + | InputLirc nutzt das Kernel-Input-Subsystem (ir-keytable) und gibt die Events an LIRC weiter, das dann für die Aktionen in den Anwendungen sorgt. |
| | | |
− | Danach muss man in <code>/etc/init/tty1.conf</code> die Zeile <code>exec /sbin/getty 38400 tty1</code> durch folgende Zeile ersetzen:
| + | Installation: |
− | exec /sbin/rungetty --autologin namedesbenutzers tty1 | + | sudo aptitude install lirc lirc-x inputlirc |
| | | |
− | Bei anderen Linux-Systemen (z.B. [[Debian]] 6.0 Squeeze) muss man in der <code>/etc/inittab</code> die Zeile <code>1:2345:respawn:/sbin/getty 38400 tty1</code> durch folgende Zeile ersetzen:
| |
− | 1:2345:respawn:/sbin/rungetty --autologin namedesbenutzers tty1
| |
| | | |
− | Nach dem Parameter <code>tty1</code> kann man noch ein Kommando angeben, das automatisch ausgeführt wird. Ein textbasierter Music-Client lässte sich daher durch Aufruf von <code>ncmpcpp</code> erstellen; bei Beenden des Programms wird es dann automatisch wieder gestartet. Dazu muss allerdings zuvor der [[MPD]]-Server installiert sein.
| + | In <code>/etc/default/inputlirc</code> muss die Variable <code>EVENTS</code> auf den von der oben angegebenen [[udev]]-Regel erstellten symbolischen Link gesetzt werden:<ref>Vgl. http://kodi.wiki/view/HOW-TO:Set_up_an_MCE_remote_control_in_Linux </ref> |
| + | EVENTS="/dev/input/infrared" |
| + | Das ist dann auch der korrekte Name für das <code><remote></code>-Tag in der <code>.kodi/userdata/Lircmapxml</code>. |
| + | Kernel-Input kann mit ir-keytable -t getestet werden (siehe oben). |
| + | |
| + | Die LIRC-Tastencodes können mit |
| + | irw |
| + | angezeigt werden (einzelne Tasten auf der Fernbedienung betätigen). |
| | | |
− | ==== AutoLogin unter Systemd ==== | + | [[Kodi]]-Funktionen: Die <code>~/.kodi/userdata/Lircmap.xml</code> erhält folgenden Inhalt: |
| + | <pre> |
| + | <?xml version="1.0" encoding="UTF-8"?> |
| + | <!-- This file contains the mapping of LIRC keys to XBMC keys used in Keymap.xml --> |
| + | <!-- --> |
| + | <!-- How to add remotes --> |
| + | <!-- <remote device="name_Lirc_calls_the_remote"> --> |
| + | <!-- --> |
| + | <!-- For the commands the layout following layout is used --> |
| + | <!-- <XBMC_COMMAND>LircButtonName</XBMC_COMMAND> --> |
| + | <!-- --> |
| + | <!-- For a list of XBMC_COMMAND's check out the <remote> sections of keymap.xml --> |
| | | |
− | Siehe dazu http://noctus.net/2011/mingetty-und-systemd
| + | <lircmap> |
| + | <remote device="/dev/input/event6"> |
| + | <!-- new kernel-based lirc button names --> |
| + | <eject>KEY_EJECTCD</eject> |
| + | <left>KEY_LEFT</left> |
| + | <right>KEY_RIGHT</right> |
| + | <up>KEY_UP</up> |
| + | <down>KEY_DOWN</down> |
| + | <select>KEY_OK</select> |
| + | <start>KEY_HOME</start> |
| + | <back>KEY_BACK</back> |
| + | <record>KEY_RECORD</record> |
| + | <play>KEY_PLAY</play> |
| + | <pause>KEY_PAUSE</pause> |
| + | <stop>KEY_STOP</stop> |
| + | <forward>KEY_FORWARD</forward> |
| + | <reverse>KEY_REWIND</reverse> |
| + | <volumeplus>KEY_VOLUMEUP</volumeplus> |
| + | <volumeminus>KEY_VOLUMEDOWN</volumeminus> |
| + | <pageplus>KEY_CHANNELUP</pageplus> |
| + | <pageminus>KEY_CHANNELDOWN</pageminus> |
| + | <skipplus>KEY_NEXT</skipplus> |
| + | <skipminus>KEY_AGAIN</skipminus> |
| + | <mute>KEY_MUTE</mute> |
| + | <power>KEY_POWER</power> |
| + | <myvideo>KEY_VIDEO</myvideo> |
| + | <mymusic>KEY_AUDIO</mymusic> |
| + | <livetv>LiveTV</livetv> |
| + | <guide>KEY_EPG</guide> |
| + | <one>KEY_1</one> |
| + | <two>KEY_2</two> |
| + | <three>KEY_3</three> |
| + | <four>KEY_4</four> |
| + | <five>KEY_5</five> |
| + | <six>KEY_6</six> |
| + | <seven>KEY_7</seven> |
| + | <eight>KEY_8</eight> |
| + | <nine>KEY_9</nine> |
| + | <zero>KEY_0</zero> |
| + | <red>KEY_RED</red> |
| + | <green>KEY_GREEN</green> |
| + | <yellow>KEY_YELLOW</yellow> |
| + | <blue>KEY_BLUE</blue> |
| + | <menu>KEY_DVD</menu> |
| + | <clear>KEY_CLEAR</clear> |
| + | <enter>KEY_ENTER</enter> |
| | | |
− | === Weiterführendes ===
| + | <!-- extensions --> |
| + | <back>KEY_EXIT</back> |
| + | </remote> |
| + | </lircmap |
| + | </pre> |
| + | Siehe |
| + | * http://www.pro-linux.de/artikel/2/1682/einstieg-in-lirc-mit-inputlirc.html |
| | | |
− | * Die ct stellte [http://www.ct.de/1103122 Skripte für ein manipulationssicheres Linux] vor (c't 3/2011 S. 122ff.).
| + | ==== ir-keytable und Kodi ==== |
| | | |
− | * http://de.m.wikipedia.org/wiki/Unix-Kommandos#Benutzer-_und_Rechteverwaltung
| + | Für neuere Linux- und [[Kodi]]-Versionen braucht man im Regelfall LIRC nicht. <code>ir-keytable</code> reicht aus. |
| + | Beispiel für eine TT-Fernbedienung an einem Intel [[NUC]] mit eingebautem IR-Empfänger: |
| + | Man bastelt auf Basis der <code>/lib/udev/rc_keymaps/tt_1500</code> eine neue Datei namens <code>/etc/rc_keymaps/meine_tt</code> mit folgendem Inhalt: |
| + | <pre> |
| + | # table tt_1500, type: RC5 |
| + | 0x1501 KEY_POWER |
| + | 0x1502 KEY_SHUFFLE |
| + | 0x1503 KEY_1 |
| + | 0x1504 KEY_2 |
| + | 0x1505 KEY_3 |
| + | 0x1506 KEY_4 |
| + | 0x1507 KEY_5 |
| + | 0x1508 KEY_6 |
| + | 0x1509 KEY_7 |
| + | 0x150a KEY_8 |
| + | 0x150b KEY_9 |
| + | 0x150c KEY_0 |
| + | 0x150d KEY_UP |
| + | 0x150e KEY_LEFT |
| + | 0x150f KEY_ENTER |
| + | 0x1510 KEY_RIGHT |
| + | 0x1511 KEY_DOWN |
| + | 0x1512 KEY_C |
| + | 0x1513 KEY_BACKSPACE |
| + | 0x1514 KEY_RED |
| + | 0x1515 KEY_GREEN |
| + | 0x1516 KEY_YELLOW |
| + | 0x1517 KEY_BLUE |
| + | 0x1518 KEY_MUTE |
| + | 0x1519 KEY_TEXT |
| + | 0x151a KEY_MODE |
| + | 0x1521 KEY_OPTION |
| + | 0x1522 KEY_E |
| + | 0x1523 KEY_CHANNELUP |
| + | 0x1524 KEY_CHANNELDOWN |
| + | 0x1525 KEY_VOLUMEUP |
| + | 0x1526 KEY_VOLUMEDOWN |
| + | 0x1527 KEY_SETUP |
| + | 0x153a KEY_RECORD |
| + | 0x153b KEY_SPACE |
| + | 0x153c KEY_X |
| + | 0x153d KEY_REWIND |
| + | 0x153e KEY_PAUSE |
| + | 0x153f KEY_FORWARD |
| + | </pre> |
| | | |
− | == Virtualisierung ==
| |
| | | |
− | * [ftp://ftp.freiesmagazin.de/2009/freiesMagazin-2009-05.pdf freiesmagazin.de Mai 2009] zeigt, wie man einen virtuellen Rechner mittels KVM am Heimrechner einrichtet.
| + | Diese schreibt man auf den Intel-IR-Receiver (hier: <code>rc0</code>) mit |
− | * Open VirtualBox (von Oracle) wird z.B. bei Ubuntu mitgeliefert.
| + | sudo ir-keytable -c -w /etc/rc_keymaps/meine_tt -s rc0 |
| | | |
− | * [[Docker]] ist im Standardpaketumfang von [[Linux Mint]] enthalten.
| + | Um nicht noch durch den im DVB-Stick enthaltenen IR-Receiver (hier: <code>rc1</code>) verwirrt zu werden, kann man dessen Zuordnungstabelle löschen: |
| + | sudo ir-keytable -c -s rc1 |
| | | |
− | * LXC ist ebenfalls eine Container-Lösung
| + | Kodi muss zur Wirksamkeit wohl neu gestartet werden. |
| | | |
− | == Shells == | + | ==== IR Probleme ==== |
| | | |
− | === Dokumentation für bash (Kommandozeile/Konsole) ===
| + | Zu Testzwecken hilft das Anzeigen einzelner Tastendrücke: |
| + | irw |
| | | |
− | * [http://tldp.org/LDP/abs/html/index.html Advanced Bash Shell Scripting Guide] mit vielen Beispielen.
| |
− | * [http://mywiki.wooledge.org/BashPitfalls Häufige Fehler bei der Bash-Programmierung]
| |
− | * [http://linuxconfig.org/Bash_scripting_Tutorial Bash Tutorial]
| |
| | | |
− | === Ablaufsteuerung ===
| + | Mit Intel NUCs scheint es manchmal Probleme mit dem internen IR-Receiver zu geben. <ref>Siehe https://communities.intel.com/thread/52072?start=15&tstart=0</ref> |
− | ==== if-Verzweigung ====
| |
| | | |
− | Der Rückgabewert 0 einer Funktion oder eines Kommando wird als wahr gewertet.
| + | Wenn man zwei IR-Receiver (z.B. eingebauten und den einer TV-Karte) hat, kann es passieren, dass man das Protokoll für den zweiten nicht einstellen kann.<ref>Vgl. https://github.com/OpenELEC/OpenELEC.tv/issues/3137</ref>,<ref>Siehe http://ilostmynotes.blogspot.de/2012/12/fintek-ir-receiver-and-xbox-remote-to.html </ref>, <ref>https://bbs.archlinux.org/viewtopic.php?id=151479&p=2</ref> |
| | | |
− | Damit gibt
| + | Möglicherweise gibt es auf einem Debian Jessie ein LIRC zuviel und die Tasten werden ununterbrochen wiederholt. Dann hilft evtl.: |
− | if true; then echo eins; else echo zwei; fi; | + | sudo service lircd-uinput stop |
− | "eins" aus.
| + | Den <code>lircd-uinput</code> - Service kann man auch dauerhaft deaktivieren: |
| + | sudo systemctl disable lircd-uinput |
| | | |
− | Die Negation erreicht man mit dem Operator <code>!</code>:
| + | ===== IR-Fernbedienung erzeugt doppelte Tastendrücke ===== |
− | if ! true; then echo eins; else echo zwei; fi;
| |
− | liefert "zwei".
| |
| | | |
| + | Wenn man [[Kodi]] über eine Infrarot-Fernbedienung steuern will und sie wie oben dargestellt mit [[LIRC]] und Kodis [[Lircmap.xml]] eingerichtet hat, dann kann es vorkommen, dass die Fernbedienung Tastendrücke doppelt an Kodi meldet. Wenn dies der Fall ist, schaltet man das entsprechende Input-Device im X-Server ab. Dazu sucht man mit |
| + | export DISPLAY=:0.0 |
| + | xinput list |
| + | die Id (z.B. 9) des IR-Adapters (üblicherweise benannt nach dem TV-Stick, der den IR-Empfänger integriert hat). |
| + | Mit |
| + | xinput list-props 9 |
| + | (statt 9 ggf. andere ID angeben) kann man dann die Eigenschaften des IR-Empfängers ausgeben lassen. Hinter jeder Eigenschaft ist in Klammern eine Eigenschaftsnummer angegeben. Die Eigenschaft mit dem "Enabled" im Text, muss auf 0 gesetzt werden, z.B. so: |
| + | xinput set-prop 9 138 0 |
| + | Oft funktioniert auch direkt |
| + | xinput set-prop 9 "Device Enabled" 0 |
| | | |
− | ==== while-Schleife ====
| + | Dazu gibt es auch [https://bugs.launchpad.net/ubuntu/+source/linux/+bug/663651/comments/23 ein fertiges Skript]. |
− | * Die bash-Shell bietet auch eine einfach zu nutzende While-Schleife. Beispiel:
| |
− | while true; do df -h; sleep 50s; echo `date`; done;
| |
− | * Das kann man auch mit einer Pipe kombinieren (diese Schleife konvertiert Musikdateien, die nur nach der Tracknummer benannt sind, in TrackNr.mp3 um):
| |
− | find /mnt/Daten/MusikSorted/ | grep ".*/[0-9][0-9]$" | (while read i; do mv "$i" "$i.mp3"; done; )
| |
− | ==== Funktionen ====
| |
− | * Funktionen in einem Shell-Script sind einfach definiert:
| |
− | function meineFunktion() {
| |
− | echo Hallo welt und $1;
| |
− | }
| |
− | # Aufruf:
| |
− | meineFunktion Tina
| |
− | # Ausgabe: Hallo welt und Tina
| |
| | | |
− | === Variablen === | + | == Prozessverwaltung == |
− | * Array-Variablen können z.B. folgendermaßen Werte zugewiesen werden:
| |
− | meinArray=(eins zwei drei vier)
| |
| | | |
− | * Ein komisches Verhalten zieht <code>declare</code> innerhalb einer Funktion bei: Es begrenzt die Sichtbarkeit der Variablen auf den Funktionsbereich. Wenn globale Variablen zum Informationsaustausch zwischen Funktion und aufrufendem Skript genutzt werden sollen, sollte declare in der Funktion also besser nicht genutzt werden. | + | === nohup === |
| + | * Mit dem Befehl <code>nohup</code> kann man Prozesse starten, die nicht beendet werden, wenn die Shell verlassen wird. Die Standardausgabe <code>stdout</code> wird nach <code>nohup.out</code> im aktuellen Verzeichnis umgeleitet (kann z.B. mit <code>cat nohup.out</code> angesehen werden. |
| | | |
− | === Parameteroptionen verarbeiten === | + | === cron === |
| | | |
− | [http://www.mkssoftware.com/docs/man1/getopts.1.asp getopts], ein in der Bash enthaltenes Kommando, hilft Kommandozeilenoptionen zu verarbeiten. | + | ==== crontab ==== |
| + | * Mit dem Befehl <code>crontab</code> lassen sich Prozesse zu einem bestimmten Zeitpunkt ausführen. Anleitungen finden sich z.B. bei [http://de.wikipedia.org/wiki/Cron Wikipedia], [http://www.newbie-net.de/anleitung_cron.html Newbie-Net]. Mit |
| + | crontab -l |
| + | wird die <code>crontab</code> des aktuellen Benutzers ausgegeben. Mit |
| | | |
− | === Exit-Status === | + | crontab -e |
| + | kann die <code>crontab</code> geändert werden. Eine Crontab-Datei enthält Zeilen mit normalerweise sechs durch Leerzeichen getrennte Spalten: |
| + | * Minuten |
| + | * Stunden |
| + | * Tage |
| + | * Monate |
| + | * Wochentage |
| + | * Auszuführender Befehl / Datei |
| + | Beispiel: |
| + | 2 3 * * * cp src backup |
| + | @reboot echo "hallo" |
| + | */10 * * * * echo "schon wieder" |
| + | |
| + | In der ersten Zeile wird der cron-Dämon angewiesen, immer um 3:02 Uhr morgens an jedem Tag die Datei <code>src</code> nach <code>backup</code> zu kopieren. In der zweiten Zeile wird bei jedem Boot-Vorgang ein "hallo" per Mail(?) an den jeweiligen Benutzer geschickt. Die letzte Zeile wird alle 10 Minuten ausgeführt. Zu den weiteren "@-Zeiten" siehe http://library.linode.com/linux-tools/utilities/cron. |
| + | |
| + | ==== /etc/cron.weekly u.a. ==== |
| | | |
− | Mit
| + | Ausführbare Dateien in den Verzeichnissen <code>/etc/cron.daily</code>, <code>/etc/cron.weekly</code> und <code>/etc/cron.monthly</code> werden von <code>anacron</code> und/oder <code>cron</code> periodisch ausgeführt. |
− | echo $? | + | |
− | wird der Rückgabewert des unmittelbar davor ausgeführten Shell-Kommandos/Skripts ausgegeben.
| + | Gegenüber der <code>crontab</code>-Methode ergibt sich daraus ein Vorteil bei Rechnern, die nicht 24 Stunden im Betrieb sind. Bei [[Debian]] muss dafür jedoch anacron nachinstalliert werden (als root): |
| + | aptitude install anacron |
| + | |
| + | Die Dateinamenskonvention in den Verzeichnissen <code>/etc/cron.daily</code> etc. ist recht restriktiv. Siehe dazu die [[man]]-pages von <code>run-parts</code>. Um zu sehen, ob das eigene Skript die Namenskonvention einhält, kann man |
| + | run-parts --test /etc/cron.daily |
| + | ausführen. Es wird eine Liste derjenigen Skripte ausgegeben, die die Namenskonvention einhält. |
| | | |
− | Das kann z.B. für einen Abbruch genutzt werden:
| |
− | do_something;
| |
− | exit_status=$?;
| |
− | if (($exit_status)); then
| |
− | echo do_something failed.;
| |
− | exit $exit_status;
| |
− | fi;
| |
| | | |
− | Die Kurzform für die ersten drei Zeilen wäre:
| + | ==== Feststellen, ob Script von Cron gestartet wurde ==== |
− | if do_something; then
| |
| | | |
− | === Debugging ===
| + | Siehe https://stackoverflow.com/questions/33354864/how-to-check-if-linux-shell-script-is-executed-by-a-cronjob : |
| + | <pre> |
| | | |
− | Mit
| + | if [ -t 0 ]; then |
− | set -x
| + | echo "I'm on a TTY, this is interactive." |
− | wird Tracing eingeschaltet: Jeder Script-Befehl wird vor der Ausführung auf der Konsole ausgegeben.
| + | else |
| + | logger "My output may get emailed, or may not. Let's log things instead." |
| + | fi |
| + | </pre> |
| | | |
− | Mit
| + | == Benutzerverwaltung == |
− | set -e
| |
− | wird grundsätzlich das Script bei einem erfolglosen Befehl abgebrochen.
| |
| | | |
− | === Verarbeiten von Textstreams === | + | === neuer Benutzer === |
| | | |
− | Linux kennt zwei Standard-Ausgabe-Streams, stdout und stderr. Die für stderr bestimmten Ausgaben können mit dem Operator "2>" in eine Datei umgeleitet werden.
| + | * Einen neuen Benutzer legt man am Besten mit <code>adduser NEUERNUTZER </code> an. Im Gegensatz zu <code>useradd </code> wird dabei gleich ein /home-Verzeichnis angelegt. Ein Passwort wird dabei auch gleich abgefragt. |
| | | |
− | * [http://www.easylinux.de/2005/09/084-umleitungen/ Einführung in Pipes]
| + | === Benutzer-Nummer === |
− | * Sinnvolle Hilfen zum Verarbeiten von Textstreams/Auslesen von Dateien
| |
− | ** [[wc]] zählt Worte und Zeilen
| |
− | ** [[cut]] liefert bestimmte Teile einer Zeile
| |
− | ** [[grep]] sucht nach Textbestandteilen
| |
− | ** [[sed]] hilft beim Editieren einer Datei auf der Kommandozeile bzw. in Shell-Skripten, siehe z.B. der [http://www.freiesmagazin.de/ftp/2010/freiesMagazin-2010-03.pdf Artikel zu sed im "freien Magazin"].
| |
− | ** [[printf]] ermöglicht wie in der Programmiersprache C das formatierte Ausgeben von Zahlen und Zeichen
| |
− | printf '%s mit führenden Nullen: %05d' Zahl 76
| |
| | | |
− | ==== sed ====
| + | * Die [http://www.unixtutorial.org/2008/01/how-to-find-uid-in-unix/ UID findet man mit dem Befehl <code>id</code>]. |
− | Beispiel für sed für die Umwandlung in eine Playlist:
| |
− | sed -e 's/..\/Musik\/Music/dhMusic/' -e 's/\/[0-9][0-9] /\//' <playlistOriginal.m3u > playListNeu.m3u
| |
− | In der neuen Playlist
| |
− | * ist der Pfadanfang geändert von ../Musik/Musik nach dhMusic und
| |
− | * sind die Trackziffern inklusive des Leerzeichens weggelassen.
| |
| | | |
− | Etwas komplizierter
| |
− | sed -e 's:\\:/:g' -e 's:../Musik/Music/\(.\):sortedMusic/\1/\1:' -e 's:/\([0-9][0-9]\) :/\1_-_:' -e 's/ /_/g' < playlistOriginal.m3u > playListNeu.m3u
| |
| | | |
− | * Zunächst wird der Backslash durch den Slash ersetzt.
| + | === Konsolen-Benutzer ohne Passwort === |
− | * Dann der Pfadanfang geändert | + | * Für einen Benutzer ohne Passwort (beim Login auf Shell-Ebene muss man nur den Login-Namen, aber kein Passwort eingeben)<ref>Vergleiche http://onlyubuntu.blogspot.com/2008/06/howto-enable-empty-password-login-in.html.</ref> legt man ihn in folgenden zwei Schritten an: |
− | * Außerdem wird die Pfadstruktur um eine Ebene erweitert: Den Anfangsbuchstaben des Interpreten
| + | adduser userWithoutPassword |
− | * Zwischen die Trackziffern und den Namen des Lieds werden noch ein Trennstrich mit zwei Leerzeichen eingefügt.
| + | passwd -d userWithoutPassword |
− | * Schließlich werden alle Leerzeichen durch einen Unterstrich ersetzt.
| |
| | | |
− | Mit dem Modifizierer <code>-i</code> (oder <code>--in-place</code>) kann eine Datei geändert werden, die zugleich als Eingabestream fungiert.
| + | === AutoLogin auf Konsole === |
| | | |
− | === Datum === | + | ==== AutoLogin unter SysV ==== |
| + | Ein automatisches Login erreicht man mit dem Paket [http://wiki.ubuntuusers.de/autologin rungetty]: |
| + | aptitude install rungetty |
| | | |
− | date
| |
− | zeigt das aktuelle Datum an.
| |
− | date +%s
| |
− | zeigt die seit 1970 vergangenen Sekunden an.
| |
− | date -d "2100-1-1 -1 day"
| |
− | zeigt den letzten Tag des 21. Jahrhunderts (31.12.2099) an.
| |
| | | |
− | Siehe
| + | Danach muss man in <code>/etc/init/tty1.conf</code> die Zeile <code>exec /sbin/getty 38400 tty1</code> durch folgende Zeile ersetzen: |
− | * [http://tldp.org/LDP/abs/html/timedate.html weitere Beispiele im Advanced Bash Scripting Guide].
| + | exec /sbin/rungetty --autologin namedesbenutzers tty1 |
| | | |
− | === Interaktion mit Desktop ===
| + | Bei anderen Linux-Systemen (z.B. [[Debian]] 6.0 Squeeze) muss man in der <code>/etc/inittab</code> die Zeile <code>1:2345:respawn:/sbin/getty 38400 tty1</code> durch folgende Zeile ersetzen: |
− | ==== Zwischenablage ====
| + | 1:2345:respawn:/sbin/rungetty --autologin namedesbenutzers tty1 |
| | | |
− | * Mit [http://www.linux-community.de/Archiv/Tipp-der-Woche/Xclip-Zwischenablage-fuer-die-Konsole xclip] lässt sich der Inhalt der Shell-Pipe in die Zwischenablage kopieren. Der Inhalt steht dann beispielsweise in einer KDE- oder Gnome-Anwendung zur Verfügung.
| + | Nach dem Parameter <code>tty1</code> kann man noch ein Kommando angeben, das automatisch ausgeführt wird. Ein textbasierter Music-Client lässte sich daher durch Aufruf von <code>ncmpcpp</code> erstellen; bei Beenden des Programms wird es dann automatisch wieder gestartet. Dazu muss allerdings zuvor der [[MPD]]-Server installiert sein. |
| | | |
− | ==== Nachricht an Desktop ==== | + | ==== AutoLogin unter Systemd ==== |
| | | |
− | Mit
| + | Siehe dazu http://noctus.net/2011/mingetty-und-systemd |
− | notify-send text
| |
− | kann eine Nachricht (text) an den Desktop gesendet werden, die dem Benutzer angezeigt wird.<ref>https://linuxnetz.wordpress.com/2010/04/21/notify-send/</ref>
| |
| | | |
− | Dafür ist allerdings das Paket <code>libnotify-bin</code> zu installieren:
| + | === Weiterführendes === |
− | sudo aptitude install libnotify-bin
| |
| | | |
− | ==== User-Dialog ====
| + | * Die ct stellte [http://www.ct.de/1103122 Skripte für ein manipulationssicheres Linux] vor (c't 3/2011 S. 122ff.). |
| | | |
− | Unter [[Gnome]] lässt sich mit <code>zenity</code> von der [[Bash]] mit dem Nutzer in Dialog treten (Ja/Nein, User-Eingabezeile, ...).
| + | * http://de.m.wikipedia.org/wiki/Unix-Kommandos#Benutzer-_und_Rechteverwaltung |
| | | |
− | ==== Arbeitsflächen wechseln ==== | + | == Virtualisierung == |
| | | |
− | Das Paket <code>wmctrl</code> erlaubt den Wechsel zwischen den Arbeitsflächen des Desktops:
| + | * [ftp://ftp.freiesmagazin.de/2009/freiesMagazin-2009-05.pdf freiesmagazin.de Mai 2009] zeigt, wie man einen virtuellen Rechner mittels KVM am Heimrechner einrichtet. |
− | wmctrl -s arbeitsflächennummer
| + | * Open VirtualBox (von Oracle) wird z.B. bei Ubuntu mitgeliefert. |
− | wobei arbeitsflächennummer die mit 0 beginnende Nummer des Desktops ist.<ref>http://www.linuxquestions.org/questions/linux-desktop-74/how-to-specify-a-gnome-workpace-an-application-will-launch-in-555764/</ref>
| |
| | | |
− | Das Paket <code>devilspie</code> erlaubt es, Programme nach bestimmten Kriterien auf andere Arbeitsflächen/Viewports zu verfrachten. Dazu muss beispielsweise für <code>xterm</code> folgende Datei <code>~/.devilspie/xterm.ds</code> (Die Endung <code>.ds</code> ist wichtig) erstellt werden:
| + | * [[Docker]] ist im Standardpaketumfang von [[Linux Mint]] enthalten. |
| | | |
− | (if
| + | * LXC ist ebenfalls eine Container-Lösung |
− | (is (application_name) "xterm")
| |
− | (begin
| |
− | (set_viewport 3)
| |
− | )
| |
− | )
| |
| | | |
− | Anschließend muss <code>devilspie</code> gestartet werden. Bei den folgenden Aufrufen von <code>xterm</code> wird das Fenster automatisch auf die Arbeitsfläche 3 landen.
| + | == Shells == |
| | | |
− | Eine Möglichkeit, mittels wmctrl und bash-Script Compiz-Viewports zu kontrollieren, findet sich [http://www.linuxquestions.org/questions/programming-9/bash-script-for-automatic-viewport-changing-and-other-wm-stuff-works-with-compiz-838827/ hier] und [http://forum.ubuntuusers.de/topic/wuerfel-per-bash-drehen/#post-1206881 hier], letzteres basierend auf [http://sfyang-en.blogspot.com/2008/02/rotate-cube-in-compiz-with-wmctrl.html diesem Blog].
| + | === Dokumentation für bash (Kommandozeile/Konsole) === |
| | | |
− | == Dateiverwaltung ==
| + | * [http://tldp.org/LDP/abs/html/index.html Advanced Bash Shell Scripting Guide] mit vielen Beispielen. |
| + | * [http://mywiki.wooledge.org/BashPitfalls Häufige Fehler bei der Bash-Programmierung] |
| + | * [http://linuxconfig.org/Bash_scripting_Tutorial Bash Tutorial] |
| | | |
− | === Dateisuche === | + | === Tab-Completion === |
− | Ein rekursives MS-DOS-<code>dir</code> lässt sich mit dem Befehl find erreichen:
| |
| | | |
− | find / -name "*xy*"
| + | Wenn man in der Bash die Tabulatortaste drückt, wird der gerade angefangene Befehl, der gerade angefangene Dateiname usw. vervollständigt bzw. bei zweimaligem Drücken weitere Vervollständigungen angeboten. |
− |
| |
− | Es findet alle Dateien, die ein xy im Dateinamen enthalten und gibt den vollständigen Pfad aus. Die Anführungszeichen sind wichtig, ansonsten würde die Shell bereits die Sternchen auswerten.
| |
| | | |
− | === Berechtigungen ===
| + | Eine deutliche Erweiterung dieser Funktionalität auch für Optionen für verschiedene Kommandozeilentools bietet das Paket <code>bash-completion</code>: |
− | * '''Berechtigungen''' für automatisch eingebundene '''FAT32'''-Laufwerke/Festplatten werden in der Datei ''/etc/fstab'' vorgegeben. Sie können nicht mit ''chmod'' oder ''chown'' geändert werden.
| + | sudo aptitude install bash-completion |
− | * Informationen u.a. zum SUID-Bit und zum Abschalten auf ganzen Partitionen finden sich auf dem [http://www.informatikserver.at/selflinux/html/grundlagen_sicherheit07.html Informatikserver.at]
| |
| | | |
− | === Speicherplatz === | + | ==== Autovervollständigung für Rechnernamen ==== |
− | * Den '''freien Platz auf der Festplatte''' erfährt man durch
| + | Bei der Vervollständigung für Rechnernahmen, z.B. für den [[ssh]]-Befehl, schaut die Vervollständigung regelmäßig in die Datei <code>/etc/hosts</code>. |
− | df -h
| + | Möchte man weitere Rechnernamen aufnehmen, muss man die Umgebungsvariable $HOSTFILE auf eine Datei mit Rechnernamen setzen:<ref>Vgl. http://www.linux-magazine.com/Online/Features/Bash-Tips-Autocompletion .</ref> |
− | * Den vom aktuellen Verzeichnis und seinen Unterverzeichnis '''belegten Platz''' erfährt man durch
| + | export HOSTFILE="/home/USER/myhostfile" |
− | du --human-readable --summarize
| + | Um dies bei jedem Start der Bash automatisch zu tun, fügt man diese Zeile am Ende der <code>.bashrc</code> im Homeverzeichnis des jeweiligen Benutzers ein. |
| | | |
− | === Mounten ===
| |
| | | |
− | ==== Erkennen einer CD-ROM ====
| + | In der entsprechenden Datei (im Beispiel /home/USER/myhostfile) werden die Rechner Zeile für Zeile eingetragen: |
| + | fritz.box |
| + | pia2016.de |
| | | |
− | Möglicherweise hilft bei Nichterkennung einer CD-ROM das [http://ignorantguru.github.io/udevil/ Einschalten des Kernel-Pollings (siehe unteren Teil der verlinkten Seite)].
| + | === Gefrorene Shell === |
| | | |
− | ==== UUID ====
| + | Mittels Strg-S kann man das Terminal anhalten (XOFF). Mittels Strg-Q geht es wieder weiter (XON). |
| | | |
− | Die UUIDs der Festplattenpartitionen lassen sich mit <code>sudo blkid</code> anzeigen.
| + | === Ablaufsteuerung === |
− | In der <code>/etc/fstab</code> ersetzt man das übliche <code>/dev/sdXX</code> durch <code>UUID=12345678</code>.
| + | ==== if-Verzweigung ==== |
| | | |
− | ==== LABEL ====
| + | Der Rückgabewert 0 einer Funktion oder eines Kommando wird als wahr gewertet. |
| | | |
− | Eine ext2/ext3/ext4-Partition lässt sich mit <code>sudo e2label</code> mit einem Label versehen.
| + | Damit gibt |
− | In der <code>/etc/fstab</code> ersetzt man das übliche <code>/dev/sdXX</code> durch <code>LABEL=MyPart</code>.
| + | if true; then echo eins; else echo zwei; fi; |
| + | "eins" aus. |
| | | |
− | ==== Dauerhaftes Mounten einer NTFS-Partition ====
| + | Die Negation erreicht man mit dem Operator <code>!</code>: |
| + | if ! true; then echo eins; else echo zwei; fi; |
| + | liefert "zwei". |
| | | |
− | Um eine NTFS-Partition (z.B. auf /dev/sda2) dauerhaft (also schon beim Booten) zu mounten, fügt man in die Datei <code>/etc/fstab</code> folgende Zeile hinzu:
| |
− | /dev/sda2 /mnt/winC ntfs defaults,umask=011,uid=BENUTZER,gid=BENUTZERGRUPPE 0 0
| |
− | wobei BENUTZER und BENUTZERGRUPPE durch die entsprechenden Benutzernamen bzw. Gruppennammen zu ersetzen sind.
| |
| | | |
− | Außerdem muss der Mount-Point erzeugt werden:
| + | ==== while-Schleife ==== |
− | mkdir /mnt/winC | + | * Die bash-Shell bietet auch eine einfach zu nutzende While-Schleife. Beispiel: |
| + | while true; do df -h; sleep 50s; echo `date`; done; |
| + | * Das kann man auch mit einer Pipe kombinieren (diese Schleife konvertiert Musikdateien, die nur nach der Tracknummer benannt sind, in TrackNr.mp3 um): |
| + | find /mnt/Daten/MusikSorted/ | grep ".*/[0-9][0-9]$" | (while read i; do mv "$i" "$i.mp3"; done; ) |
| + | ==== Funktionen ==== |
| + | * Funktionen in einem Shell-Script sind einfach definiert: |
| + | function meineFunktion() { |
| + | echo Hallo welt und $1; |
| + | } |
| + | # Aufruf: |
| + | meineFunktion Tina |
| + | # Ausgabe: Hallo welt und Tina |
| | | |
− | Damit werden können aber alle Benutzer alle Daten dieses Laufwerks lesen und schreiben. Will man dies nicht, muss man mit den Optionen <code>uid=</code>, <code>gid=</code> und <code>umask=</code> eine Lösung finden.
| + | === Variablen === |
| + | * Array-Variablen können z.B. folgendermaßen Werte zugewiesen werden: |
| + | meinArray=(eins zwei drei vier) |
| | | |
− | Unter [[Debian]] ist für den Schreibzugriff auf [[NTFS]] die Installation des Pakets <code>ntfs-3g</code> notwendig:
| + | * Ein komisches Verhalten zieht <code>declare</code> innerhalb einer Funktion bei: Es begrenzt die Sichtbarkeit der Variablen auf den Funktionsbereich. Wenn globale Variablen zum Informationsaustausch zwischen Funktion und aufrufendem Skript genutzt werden sollen, sollte declare in der Funktion also besser nicht genutzt werden. |
− | aptitude install ntfs-3g
| + | |
| + | === Parameteroptionen verarbeiten === |
| + | |
| + | [http://www.mkssoftware.com/docs/man1/getopts.1.asp getopts], ein in der Bash enthaltenes Kommando, hilft Kommandozeilenoptionen zu verarbeiten. |
| | | |
| + | Siehe auch |
| + | * https://www.redhat.com/en/blog/arguments-options-bash-scripts |
| | | |
− | ===== Korrupte NTFS-Partition ===== | + | === Exit-Status === |
| | | |
| Mit | | Mit |
− | sudo ntfsfix /dev/sdb1 | + | echo $? |
− | kann die NTFS-Partition auf /dev/sdb1 repariert werden.<ref>http://askubuntu.com/questions/74105/how-do-you-repair-an-input-output-error-in-an-ntfs-partition</ref>
| + | wird der Rückgabewert des unmittelbar davor ausgeführten Shell-Kommandos/Skripts ausgegeben. |
| | | |
− | ==== USB-Datenträger unter Systemd ==== | + | Das kann z.B. für einen Abbruch genutzt werden: |
| + | do_something; |
| + | exit_status=$?; |
| + | if (($exit_status)); then |
| + | echo do_something failed.; |
| + | exit $exit_status; |
| + | fi; |
| | | |
− | Wenn man eine USB-Disk nur manchmal beim Start eingesteckt hat, sie in dem Fall aber automatisch mounten will, helfen möglicherweise die <code>/etc/fstab</code>-Optionen <code>nofail,nobootwait</code>.<ref>Siehe http://www.reddit.com/r/archlinux/comments/1lafu2/fstab_how_to_automount_but_ignore_if_its_not/ , https://bbs.archlinux.org/viewtopic.php?id=147478</ref>
| + | Die Kurzform für die ersten drei Zeilen wäre: |
| + | if do_something; then |
| | | |
− | Unter Systemd kann man auch die Optionenkombination <code>noauto,x-systemd.automount</code> in <code>/etc/fstab</code> verwenden. Dann wird die entsprechende Platte erst dann gemountet, wenn auf den Mountpunkt zugegriffen wird.<ref>Vgl. https://bbs.archlinux.org/viewtopic.php?id=147478</ref>
| + | === Debugging === |
| | | |
− | Siehe
| + | Mit |
− | * http://www.wrigley.me.uk/wp/2012/12/03/automounting-usb-disk-on-boot-with-systemd-in-fedora/
| + | set -x |
− | * https://bbs.archlinux.org/viewtopic.php?id=147478
| + | wird Tracing eingeschaltet: Jeder Script-Befehl wird vor der Ausführung auf der Konsole ausgegeben. |
| | | |
− | ==== Mounten eines CD-Images ====
| + | Mit |
− | Um ein '''CD-Image zu betrachten''' kann man dieses folgendermaßen ins normale Dateisystem einhängen:
| + | set -e |
− | mkdir zielpunkt
| + | wird grundsätzlich das Script bei einem erfolglosen Befehl abgebrochen. |
− | sudo mount -o loop -t iso9660 /pfad/zum/iso.image zielpunkt
| |
− |
| |
− | Am Ende lässt es sich ganz normal mit
| |
− |
| |
− | umount /zielpunkt
| |
| | | |
− | aushängen
| + | === Unit Tests === |
| | | |
− | ==== Mounten eines FTP-Verzeichnisses ====
| + | [https://github.com/pgrange/bash_unit Bash_unit] ist ein Paket zum Erstellen von Unit-Tests für Bash. |
| | | |
− | * Zum Mounten eines FTP-Verzeichnisses hilft [http://blog.bumsdiekuh.net/archives/84-FTP-Server-ganz-einfach-mounten-mit-curlftpfs.html angeblich] curlftpfs ([http://www.exanto.de/sftp-und-ftp-unter-linux-mounten.html ausführlichere Anleitung]).
| + | === Verarbeiten von Textstreams === |
− | * Eine andere Möglichkeit scheint [http://wiki.ubuntuusers.de/Lufs Lufs] zu bieten.
| |
| | | |
− | ==== Mounten eines ZIP-Archivs ====
| + | * Sinnvolle Hilfen zum Verarbeiten von Textstreams/Auslesen von Dateien |
− | | + | ** [[wc]] zählt Worte und Zeilen |
− | * [http://freshmeat.net/projects/fuse-zip fuse-zip(Freshmeat)], [http://linux.softpedia.com/get/System/Filesystems/fuse-zip-40109.shtml fuse-zip (Softpedia)], [http://code.google.com/p/fuse-zip/ fuse-zip (Google Code)] | + | ** [[cut]] liefert bestimmte Teile einer Zeile |
− | * [http://www.inf.bme.hu/~mszeredi/avfs/ AVFS] | + | ** [[grep]] sucht nach Textbestandteilen |
| + | ** [[sed]] hilft beim Editieren einer Datei auf der Kommandozeile bzw. in Shell-Skripten, siehe z.B. der [http://www.freiesmagazin.de/ftp/2010/freiesMagazin-2010-03.pdf Artikel zu sed im "freien Magazin"]. |
| + | ** [[printf]] ermöglicht wie in der Programmiersprache C das formatierte Ausgeben von Zahlen und Zeichen |
| + | printf '%s mit führenden Nullen: %05d' Zahl 76 |
| | | |
− | ==== Mounten via SSH ====
| + | Falls die Standardausgabe zu viel gepuffert wird kann man dies durch das Kommando <code>stdbuf -oL</code> in Zeilenpufferung ändern.<ref>Vgl. https://www.turnkeylinux.org/blog/unix-buffering .</ref> |
| | | |
− | * Übers Netzwerk kann man auch per [http://apps.sourceforge.net/mediawiki/fuse/index.php?title=Main_Page SSH-FUSE-Dateisystem] auf einen entfernten Rechner zugreifen. Das ist ein recht sicherer Zugriff, aber auch transparent, da die Dateien ins lokale Verzeichnis eingehängt (gemountet) werden können.
| + | ==== Piping ==== |
| | | |
− | ==== Mounten von NFS ====
| |
| | | |
− | Eine [[NFS]]-Freigabe (siehe /etc/exports auf dem Host) kann folgendermaßen gemountet werden:
| + | Linux kennt zwei Standard-Ausgabe-Streams, stdout und stderr. |
− | sudo mount 192.168.0.5:/srv/nfs/myhome /mnt/nfshome
| |
| | | |
− | ==== Mounten eines WebDAV-Verzeichnisses ====
| + | Die für stderr bestimmten Ausgaben können mit dem Operator "2>" in eine Datei umgeleitet werden. |
| + | Beispiel: |
| + | find / -name '*.mp3' 2> /dev/null |
| | | |
− | * [[WebDAV]]-Verzeichnisse können auch dauerhaft gemountet werden, siehe [http://www.arvid-geiger.de/index.php?category_id=40&wikipage=WebDav hier]. | + | * [http://www.easylinux.de/2005/09/084-umleitungen/ Einführung in Pipes] |
| | | |
− | Um als normaler User WebDAV-Verzeichnisse einzuhängen benötigt die <code>/etc/fstab</code> etwa folgende Zeile (Beispiel für T-Online Mediencenter und Benutzer USER):
| + | ==== heredoc ==== |
− |
| |
− | https://webdav.mediencenter.t-online.de/ /home/USER/t-online davfs noauto,user,rw 0 0
| |
| | | |
− | Zusätzlich muss der Mountpunkt noch angelegt werden:
| + | Man kann auch kleine Textschnipsel in ein Skript selbst schreiben und dann weiterleiten: |
− | mkdir ~/t-online
| |
| | | |
− | Davfs2 muss installiert werden und normalen Nutzern das Mounten erlaubt werden
| + | cat <<EOF |
− | sudo aptitude install davfs2 | + | Dies ist ein Text, der |
− | sudo dpkg-reconfigure davfs2 # Frage nach setuid mit "Ja" beantworten | + | an cat weitergegeben wird. |
| + | EOF |
| | | |
− | Der Benutzer muss noch der Gruppe <code>davfs2</code> hinzugefügt werden:
| + | Statt EOF kann in den so genannten "heredocs" auch irgendein anderes Wort |
− | sudo addgroup USER davfs2
| + | zur Bezeichnung des Endes des heredocs geschrieben werden. Es muss nur |
| + | das Gleiche am Anfang und am Ende sein. |
| | | |
− | Zur Vermeidung der Passwortabfrage sollte noch die Datei <code>/home/USER/.davfs2/secrets</code> mit folgendem Inhalt angelegt werden:<ref>http://tomalison.com/reference/2010/04/03/webdav/</ref>
| + | ==== sed ==== |
− | /home/USER/t-online xy@t-online.de password
| + | Beispiel für sed für die Umwandlung in eine Playlist: |
| + | sed -e 's/..\/Musik\/Music/dhMusic/' -e 's/\/[0-9][0-9] /\//' <playlistOriginal.m3u > playListNeu.m3u |
| + | In der neuen Playlist |
| + | * ist der Pfadanfang geändert von ../Musik/Musik nach dhMusic und |
| + | * sind die Trackziffern inklusive des Leerzeichens weggelassen. |
| | | |
− | Die Datei sollte nur von USER einsehbar sein:
| + | Etwas komplizierter |
− | chmod 600 /home/USER/.davfs2/secrets | + | sed -e 's:\\:/:g' -e 's:../Musik/Music/\(.\):sortedMusic/\1/\1:' -e 's:/\([0-9][0-9]\) :/\1_-_:' -e 's/ /_/g' < playlistOriginal.m3u > playListNeu.m3u |
| | | |
− | Dann kann das WebDAV-Verzeichnis gemountet werden: | + | * Zunächst wird der Backslash durch den Slash ersetzt. |
− | mount /home/USER/t-online
| + | * Dann der Pfadanfang geändert |
| + | * Außerdem wird die Pfadstruktur um eine Ebene erweitert: Den Anfangsbuchstaben des Interpreten |
| + | * Zwischen die Trackziffern und den Namen des Lieds werden noch ein Trennstrich mit zwei Leerzeichen eingefügt. |
| + | * Schließlich werden alle Leerzeichen durch einen Unterstrich ersetzt. |
| | | |
| + | Mit dem Modifizierer <code>-i</code> (oder <code>--in-place</code>) kann eine Datei geändert werden, die zugleich als Eingabestream fungiert. |
| | | |
− | Siehe auch [http://skripta.de/Davfs2.html diese Anleitung zum Mounten des Telekom Mediencenters].
| + | === Datum === |
| | | |
− | ==== Mounten einer Windows-Freigabe/Samba-Share ====
| + | date |
| + | zeigt das aktuelle Datum an. |
| + | date +%s |
| + | zeigt die seit 1970 vergangenen Sekunden an. |
| + | date -d "2100-1-1 -1 day" |
| + | zeigt den letzten Tag des 21. Jahrhunderts (31.12.2099) an. |
| | | |
− | * Um die [[Samba]]-Server im Netzwerk anzuzeigen, bitte | + | Siehe |
− | nmbstatus
| + | * [http://tldp.org/LDP/abs/html/timedate.html weitere Beispiele im Advanced Bash Scripting Guide]. |
− | eingeben.<ref>Vgl. http://de.opensuse.org/SDB:Drucken_via_SMB_(Samba)_Share_bzw._Windows_Freigabe.</ref>
| |
| | | |
− | * Um die von einem Samba-Server (z.B. Windows-Rechner) freigegebenen Ressourcen anzusehen, bitte
| + | === Interaktion mit Desktop === |
− | smbclient -L sambaserver
| + | ==== Zwischenablage ==== |
− | eingeben, wobei <code>sambaserver</code> der Name des Samba-Servers ist.<ref>http://www.tldp.org/HOWTO/SMB-HOWTO-8.html.</ref>
| |
| | | |
− | * Mit Konqueror lässt sich graphisch durch die Samba-Freigaben browsen: Einfach <code>smb:/</code> in die Adresszeile eingeben. | + | * Mit [http://www.linux-community.de/Archiv/Tipp-der-Woche/Xclip-Zwischenablage-fuer-die-Konsole xclip] lässt sich der Inhalt der Shell-Pipe in die Zwischenablage kopieren. Der Inhalt steht dann beispielsweise in einer KDE- oder Gnome-Anwendung zur Verfügung. |
| | | |
− | * Samba-Mounts lassen sich in der /etc/fstab auch [http://www.justlinux.com/nhf/Filesystems/Mounting_smbfs_Shares_Permanently.html permanent einrichten].
| + | ==== Nachricht an Desktop ==== |
− | ** Siehe für die Freigabe einer [[Samba]]-Share und deren Mounten z.B. [http://forum.geizhals.at/t369562,2885141.html#2885141 hier] oder [http://de.opensuse.org/SDB:Auf_Windows-Freigaben_zugreifen hier (OpenSuse 8.1)].
| |
− | ** Auch [http://www.wiki.csoft.at/index.php/Netzwerklaufwerk_mit_Linux_hinzuf%C3%BCgen hier] gibt es ein Beispiel zum Mounten einer [[Windows-Freigabe]].
| |
| | | |
| + | Mit |
| + | notify-send text |
| + | kann eine Nachricht (text) an den Desktop gesendet werden, die dem Benutzer angezeigt wird.<ref>https://linuxnetz.wordpress.com/2010/04/21/notify-send/</ref> |
| | | |
− | ==== Mounten eines Loop-Devices ====
| + | Dafür ist allerdings das Paket <code>libnotify-bin</code> zu installieren: |
| + | sudo aptitude install libnotify-bin |
| | | |
− | Das Mounten eines Loop-Devices geht wie das Mounten eines normalen Block-Devices. Bei den Optionen in der /etc/fstab steht zusätzlich <code>loop</code>.
| + | ==== User-Dialog ==== |
| | | |
− | Siehe
| + | Unter [[Gnome]] lässt sich mit <code>zenity</code> von der [[Bash]] mit dem Nutzer in Dialog treten (Ja/Nein, User-Eingabezeile, ...). |
− | * http://www.volkerschatz.com/unix/advmount.html
| |
| | | |
− | ==== Mounten eines Sandwich-Dateisystems ==== | + | ==== Arbeitsflächen wechseln ==== |
| | | |
− | Das '''UnionFS''' und das '''AUFS''' wird in moderneren [[Linux]]-Distributionen von '''OverlayFS''' abgelöst. | + | Das Paket <code>wmctrl</code> erlaubt den Wechsel zwischen den Arbeitsflächen des Desktops: |
| + | wmctrl -s arbeitsflächennummer |
| + | wobei arbeitsflächennummer die mit 0 beginnende Nummer des Desktops ist.<ref>http://www.linuxquestions.org/questions/linux-desktop-74/how-to-specify-a-gnome-workpace-an-application-will-launch-in-555764/</ref> |
| | | |
− | Beispiel: Der Inhalt des Verzeichnisses <code>lower</code> sollte im Verzeichnis <code>together</code> erscheinen, soweit er nicht vom Inhalt von <code>upper</code> verdrängt wird:
| + | Das Paket <code>devilspie</code> erlaubt es, Programme nach bestimmten Kriterien auf andere Arbeitsflächen/Viewports zu verfrachten. Dazu muss beispielsweise für <code>xterm</code> folgende Datei <code>~/.devilspie/xterm.ds</code> (Die Endung <code>.ds</code> ist wichtig) erstellt werden: |
− | sudo mount -t overlayfs -o lowerdir=lower,upperdir=upper overlayfs together
| |
− | Ist <code>upper</code> beim Einhängen leer, sieht man alle Änderungen im Verzeichnis <code>together</code> in <code>upper</code>. <code>lower</code> ändert sich nicht.
| |
| | | |
− | Siehe
| + | (if |
− | * [http://askubuntu.com/questions/109413/how-do-i-use-overlayfs Kurzanleitung für OverlayFS]
| + | (is (application_name) "xterm") |
− | * [https://git.kernel.org/cgit/linux/kernel/git/mszeredi/vfs.git/tree/Documentation/filesystems/overlayfs.txt?h=overlayfs.current OverlayFS-Technik]
| + | (begin |
| + | (set_viewport 3) |
| + | ) |
| + | ) |
| | | |
| + | Anschließend muss <code>devilspie</code> gestartet werden. Bei den folgenden Aufrufen von <code>xterm</code> wird das Fenster automatisch auf die Arbeitsfläche 3 landen. |
| | | |
− | Ähnliche Funktionalität wie OverlayFS scheint '''Ovl.o''' zu bringen:
| + | Eine Möglichkeit, mittels wmctrl und bash-Script Compiz-Viewports zu kontrollieren, findet sich [http://www.linuxquestions.org/questions/programming-9/bash-script-for-automatic-viewport-changing-and-other-wm-stuff-works-with-compiz-838827/ hier] und [http://forum.ubuntuusers.de/topic/wuerfel-per-bash-drehen/#post-1206881 hier], letzteres basierend auf [http://sfyang-en.blogspot.com/2008/02/rotate-cube-in-compiz-with-wmctrl.html diesem Blog]. |
− | * [http://home.comcast.net/~artn/ovlfs/ovl.man.txt Manpage für ovl.o]
| |
| | | |
| + | ==== Terminalfenstertitel ==== |
| | | |
− | ==== weitere Infoquelle für mount ====
| + | Der Terminaltitel lässt sich mit einer Escape-Sequenz setzen: |
| + | echo -ne "\033]0;SOME TITLE HERE\007" |
| + | Achtung: Das funktioniert bei mir aber nur innerhalb eines Shell-Skripts! |
| | | |
− | Siehe
| + | Im Normalfall bringt das aber nichts, wenn der Prompt wieder angezeigt wird, der normalerweise eine Escape-Sequenz zum Ändern des Terminaltitels beinhaltet. Daher sollte man diesen zurücksetzen: |
− | * [http://pclosmag.com/html/issues/200709/page07.html Beschreibung von Mount-Optionen].
| + | PS1="\u@\h:\w\$ " |
| | | |
− | === Kopieren einer Audio-CD ===
| + | Siehe |
| + | * http://askubuntu.com/questions/22413/how-to-change-gnome-terminal-title |
| | | |
− | Angeblich funktioniert [[dd]] nicht mit Audio-CDs.
| + | ==== Interaktion der Shell mit Maus ==== |
| | | |
− | Das einfachste Kommando zum Kopieren einer CD ist<ref>Siehe http://www.togaware.com/linux/survivor/Duplicate_Audio.html</ref>
| + | Siehe |
− | cdrdao copy
| + | * https://unix.stackexchange.com/questions/106736/detect-if-mouse-button-is-pressed-then-invoke-a-script-or-command |
| + | * http://positon.org/listen-to-mouse-events-in-linux-text-mode |
| + | * http://bamboofields.net/Bash%20-%20Linux%20raw%20mouse%20events%20bash%20click |
| + | * [https://stackoverflow.com/questions/8361263/detect-mouse-click-in-bash-script xdotool in an X-Environment] |
| + | * https://ubuntuforums.org/showthread.php?t=1017150 |
| | | |
− | Um trotzdem von der Kommandozeile (und nicht z.B. mit den grafischen Tools Brasero oder K3b) eine Audio-CD kopieren nutzt man <code>cdrdao</code>:
| + | == Dateiverwaltung == |
| | | |
− | cdrdao read-cd --device /dev/cdrom --read-raw --datafile INHALT.bin VERZEICHNIS.toc # Kopiert CD-Inhalt und -Verzeichnis auf die Festplatte
| + | === Dateisuche === |
− | cdrdao write-cd --device /dev/cdrom VERZEICHNIS.toc # Kopiert CD-Inhalt auf neue Audio-CD
| |
| | | |
− | Falls man beim Lesen Probleme bekommt und cdrdao an einer bestimmten Stelle hängen bleibt, sollte man den Paranoia-Mode reduzieren:
| + | ==== Suchen auch in Unterordnern ==== |
− | cdrdao read-cd --device /dev/cdrom ''--paranoia-mode 0'' --read-raw --datafile INHALT.bin VERZEICHNIS.toc
| + | Ein rekursives MS-DOS-<code>dir</code> lässt sich mit dem Befehl find erreichen: |
| | | |
− | === Backup ===
| + | find / -name "*xy*" |
− | * [http://blog.beimax.de/2008/10/27/tagliches-inkrementelles-backup-mit-cron-und-tar-unter-linux/ Inkrementelles Backup mit cron und tar]
| + | |
− | * [http://de.wikibooks.org/wiki/Linux-Kompendium:_Backups Linux-Kompendium: Backups] | + | Es findet alle Dateien, die ein xy im Dateinamen enthalten und gibt den vollständigen Pfad aus. Die Anführungszeichen sind wichtig, ansonsten würde die Shell bereits die Sternchen auswerten. |
− | * Siehe auch [[Programmierprojekte#P2P-Backup]]
| |
− | * [http://wiki.ubuntuusers.de/dirvish Dirvish] ist eine recht simple Commandline-Lösung, die auf [[rsync]] und [[ssh]] basiert.
| |
− | ** [http://wiki.edseek.com/howto:dirvish Dirvish-HOWTO]
| |
− | * [http://www.amanda.org/ Amanda] ist eine Open-Source-Lösung zum Backup mehrerer Clients (auch Windows) auf einem zentralen Server
| |
− | * [http://www.getdropbox.com/pricing dropbox] bietet 2 GB - Webspeicherplatz zum Synchronisieren mehrerer Computer, aber auch als Webbackup nutzbar. Es gibt auch ein [https://www.dropbox.com/help/246/en Ubuntu-Repository für Dropbox].
| |
| | | |
| + | ==== Suchen nach Dateinamen und Wörtern im Dateiinhalt ==== |
| | | |
− | Open-Source Backup Produkte:
| + | Will man an Hand des Dateinamens eine Vorauswahl der Dateien treffen, deren Inhalt auf ein bestimmtes Wort untersucht wird, kann man <code>find</code> und <code>grep</code> kombinieren: |
− | * [http://backuppc.sourceforge.net/info.html BackupPC] (serverseitige Lösung zum Backup vieler Clients, geschrieben in Perl, mit Web-Interface zur Administration)
| |
− | * [http://www.amanda.org/ Amanda]
| |
− | * [http://www.nongnu.org/storebackup/de/node14.html storebackup]
| |
| | | |
− | Linux-Bordmittel: <code>dump</code>, <code>tar</code>, <code>smbtar</code>, [http://www.orgapage.net/pages/server/linux/backup.php?OP_SITE=c2c6a3e534e145bb4b8df1f629e0d380 rsync], [http://www.bsi-fuer-buerger.de/daten/03080801.htm Tipps vom BSI], [http://www.linux-backup.net/ linux-backup.net]
| + | find . -name package.json -print0 | xargs -0 grep mylib |
| | | |
− | [http://linuxwiki.de/rsync/SnapshotBackups Umfangreiche Anleitung zu inkrementellem Backup] mit Hilfe von <code>rsync</code>
| + | Dieser Befehl sucht im aktuellen Verzeichnis und dessen Unterverzeichnissen nach Dateien mit dem Namen package.json. In diesen sucht es nach der Zeichenfolge "mylib". |
| | | |
− | * Andere Hilfsmittel: <code>[[unison]]</code> | + | === Berechtigungen === |
− |
| + | * '''Berechtigungen''' für automatisch eingebundene '''FAT32'''-Laufwerke/Festplatten werden in der Datei ''/etc/fstab'' vorgegeben. Sie können nicht mit ''chmod'' oder ''chown'' geändert werden. |
− | * [[MediaWiki]]: [http://www.mediawiki.org/wiki/Manual:Backing_up_a_wiki Anleitung zum Backup eines MediaWiki-Systems] | + | * Informationen u.a. zum SUID-Bit und zum Abschalten auf ganzen Partitionen finden sich auf |
| + | ** dem [http://www.informatikserver.at/selflinux/html/grundlagen_sicherheit07.html Informatikserver.at] |
| + | ** https://www.informatik-aktuell.de/betrieb/betriebssysteme/rechte-im-dateisystem-mehr-als-nur-rwx.html |
| | | |
− | === Festplatten in Ruhezustand versetzen ===
| + | Mit |
| + | namei -om PATH |
| + | können die einzelnen Berechtigungen eines Pfades PATH angezeigt werden. |
| | | |
− | Mittels
| + | ==== SUID ==== |
− | hdparm -S 30 /dev/sdc | + | Mit Setzen des SUID-Bits für ein binäres Programm (also keinem Shell-Skript) mit |
− | lässt sich eine Festplatte nach 30*5=150 Sekunden in den Ruhezustand versetzen.
| + | chmod u+s PROGRAMM |
| + | wird der Benutzer, der das Programm aufrufen darf (z.B. Ausführungs-Bit "x" bei der einschlägigen Gruppe gesetzt), das Programm unter dem Benutzer, der Eigentümer des Programms ist, ausführen. |
| | | |
− | Über die <code>/etc/hdparm.conf</code> lässt sich [https://linuxundich.de/hardware/festplatten-automatisch-im-betrieb-in-den-standby-schalten/ das auch automatisch einrichten].
| + | ==== SGID ==== |
| + | Mit Setzen des SGID-Bits für ein Verzeichnis erben neu angelegte Dokumente/Verzeichnisse in diesem Verzeichnis dessen Gruppe als Gruppenzugehörigkeit. |
| | | |
− | === Festplattenfehler === | + | ==== umask ==== |
| | | |
− | Festplattenfehler lassen sich u.a. mit
| + | In den Konfigurationsdateien <code>/etc/profile</code>, <code>~/.profile</code> (z.B. umask 027) oder <code>/etc/login.defs</code> (z.B. UMASK 027), je nach Linux-Ausgabe, kann zentral die Standard-Umask vorgegeben werden. Damit kann insbesondere standardmäßig vorgegeben werden, dass die erzeugten Dokumente nicht world-readable sind (umask 007). |
− | * smartmontools
| |
− | * badblocks
| |
− | * e2fsck
| |
− | * dd_rescue
| |
− | * debugfs
| |
− | finden.
| |
| | | |
− | Z.B. kann man ein fehlerhaftes EXT2/EXT3/EXT4-Dateisystem mit folgendem Befehl (interaktiv) reparieren lassen:
| + | Angeblich<ref> Vgl. https://forum.chip.de/discussion/1838389/default-umask</ref> kann man auch user-spezifisch die Default-Umask setzen: Siehe dazu /etc/default/useradd oder /etc/adduser.conf |
− | sudo e2fsck /dev/sda5
| |
| | | |
− | Siehe
| + | === Speicherplatz === |
− | * http://www.technologyblog.de/2014/06/defekte-sektoren-reparieren-unter-linux-mit-badblocks/ | + | * Den '''freien Platz auf der Festplatte''' erfährt man durch |
− | * http://www.linux-community.de/Internal/Artikel/Print-Artikel/LinuxUser/2010/08/Integritaet-gespeicherter-Daten-sicherstellen | + | df -h |
| + | * Den vom aktuellen Verzeichnis und seinen Unterverzeichnis '''belegten Platz''' erfährt man durch |
| + | du --human-readable --summarize |
| + | * Um zu sehen, welcher Platz von den einzelnen Dateien bzw. Verzeichnisse des Arbeitsverzeichnisses eingenommen wird, hilft das Tool [[xargs]]. Z.B. um alle Dateien/Verzeichnisse im Gigabyte-Bereich zu finden: |
| + | ls --almost-all -1 | xargs -n1 -d '\n' du -h --summarize | sed -n -e '/[[:digit:]]G\s/p' |
| | | |
− | === Verschlüsselung === | + | === Mounten === |
| | | |
− | * Siehe auch [[Verschlüsselung]]
| + | ==== Erkennen einer CD-ROM ==== |
| | | |
− | ==== Dateien verschlüsseln ====
| + | Möglicherweise hilft bei Nichterkennung einer CD-ROM das [http://ignorantguru.github.io/udevil/ Einschalten des Kernel-Pollings (siehe unteren Teil der verlinkten Seite)]. |
− | * Mit <code>gpg</code> lassen sich unter Linux [http://www.cs.arizona.edu/computing/utilities/linux-encryption.html#gpg einzelne Dateien verschlüsseln].
| |
− | * Automatisch für ganze Verzeichnisse geht das mit [[EncFS]]
| |
| | | |
− | ==== Dateisysteme verschlüsseln ==== | + | ==== UUID ==== |
| | | |
− | * [http://www.linux-magazin.de/Ausgaben/2006/10/Loechriger-Kaese älterer Überblick über Datei-Verschlüsselungen unter Linux]
| + | Die UUIDs der Festplattenpartitionen lassen sich mit <code>sudo blkid</code> anzeigen. |
| + | In der <code>/etc/fstab</code> ersetzt man das übliche <code>/dev/sdXX</code> durch <code>UUID=12345678</code>. |
| | | |
− | ==== SSL ==== | + | ==== LABEL ==== |
− | [[SSL]]-Zertifikate kopiert man unter [[Ubuntu]] ins Verzeichnis <code>/usr/share/ca-certificates</code> und macht sie dem System so bekannt:
| |
− | sudo dpkg-reconfigure ca-certificates
| |
| | | |
− | Siehe auch [[SSL]]
| + | Eine ext2/ext3/ext4-Partition lässt sich mit <code>sudo e2label</code> mit einem Label versehen. |
| + | In der <code>/etc/fstab</code> ersetzt man das übliche <code>/dev/sdXX</code> durch <code>LABEL=MyPart</code>. |
| | | |
− | ==== Leere Verzeichnisse löschen ==== | + | ==== Dauerhaftes Mounten einer NTFS-Partition ==== |
| | | |
− | Mit folgendem Befehl werden alle leeren Unterverzeichnisse gelöscht:<ref>http://www.unixboard.de/vb3/showthread.php?28301-leere-Verzeichnisse-finden</ref>
| + | Um eine NTFS-Partition (z.B. auf /dev/sda2) dauerhaft (also schon beim Booten) zu mounten, fügt man in die Datei <code>/etc/fstab</code> folgende Zeile hinzu: |
| + | /dev/sda2 /mnt/winC ntfs defaults,umask=011,uid=BENUTZER,gid=BENUTZERGRUPPE 0 0 |
| + | wobei BENUTZER und BENUTZERGRUPPE durch die entsprechenden Benutzernamen bzw. Gruppennammen zu ersetzen sind. |
| | | |
− | find -depth -type d -empty -exec rmdir "{}" \; | + | Außerdem muss der Mount-Point erzeugt werden: |
| + | mkdir /mnt/winC |
| | | |
− | === Dateien im Netzwerk === | + | Damit werden können aber alle Benutzer alle Daten dieses Laufwerks lesen und schreiben. Will man dies nicht, muss man mit den Optionen <code>uid=</code>, <code>gid=</code> und <code>umask=</code> eine Lösung finden. |
| | | |
− | Siehe
| + | Unter [[Debian]] ist für den Schreibzugriff auf [[NTFS]] die Installation des Pakets <code>ntfs-3g</code> notwendig: |
− | * [[NFS]]
| + | aptitude install ntfs-3g |
− | * [[Samba]]
| |
− | * [http://www.openafs.org/ OpenAFS]
| |
− | * [[WebDAV]]
| |
− | * [[SSH]] mit sshfs
| |
| | | |
− | == Netzwerk ==
| |
− | Siehe [[oldCt:Linux-Tipps#Netzwerk]]
| |
− | * Siehe [[Samba]]
| |
− | * Siehe zudem [[Installation von OpenSuse über PXE]]
| |
− | * Siehe [[Bluetooth-Tipps]]
| |
− | * Siehe [[Sony VAIO PCG-Z600RE]]
| |
− | * Siehe auch [[#Mounten eines FTP-Verzeichnisses]].
| |
| | | |
− | === Allgemeines === | + | ===== Korrupte NTFS-Partition ===== |
| | | |
− | In <code>/etc/network/interfaces</code> kann man manuelle Einstellungen für das Netzwerk vornehmen. Siehe [http://wiki.ubuntuusers.de/interfaces diese Anleitung] für [[Ubuntu]]. Dann kann man aber für das betreffende Interface den NetworkManager nicht mehr verwenden.
| + | Mit |
| + | sudo ntfsfix /dev/sdb1 |
| + | kann die NTFS-Partition auf /dev/sdb1 repariert werden.<ref>http://askubuntu.com/questions/74105/how-do-you-repair-an-input-output-error-in-an-ntfs-partition</ref> |
| | | |
− | === Network-Manager === | + | ==== USB-Datenträger unter Systemd ==== |
− | In Desktop-Distributionen ist üblicherweise der "Network-Manager" installiert. Er lässt sich auch auf der Kommandozeile nutzen:
| |
| | | |
− | sudo aptitude install Network-Manager
| + | Wenn man eine USB-Disk nur manchmal beim Start eingesteckt hat, sie in dem Fall aber automatisch mounten will, helfen möglicherweise die <code>/etc/fstab</code>-Optionen <code>nofail,nobootwait</code>.<ref>Siehe http://www.reddit.com/r/archlinux/comments/1lafu2/fstab_how_to_automount_but_ignore_if_its_not/ , https://bbs.archlinux.org/viewtopic.php?id=147478</ref> |
| | | |
− | Hinzufügen einer WLAN-Verbindung:
| + | Unter Systemd kann man auch die Optionenkombination <code>noauto,x-systemd.automount</code> in <code>/etc/fstab</code> verwenden. Dann wird die entsprechende Platte erst dann gemountet, wenn auf den Mountpunkt zugegriffen wird.<ref>Vgl. https://bbs.archlinux.org/viewtopic.php?id=147478</ref> |
− | sudo nmcli device wifi connect ''SSID'' password ''PASSWORD''
| |
− | SSID ist der WLAN-Name und Passwort ist der WLAN-Schlüssel.
| |
| | | |
− | Der Network-Manager lässt sich auch deaktivieren:<ref>Siehe http://xmodulo.com/disable-network-manager-linux.html . </ref>
| + | Siehe |
− | Unter [[Linux Mint 17]] (wahrscheinlich auch unter Ubuntu 14.04 LTS Trusty) geht das so:
| + | * http://www.wrigley.me.uk/wp/2012/12/03/automounting-usb-disk-on-boot-with-systemd-in-fedora/ |
− | echo manual | sudo tee /etc/init/network-manager.override
| + | * https://bbs.archlinux.org/viewtopic.php?id=147478 |
| | | |
| + | ==== Mounten eines CD-Images ==== |
| + | Um ein '''CD-Image zu betrachten''' kann man dieses folgendermaßen ins normale Dateisystem einhängen: |
| + | mkdir zielpunkt |
| + | sudo mount -o loop -t iso9660 /pfad/zum/iso.image zielpunkt |
| + | |
| + | Am Ende lässt es sich ganz normal mit |
| + | |
| + | umount /zielpunkt |
| | | |
− | === wicd ===
| + | aushängen |
| | | |
− | Eine Alternative zum Network-Manager ist wicd. Neben der grafischen Oberfläche (auch mit Tray-Icon) bietet wicd auch eine Kommandozeile und eine ncurses-Version zur halbgrafischen Bedienung im Terminal.
| + | ==== Mounten eines FTP-Verzeichnisses ==== |
| | | |
− | Sollte wicd unter [[Linux Mint]] 17.3 vor dem Start nach einem Passwort fragen, hilft folgende Befehlsfolge (man beachte die Punkte).<ref>Siehe https://answers.launchpad.net/ubuntu/+source/wicd/+question/94845/ Post #7.</ref>
| + | * Zum Mounten eines FTP-Verzeichnisses hilft [http://blog.bumsdiekuh.net/archives/84-FTP-Server-ganz-einfach-mounten-mit-curlftpfs.html angeblich] curlftpfs ([http://www.exanto.de/sftp-und-ftp-unter-linux-mounten.html ausführlichere Anleitung]). |
| + | * Eine andere Möglichkeit scheint [http://wiki.ubuntuusers.de/Lufs Lufs] zu bieten. |
| | | |
− | === Fehlersuche === | + | ==== Mounten eines ZIP-Archivs ==== |
| | | |
− | * Falls der Rechner etwas älter ist und die Netzwerkkarte nicht erkannt wird, hat es vielleicht mit einer Unverträglichkeit mit dem Power-Management zu tun. Vielleicht helfen dann die Boot-Optionen <code>noapic nolapic</code> weiter. | + | * [http://freshmeat.net/projects/fuse-zip fuse-zip(Freshmeat)], [http://linux.softpedia.com/get/System/Filesystems/fuse-zip-40109.shtml fuse-zip (Softpedia)], [http://code.google.com/p/fuse-zip/ fuse-zip (Google Code)] |
− | * Falls der Rechner seine IP-Adresse von einem DHCP-Server beziehen soll, hilft vielleicht
| + | * [http://www.inf.bme.hu/~mszeredi/avfs/ AVFS] |
− | /sbin/dhcpcd -d -t 10 eth0
| |
| | | |
− | Mit
| + | ==== Mounten via SSH ==== |
− | dmesg|less
| |
− | kann man sich die Ausgaben während des Bootvorgangs ansehen. Siehe bei Netzwerk-Problemen unter Linux auch http://www.adsl4linux.de/howtos/lan22/ und das [http://www.tldp.org/HOWTO/Ethernet-HOWTO.html Ethernet-HOWTO].
| |
| | | |
− | * Eine Anleitung zu [http://www.oreilly.de/german/freebooks/linag2/netz0802.htm pppd] findet sich bei O'Reilly. | + | * Übers Netzwerk kann man auch per [http://apps.sourceforge.net/mediawiki/fuse/index.php?title=Main_Page SSH-FUSE-Dateisystem] auf einen entfernten Rechner zugreifen. Das ist ein recht sicherer Zugriff, aber auch transparent, da die Dateien ins lokale Verzeichnis eingehängt (gemountet) werden können. |
− | * Siehe
| |
− | ** [[Synchronisation unter Linux]], [[Synchronisation Web-PC-Handy]].
| |
| | | |
− | === WLAN === | + | ==== Mounten von NFS ==== |
| | | |
− | ==== WLAN-Hardware ====
| + | Eine [[NFS]]-Freigabe (siehe /etc/exports auf dem Host) kann folgendermaßen gemountet werden: |
| + | sudo mount 192.168.0.5:/srv/nfs/myhome /mnt/nfshome |
| | | |
− | ===== USB-WLAN mit RT3070 Chip ===== | + | ==== Mounten eines WebDAV-Verzeichnisses ==== |
| | | |
− | Der RT3070 ist u.a. im [http://wiki.ubuntuusers.de/wlan/karten#LogiLink LogiLink WL00049A verbaut].
| + | * [[WebDAV]]-Verzeichnisse können auch dauerhaft gemountet werden, siehe [http://www.arvid-geiger.de/index.php?category_id=40&wikipage=WebDav hier]. |
| | | |
− | * Unter [[Ubuntu]] muss [http://linuxforums.org.uk/hardware-compatibility/ralink-rt2870-based-usb-wireless-n-adapters-(ubuntu)/ das Modul rt2800usb] gesperrt werden, indem es in die <code>/etc/modprobe.d/blacklist.conf</code> eingetragen wird.
| + | Um als normaler User WebDAV-Verzeichnisse einzuhängen benötigt die <code>/etc/fstab</code> etwa folgende Zeile (Beispiel für T-Online Mediencenter und Benutzer USER): |
| + | |
| + | https://webdav.magentacloud.de/ /home/USER/t-online davfs noauto,user,rw 0 0 |
| | | |
− | * Auch in [[Debian]] muss [http://vivahate.com/2011/04/04/ralink-rt2870rt3070-in-debian-6-squeeze/ das Modul rt2800usb] gesperrt werden und das Paket <code>firmware-ralink</code> aus dem <code>non-free</code>-Repository installiert werden.
| + | Zusätzlich muss der Mountpunkt noch angelegt werden: |
| + | mkdir ~/t-online |
| | | |
− | * den Treiber auf der [http://www.ralinktech.com/support.php?s=2 Hersteller-Website]
| + | Davfs2 muss installiert werden und normalen Nutzern das Mounten erlaubt werden |
− | * http://lobmenschen.de/index.php/RALINK_RT3070_Linux_Treiber_Installation ([http://ubuntuforums.org/archive/index.php/t-1106034.html Ergänzung])
| + | sudo aptitude install davfs2 |
− | * Ab Kernel 2.6.31 ist der Rt3070-Treiber (experimentell) integriert.
| + | sudo dpkg-reconfigure davfs2 # Frage nach setuid mit "Ja" beantworten |
− | * OpenSuse scheint den Chip ab V 11.1 zu unterstützen.<ref>http://www.xadux.eu/wireless-lan-und-lan/3423-rt3070-2.html</ref>
| |
− | * Auch unter [[Ubuntu]] gibt es dazu [http://forum.ubuntuusers.de/topic/wlan-an-fritzbox-7270-mit-rt3070-wpa-wpa2/ Versuche], z.B. [http://lifewithdebian.blogspot.com/ hier]. Unter Ubuntu 9.10 funktioniert der Chip jedoch bereits out-of-the-box.
| |
− | * Für [[Debian]] gibt es [http://wiki.debian.org/rt2870sta hier] eine Anleitung zu einem ähnlichen Chip.
| |
− | * Evtl. funktioniert er auch mit [http://www.openbsd.org/cgi-bin/man.cgi?query=run&sektion=4&format=html OpenBSD].
| |
| | | |
− | ===== RT2500 =====
| + | Der Benutzer muss noch der Gruppe <code>davfs2</code> hinzugefügt werden: |
− | * unter [http://www.freebsd.org/cgi/man.cgi?query=ural&sektion=4&manpath=FreeBSD+6.0-RELEASE FreeBSD 6.0]
| + | sudo addgroup USER davfs2 |
| | | |
− | ===== rt2070-Chip =====
| + | Zur Vermeidung der Passwortabfrage sollte noch die Datei <code>/home/USER/.davfs2/secrets</code> mit folgendem Inhalt angelegt werden:<ref>http://tomalison.com/reference/2010/04/03/webdav/</ref> |
− | * [http://maxein08.wordpress.com/2009/11/04/guida-allinstallazione-di-una-chiavetta-wireless-sitecom-wl-608-su-ubuntu/ italienischer Tipp]
| + | /home/USER/t-online xy@t-online.de password |
| | | |
− | ===== ZD1211-Chipsatz =====
| + | Die Datei sollte nur von USER einsehbar sein: |
− | * [http://wiki.debian.org/zd1211rw Installation unter Debian]
| + | chmod 600 /home/USER/.davfs2/secrets |
− | * Unter [[OpenSuse]]:
| |
− | zypper install zd1211-firmware
| |
| | | |
− | ==== Vermeidung der Passwortabfrage ====
| + | Dann kann das WebDAV-Verzeichnis gemountet werden: |
| + | mount /home/USER/t-online |
| | | |
− | Wenn man unter [[Gnome]] ein [[WLAN]] einrichtet, kann man das dafür nötige Passwort im Gnome-Schlüsselbund abspeichern. Wenn man beim Hochfahren sich automatisch anmelden lässt (ohne Login mit Passwort), benötigt der [[NetworkManager]] Zugriff auf den Schlüsselbund. Daher wird man vor Aufbau der Verbindung nach dem Schlüsselbund-Passwort gefragt. Das lässt sich vermeiden, indem man dem Standardschlüsselbund ein leeres Passwort gibt<ref>http://wiki.ubuntuusers.de/GNOME_Schl%C3%BCsselbund#Automatische-Anmeldung-in-GDM</ref>. Das ist aber ein <code>Sicherheitsrisiko</code>.
| + | Ein <code>auto</code>-Einbinden in der <code>/etc/fstab</code> funktioniert nicht ohne Weiteres. Möglicherweise hilft die zusätzliche Option <code>_netdev</code>, um das Einbinden bis zum Etablieren des Netzwerks zurückzustellen.<ref>Vgl. http://askubuntu.com/questions/277873/mount-webdav-fails-on-reboot</ref> |
| | | |
| | | |
− | ==== Linuxbox als WLAN-Accesspoint ====
| + | Siehe auch [http://skripta.de/Davfs2.html diese Anleitung zum Mounten des Telekom Mediencenters]. |
| | | |
− | Den Linux-Rechner kann man auch als Accesspoint für Geräte ohne WLAN nutzen, also Kabel zwischen Client und Linux-Rechner und drahtlose Übertragung zwischen Linux-Rechner und entferntem Internet-Router:
| + | ==== Mounten einer Windows-Freigabe/Samba-Share ==== |
− | * http://www.nicolaskuttler.com/post/using-any-debian-box-as-wireless-access-point/
| |
− | * http://wiki.ubuntuusers.de/WLAN_Router
| |
| | | |
− | === Bluetooth ===
| + | * Um die [[Samba]]-Server im Netzwerk anzuzeigen, bitte |
| + | nmbstatus |
| + | eingeben.<ref>Vgl. http://de.opensuse.org/SDB:Drucken_via_SMB_(Samba)_Share_bzw._Windows_Freigabe.</ref> |
| | | |
− | Siehe [[Bluetooth]]
| + | * Um die von einem Samba-Server (z.B. Windows-Rechner) freigegebenen Ressourcen anzusehen, bitte |
| + | smbclient -L sambaserver |
| + | eingeben, wobei <code>sambaserver</code> der Name des Samba-Servers ist.<ref>http://www.tldp.org/HOWTO/SMB-HOWTO-8.html.</ref> |
| | | |
| + | * Mit Konqueror lässt sich graphisch durch die Samba-Freigaben browsen: Einfach <code>smb:/</code> in die Adresszeile eingeben. |
| | | |
− | === Using Android-Phone as Internet-Modem ===
| + | * Samba-Mounts lassen sich in der /etc/fstab auch [http://www.justlinux.com/nhf/Filesystems/Mounting_smbfs_Shares_Permanently.html permanent einrichten]. |
| + | ** Siehe für die Freigabe einer [[Samba]]-Share und deren Mounten z.B. [http://forum.geizhals.at/t369562,2885141.html#2885141 hier] oder [http://de.opensuse.org/SDB:Auf_Windows-Freigaben_zugreifen hier (OpenSuse 8.1)]. |
| + | ** Auch [http://www.wiki.csoft.at/index.php/Netzwerklaufwerk_mit_Linux_hinzuf%C3%BCgen hier] gibt es ein Beispiel zum Mounten einer [[Windows-Freigabe]]. |
| | | |
− | Normalerweise kann das [[Android]]-Smartphone einfach an einen [[USB]]-Port des [[Linux]]-Rechners angeschlossen werden. Im Android muss dann in den Einstellungen noch das USB-Tethering aktiviert werden.
| |
| | | |
− | Leider funktioniert das nicht immer, eventuell hilft
| + | ==== Mounten eines Loop-Devices ==== |
− | * [http://www.upubuntu.com/2011/12/how-to-tether-your-android-phone-to.html diese Anleitung mit der App EasyTether]
| |
| | | |
− | === Wake up on LAN ===
| + | Das Mounten eines Loop-Devices geht wie das Mounten eines normalen Block-Devices. Bei den Optionen in der /etc/fstab steht zusätzlich <code>loop</code>. |
| | | |
− | Siehe [[Wake up on LAN]] | + | Siehe |
| + | * http://www.volkerschatz.com/unix/advmount.html |
| | | |
− | === Webserver === | + | ==== Mounten eines Sandwich-Dateisystems ==== |
| | | |
− | * [[Plattformübergreifende Software#Serversoftware|Serversoftware]]
| + | Das '''UnionFS''' und das '''AUFS''' wird in moderneren [[Linux]]-Distributionen von '''OverlayFS''' abgelöst. |
− | * [[oldCt:Webhosting]]
| |
− | * [[Verschlüsselung]]
| |
| | | |
− | === Mail === | + | Beispiel: Der Inhalt des Verzeichnisses <code>lower</code> sollte im Verzeichnis <code>together</code> erscheinen, soweit er nicht vom Inhalt von <code>upper</code> verdrängt wird: |
− | * [[Mail unter Linux]]
| + | sudo mount -t overlayfs -o lowerdir=lower,upperdir=upper overlayfs together |
| + | Ist <code>upper</code> beim Einhängen leer, sieht man alle Änderungen im Verzeichnis <code>together</code> in <code>upper</code>. <code>lower</code> ändert sich nicht. |
| | | |
− | === Fernzugriff ===
| + | Siehe |
− | * [[Remote Desktop]] | + | * [http://askubuntu.com/questions/109413/how-do-i-use-overlayfs Kurzanleitung für OverlayFS] |
− | ** [[ssh]]
| + | * [https://git.kernel.org/cgit/linux/kernel/git/mszeredi/vfs.git/tree/Documentation/filesystems/overlayfs.txt?h=overlayfs.current OverlayFS-Technik] |
| | | |
− | == Grafiksystem ==
| |
− | === Framebuffer ===
| |
| | | |
− | Auch ohne X-System kann man unter Linux Grafiken anzeigen: Dazu gibt es den Framebuffer.
| + | Ähnliche Funktionalität wie OverlayFS scheint '''Ovl.o''' zu bringen: |
| + | * [http://home.comcast.net/~artn/ovlfs/ovl.man.txt Manpage für ovl.o] |
| | | |
− | Siehe z.B.
| + | ==== Mounten eines iPhone-Dateisystems ==== |
− | * [http://hacklab.cz/2012/04/22/usefulness-linux-framebuffer-virtual-console fbi] zum Anzeigen von Bildern
| |
− | * fbtv zur Anzeige von Fernsehen
| |
− | * directvnc, eine [[VNC]]-Client für den Framebuffer
| |
| | | |
− | Weitere Infos
| + | Sollte beim Anstecken eines iPhones über USB-Kabel an einen Linux-Rechner und anschließendem Entsperren des iPhones durch Wischen von unten nach oben der Ordner mit den Fotos und Videos nicht automatisch gemountet werden, hilft wahrscheinlich die Installation von <code>ifuse</code>: |
− | * [http://hacklab.cz/2012/04/22/usefulness-linux-framebuffer-virtual-console Übersicht über Anwendungen für Framebuffer]
| + | sudo aptitude install ifuse |
− | * [https://github.com/notro/fbtft/wiki/Framebuffer-use weitere Anwendungsbeispiele für den Framebuffer]
| |
| | | |
− | === X ===
| |
− | * [[X Server]]
| |
| | | |
− | === Window Manager === | + | ==== weitere Infoquelle für mount ==== |
| | | |
− | Siehe [http://www.knetfeder.de/linux/spezial/pz-spezial-fenstermanager.pdf Einführung in Nur-Fenstermanager]. | + | Siehe |
| + | * [http://pclosmag.com/html/issues/200709/page07.html Beschreibung von Mount-Optionen]. |
| | | |
− | [[Fluxbox]] ist ein im Verhältnis zu [[GNOME]] und [[KDE]] schneller und kleiner Window Manager.
| + | === Kopieren einer Audio-CD === |
| | | |
− | * [http://www.linuxmint.com/rel_helena_fluxbox.php Fluxbox-Tastenkürzel]
| + | Angeblich funktioniert [[dd]] nicht mit Audio-CDs. |
| | | |
− | * Das Umsteigen von Windows würde es erleichtern, wenn er nicht nur ein Startmenü durch Rechtsklick auf den Desktop hätte, sondern auch bei Klicken eines Icons links unten. Dazu gibt es wohl auch Lösungen:
| + | Das einfachste Kommando zum Kopieren einer CD ist<ref>Siehe http://www.togaware.com/linux/survivor/Duplicate_Audio.html</ref> |
− | ** [http://ubuntuforums.org/showthread.php?p=3130878#post3130878 Änderungen am Source-Code von Fluxbox]
| + | cdrdao copy |
| | | |
− | === Grafische Fernsteuerung ===
| + | Um trotzdem von der Kommandozeile (und nicht z.B. mit den grafischen Tools Brasero oder K3b) eine Audio-CD kopieren nutzt man <code>cdrdao</code>: |
| | | |
− | Siehe [[Remote Desktop]]
| + | cdrdao read-cd --device /dev/cdrom --read-raw --datafile INHALT.bin VERZEICHNIS.toc # Kopiert CD-Inhalt und -Verzeichnis auf die Festplatte |
| + | cdrdao write-cd --device /dev/cdrom VERZEICHNIS.toc # Kopiert CD-Inhalt auf neue Audio-CD |
| | | |
− | == Multimedia ==
| + | Falls man beim Lesen Probleme bekommt und cdrdao an einer bestimmten Stelle hängen bleibt, sollte man den Paranoia-Mode reduzieren: |
− | * Siehe [[Multimedia]]
| + | cdrdao read-cd --device /dev/cdrom ''--paranoia-mode 0'' --read-raw --datafile INHALT.bin VERZEICHNIS.toc |
− | ** [[Plattformübergreifende Software#Multimedia]]
| |
| | | |
− | === Audio === | + | === Backup === |
| + | * [http://blog.beimax.de/2008/10/27/tagliches-inkrementelles-backup-mit-cron-und-tar-unter-linux/ Inkrementelles Backup mit cron und tar] |
| + | * [http://de.wikibooks.org/wiki/Linux-Kompendium:_Backups Linux-Kompendium: Backups] |
| + | * Siehe auch [[Programmierprojekte#P2P-Backup]] |
| + | * [http://wiki.ubuntuusers.de/dirvish Dirvish] ist eine recht simple Commandline-Lösung, die auf [[rsync]] und [[ssh]] basiert. |
| + | ** [http://wiki.edseek.com/howto:dirvish Dirvish-HOWTO] |
| + | * [http://www.amanda.org/ Amanda] ist eine Open-Source-Lösung zum Backup mehrerer Clients (auch Windows) auf einem zentralen Server |
| + | * [http://www.getdropbox.com/pricing dropbox] bietet 2 GB - Webspeicherplatz zum Synchronisieren mehrerer Computer, aber auch als Webbackup nutzbar. Es gibt auch ein [https://www.dropbox.com/help/246/en Ubuntu-Repository für Dropbox]. |
| | | |
− | Siehe auch [[Audio]]
| |
| | | |
− | Siehe auch [[Videotelefonie]]
| + | Open-Source Backup Produkte: |
| + | * [https://restic.net/ restic] - Kommandozeilenprogramm, geschrieben in [[Go]], siehe unten |
| + | * [https://borgbackup.readthedocs.io/en/stable/ Borg Backup], siehe [[BorgBackup]] |
| + | * [https://burp.grke.org/ Burp] |
| + | * [http://backuppc.sourceforge.net/info.html BackupPC] (serverseitige Lösung zum Backup vieler Clients, geschrieben in Perl, mit Web-Interface zur Administration) |
| + | * [http://www.amanda.org/ Amanda] |
| + | * [http://www.nongnu.org/storebackup/de/node14.html storebackup] |
| | | |
− | === Videos === | + | Linux-Bordmittel: <code>dump</code>, <code>tar</code>, <code>smbtar</code>, [http://www.orgapage.net/pages/server/linux/backup.php?OP_SITE=c2c6a3e534e145bb4b8df1f629e0d380 rsync], [http://www.bsi-fuer-buerger.de/daten/03080801.htm Tipps vom BSI], [http://www.linux-backup.net/ linux-backup.net] |
| | | |
− | ==== Abspielen ====
| + | [http://linuxwiki.de/rsync/SnapshotBackups Umfangreiche Anleitung zu inkrementellem Backup] mit Hilfe von <code>rsync</code> |
− | Die Versorgung mit Codecs ist unter Linux ein - lösbares - Problem. Z.B. hilft die [[plattformübergreifend]]e Software [[VLC]].
| |
| | | |
− | Ein Projekt namens [http://abock.org/2009/02/11/announcing-moonshine-the-project-never-formerly-known-as-pornilus/ Moonshine] ermöglicht unter Linux Windows Media Content mit Original-Microsoft-Codecs abzuspielen. Es nutzt dazu [[Moonlight]].
| + | * Andere Hilfsmittel: <code>[[unison]]</code> |
| + | |
| + | * [[MediaWiki]]: [http://www.mediawiki.org/wiki/Manual:Backing_up_a_wiki Anleitung zum Backup eines MediaWiki-Systems] |
| + | |
| + | ==== Backup mit Borg ==== |
| | | |
− | ==== Herunterladen ==== | + | ===== Backup ===== |
| + | Initialisiere Repository mit [https://borgbackup.readthedocs.io/en/stable/ Borg Backup] |
| | | |
− | Videos von [[YouTube]] lassen sich mit
| + | borg init --encrypt none <repoPath> |
− | youtube-dl -t http://www.youtube.com/watch?v=j09hpp3AxIE | + | |
− | herunterladen. Dabei ist die anzugebende URL diejenige, die man im Browser-Adressfeld beim Surfen auf youtube findet.
| |
| | | |
− | Wenn der Download nicht funktioniert, hilft wahrscheinlich ein Update
| + | Erstelle Snapshot |
− | youtube-dl -U | + | borg create --stats --progress <repopath>::documents_$(date -I) $(realpath ~/documents) |
| | | |
− | ==== TV ====
| |
| | | |
− | Neben Projekten wie
| + | Man kann auch einen Lauf starten, bei dem nichts verändert wird: |
− | * [[VDR]]
| + | borg create --dry-run --list \ |
− | * [[MythTV]]
| + | --progress <repopath>::documents_$(date -I) $(realpath ~/documents) |
− | * [[XBMC]], nun [[Kodi]]
| |
− | ** auch mit [http://linux.mjnet.eu/post/804/xbmc-pvr-tvheadend-ubuntu-12-04-install/ tvheadend]
| |
| | | |
− | gibt es auch Konsolenprogramme:
| + | ===== Borg-Repo-Pfad ===== |
− | * [[ttv]]
| |
− | * [[fbtv]] - bietet TV im [[FrameBuffer]]
| |
| | | |
− | Für den Electronic Program Guide - EPG gibt es
| + | Auf dem lokalen Rechner ist <repopath> eine schlichte Pfadangabe wie <code>/mnt/externUSB/backup</code>. |
| | | |
− | * [http://sourceforge.net/projects/tvbrowser/ den TV-Browser], freie [[Java]]-Programmzeitschrift mit Aufzeichnungs-Plugin [[SimplePVR]]
| + | Via [[SSH]] kann man aber auch auf einen entfernten Rechner backupen. <repopath> lautet dann: |
| + | ssh://user@host:port/path/to/repo |
| + | |
| + | Die Angabe des Repository-Pfades kann man sich sparen, indem man ihn mit |
| + | export BORG_REPO=<repopath> |
| + | als Umgebungsvariable borg zur Verfügung stellt. |
| | | |
− | Wichtig ist, dass der den TV-Stick nutzende User der Gruppe <code>video</code> zugeordnet ist, z.B. für den [[Tvheadend]]-Nutzer:
| + | ==== Backup mit Restic ==== |
− | sudo adduser hts video
| |
| | | |
− | Die Pakete dvbsnoop, dvb-apps, dvb-tools und w-scan bieten Werkzeuge, um die Einrichtung von DVB-C-Adaptern zu debuggen.
| + | Anlegen eines Backup-Repositorys mit [https://restic.readthedocs.io/en/stable/manual_rest.html restic]: |
− | Beispielsweise lässt sich mit
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository init |
− | dvb-fe-tool -d DVBC/ANNEX_A | + | |
− | der ein DVB-T/C-Adapter auf DVB-C umschalten.
| + | Eine Passwortdatei ist eine einfache Textdatei mit dem Passwort in einer Zeile. |
− |
| |
| | | |
− | Siehe auch [[DVB-C]]
| + | Anzeigen der vorhandenen Snapshots |
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository -p /pfad/zur/Passwortdatei snapshots |
| | | |
− | === Webcam ===
| + | Backup |
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository -p /pfad/zur/Passwortdatei backup /pfad/zu/den/zu/sichernden/dateien |
| | | |
− | * Einfach Bilder von der [[Shell]] aufnehmen geht mit dem Paket [http://ubuntu.online02.com/node/25 streamer]:
| + | restic folgt symbolischen Links (symlinks) nicht, sondern sichert sie als solche. Wenn man ein Verzeichnis, auf das ein Symlink verweist sichern will, kann man sich readlink zunutze machen: |
− | sudo aptitude install streamer
| |
− | streamer -f jpeg -o test.jpeg
| |
| | | |
− | * Alternativen sind [http://tldp.org/HOWTO/Webcam-HOWTO/framegrabbers.html camE etc.]
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository -p /pfad/zur/Passwortdatei backup $(readlink -f /pfad/zum/Symlink) |
| | | |
− | === Videotelefonie ===
| + | restic hat [https://restic.readthedocs.io/en/stable/050_restore.html viele Möglichkeiten zum Wiederherstellen]. Beispiel: |
− | ==== Skype ====
| |
− | [[Videotelefonie]] funktioniert auch unter [[Linux]], z.B. mit [[Skype]], auch wenn man zur Vermeidung von Abstürzen noch [http://dark.asengard.net/blog/2009/04/17/avoid-skype-crash-with-video-conversation-on-linux/ Workarounds] benötigt. | |
| | | |
− | * [https://help.ubuntu.com/community/SkypeTroubleshooting Skype Troubleshooting] für [[Ubuntu]]
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository -p /pfad/zur/Passwortdatei restore latest \ |
− | * [http://blogs.skype.com/linux/ Skype for Linux Blog]
| + | --target /pfad/wo/die/dateien/wiederhergestellt/werden/sollen --path "/pfad/der/wiederhergestellt/werden/soll" |
| | | |
− | ==== Alternativen ==== | + | === Festplatten in Ruhezustand versetzen === |
− | Wer nur telefonieren will, findet [http://www.easylinux.de/Artikel/ausgabe/2006/06/026-skype/ freie Alternativen], die das [[SIP]]-Protokoll nutzen.
| + | Mittels |
| + | sudo hdparm -y /dev/sdc |
| + | lässt sich die Festplatte sdc in den Standby-Modus versetzen.<ref>Vgl. https://www.pks.mpg.de/~mueller/docs/suse10.3/opensuse-manual_de/manual/sec.pmanage.silenthd.html</ref> |
| | | |
− | === Digitalkameras unter Linux ===
| + | Mittels |
− | * Siehe dazu den Beitrag unter [http://www.pro-linux.de/berichte/digitalkameras.html Pro-Linux.de]
| + | hdparm -S 30 /dev/sdc |
− | * [http://www.linuxdevcenter.com/pub/a/linux/2005/01/06/digicam.html Anleitung] für die Nutzung einer Kodak-Kamera | + | lässt sich eine Festplatte nach 30*5=150 Sekunden in den Ruhezustand versetzen. |
− | * [http://www.linuxnetmag.com/de/issue6/m6gphoto1.html Anleitung] für die Nutzung von [http://www.gphoto.org gphoto]
| |
− | * [http://m4l.berlios.de/pub/Main/HowTo/DE-DIGITALKAMERA-HOWTO.html Digitalkamera HOWTO] (noch für den Kernel 2.4)
| |
− | * Weitere Links:
| |
− | ** http://blog.chip.de/chip-linux-blog/digitalkameras-fotografie-unter-linux-20070521/
| |
− | ** http://www.multimedia4linux.de/cameramodule.html
| |
− | ** http://www.gphoto.org/cameras.html
| |
− | ** http://www.qbik.ch/usb/devices/
| |
| | | |
− | === Bildanzeige ===
| + | Über die <code>/etc/hdparm.conf</code> lässt sich [https://linuxundich.de/hardware/festplatten-automatisch-im-betrieb-in-den-standby-schalten/ das auch automatisch einrichten]. |
| | | |
− | In den graphischen Desktop-Umgebungen ist die Anzeige von Bildern selbstverständlich kein Problem.
| + | === Festplattenfehler === |
| | | |
− | Aber es gibt auch Möglichkeiten auf der Konsole:
| + | Festplattenfehler lassen sich u.a. mit |
| + | * smartmontools |
| + | * badblocks |
| + | * e2fsck |
| + | * dd_rescue |
| + | * debugfs |
| + | finden. |
| | | |
− | * [[fbi]] - benutzt Linux Frame Buffer System
| + | Z.B. kann man ein fehlerhaftes EXT2/EXT3/EXT4-Dateisystem mit folgendem Befehl (interaktiv) reparieren lassen: |
− | ** [http://linuxers.org/howto/howto-open-images-linux-console-using-fbi-console-based-image-viewer Howto für FBI]]
| + | sudo e2fsck /dev/sda5 |
− | * [[xli]]
| |
− | * [[xloadimage]] benötigt [[X]]
| |
− | * [[xwud]] bedarf einer [[X]]-Umgebung
| |
− | * [[xzgv]] benötigt [[X]], hat angeblich gute Tastaturunterstützung
| |
| | | |
− | === Bildbearbeitung ===
| + | Siehe |
− | Siehe | + | * https://recoverit.wondershare.de/harddrive-tips/repair-linux-disk.html |
− | * [[Fotografie]] | + | * http://www.technologyblog.de/2014/06/defekte-sektoren-reparieren-unter-linux-mit-badblocks/ |
− | * [[GIMP]] | + | * http://www.linux-community.de/Internal/Artikel/Print-Artikel/LinuxUser/2010/08/Integritaet-gespeicherter-Daten-sicherstellen |
− | * [[pixelize]] - ein Programm, mit dem man ein größeres Bild aus unzähligen kleineren Bildern zusammensetzen kann | |
| | | |
− | ==== ImageMagick ==== | + | === Verschlüsselung === |
− | Auf der Kommandozeile unter Linux helfen die Tools von ImageMagick:
| |
− | * [http://www.linux-community.de/Internal/Artikel/Print-Artikel/LinuxUser/2012/08/Bildbearbeitung-mit-ImageMagick Anleitung auf LINUX-Community]
| |
| | | |
− | Beispielsweise lassen sich mit folgendem Befehl Bilder als Kacheln auf einem neuen Bild getrennt mit einem transparenten Rahmen darstellen:
| + | * Siehe auch [[Verschlüsselung]] |
| | | |
− | montage -monitor -resize x200+0+0 -crop 300x200+20+0 -geometry 200x200+50+50 -background transparent bilder*.jpg uebersicht.png
| + | ==== Dateien verschlüsseln ==== |
| + | * Mit <code>gpg</code> lassen sich unter Linux [http://www.cs.arizona.edu/computing/utilities/linux-encryption.html#gpg einzelne Dateien verschlüsseln]. |
| + | * Automatisch für ganze Verzeichnisse geht das mit [[EncFS]] |
| | | |
− | === Bildinformationen === | + | ==== Dateisysteme verschlüsseln ==== |
− | Mit den [http://exiflow.sourceforge.net/wiki/Main_Page Exiflow-Tools] können Bilddateien einfach gemäß dem Erstellungsdatum umbenannt werden.
| |
| | | |
− | Mit [http://www.exiv2.org/index.html exiv2] lässt sich auf der Kommandozeile die Informationen eines Bildes auswerten.
| + | * [http://www.linux-magazin.de/Ausgaben/2006/10/Loechriger-Kaese älterer Überblick über Datei-Verschlüsselungen unter Linux] |
| | | |
− | Auch [[exiftags]] und [[exif]] bieten die Informationen aus dem EXIF-Teil des JPEG-Bilds über die Kommandozeile an.
| + | ==== SSL ==== |
| + | [[SSL]]-Zertifikate kopiert man unter [[Ubuntu]] ins Verzeichnis <code>/usr/share/ca-certificates</code> und macht sie dem System so bekannt: |
| + | sudo dpkg-reconfigure ca-certificates |
| | | |
− | Schließlich bietet auch [http://www.sentex.net/~mwandel/jhead/ jhead] ([http://linux.die.net/man/1/jhead man-page]) alle textuellen Informationen. Dieses Programm läuft nicht nur unter Linux, sondern auch unter Windows. Eine [http://www.guckes.net/augsburg2006/bildbearbeitung_auf_der_console.txt Verwendungsbeispiel]:
| + | Siehe auch [[SSL]] |
− | jhead -nfhm%04Y.%02m.%02d-%H%M%S.%f *.jpg
| |
− | Das macht aus der Datei p104711.jpg z.B. hm2007,11,12-110048.p104711.jpg.
| |
| | | |
− | In den OpenSuse-Forums findet sich ein [http://forums.opensuse.org/archives/sf-archives/archives-programming-scripting/335342-rename-files-using-creation-date.html Shell-Skript zum Umbenennen von Movies (.MOV)] basierend auf dem Dateimodifikationsdatum. Damit lässt sich obiger jhead-Befehl nachbilden (der Unterschied bleibt natürlich, dass nicht das EXIF-Datum, sondern das Dateidatum in den Namen aufgenommen wird):
| + | ==== Leere Verzeichnisse löschen ==== |
| | | |
− | #!/bin/sh
| + | Mit folgendem Befehl werden alle leeren Unterverzeichnisse gelöscht:<ref>http://www.unixboard.de/vb3/showthread.php?28301-leere-Verzeichnisse-finden</ref> |
− | for file in ${@}; do
| |
− | if [ -e $file ]; then
| |
− | timestamp=`ls -l --time-style=+%Y.%m.%d-%H%M%S $file |cut -d' ' -f6`
| |
− | newfile="hm$timestamp.$file"
| |
− | echo Aus $file wird $newfile ...
| |
− | mv -v "$file" "$newfile"
| |
− | fi
| |
− | done
| |
| | | |
− | == Fernzugriff ==
| + | find -depth -type d -empty -exec rmdir "{}" \; |
− | * [[Remote Desktop]]
| |
− | ** [[ssh]]
| |
| | | |
− | == Drucken == | + | === Dateien im Netzwerk === |
− | === Allgemeines === | |
− | * Das CUPS-Drucksystem bietet unter http://localhost:631 eine Web-Verwaltungsoberfläche.
| |
− | * CUPS verwendet das Internet Printing Protocol. Dies kann auch [http://www.heise.de/netze/Ueberall-drucken--/artikel/78252/0 Windows XP anbieten].
| |
− | * [http://hplipopensource.com/hplip-web/supported_devices/index.html Hewlett-Packard] und [http://solutions.brother.com/linux/en_us/index.html Brother] scheinen recht umfangreichen Linux-Treiber-Support für ihre Drucker zu leisten. Aber auch für [http://avasys.jp/hp/menu000000500/hpg000000442.htm Epson-Drucker] gibt es etliche Treiber.
| |
− | * [http://www.linuxforen.de/forums/showthread.php?t=213560 Überblick über Drucken unter Linux]
| |
− | * Einen Drucker am Linux-Rechner kann man [http://pda-und-co.de/linux/2009/05/03/eee-als-home-server-feste-ip-netzwerkdrucker-per-cups-einrichten/ auch vom Windows-PC als Netzwerkdrucker nutzen]
| |
| | | |
− | Beim Netzwerk-Server, an den der Drucker angeschlossen ist, muss man den Clients den Zugriff auf den Drucker erlauben:
| + | Siehe |
− | cupsctl --share-printers
| + | * [[NFS]] |
| + | * [[Samba]] |
| + | * [http://www.openafs.org/ OpenAFS] |
| + | * [[WebDAV]] |
| + | * [[SSH]] mit sshfs |
| | | |
− | Von der Shell kann man einen Netzwerkdrucker folgendermaßen zum Client hinzufügen:
| + | == Netzwerk == |
− | lpadmin -p printer -E -v ipp://server/printers/printer
| + | * Siehe [[Netzwerk]] |
− | wobei man <code>printer</code> jeweils durch die CUPS-Drucker-Bezeichnung, z.B. "DESKJET-840C" ersetzen muss.
| + | * Siehe [[Samba]] |
| + | * Siehe zudem [[Installation von OpenSuse über PXE]] |
| + | * Siehe [[Bluetooth-Tipps]] |
| + | * Siehe [[Sony VAIO PCG-Z600RE]] |
| + | * Siehe auch [[#Mounten eines FTP-Verzeichnisses]]. |
| | | |
− | Siehe auch
| + | === Allgemeines === |
− | * [[Drucken]] allgemein
| |
| | | |
− | === HP-Drucker === | + | ==== Konfiguration in <code>/etc/network/interfaces</code> ==== |
| | | |
− | HP bietet mit HPLIP eine Open Source - Unterstützung für Linux.
| + | In <code>/etc/network/interfaces</code> kann man manuelle Einstellungen für das Netzwerk vornehmen. Siehe [http://wiki.ubuntuusers.de/interfaces diese Anleitung] für [[Ubuntu]]. Dann kann man aber für das betreffende Interface den NetworkManager nicht mehr verwenden. |
| | | |
− | Falls HPLIP-Status sich wegen eines fehlenden Systray meldet, sollte man auf das GNOME-Panel gehen, rechts klicken -> "Zum Panel hinzufügen " -> "Benachrichtigungsfeld" wählen
| + | ==== Konfiguration des Netzwerks mit systemd ==== |
| | | |
− | Um einen HP-All-In-One-Drucker/Scanner wie der [[HP OfficeJet 8600 Pro Plus]] im Netzwerk zu installieren, startet man als Root
| + | Systemd kann alles, aber hält sich nicht an das KISS-Prinzip (Keep it simple stupid). So kann Systemd auch das Netzwerk konfigurieren. Siehe |
− | hp-setup -i
| + | * https://www.debian.org/doc/manuals/debian-reference/ch05.de.html#_the_modern_network_configuration_without_gui |
− | und wählt 2 für <code>net</code> aus.
| |
| | | |
− | === Brother === | + | === Network-Manager === |
| + | In Desktop-Distributionen ist üblicherweise der "Network-Manager" installiert. Er lässt sich auch auf der Kommandozeile nutzen: |
| | | |
− | Die Installation von Brother-Drucker wird seitens Brother mit eigenständigen rpm- bzw- deb-Paketen unterstützt. | + | sudo aptitude install Network-Manager |
| + | |
| + | Hinzufügen einer WLAN-Verbindung: |
| + | sudo nmcli device wifi connect ''SSID'' password ''PASSWORD'' |
| + | SSID ist der WLAN-Name und Passwort ist der WLAN-Schlüssel. |
| + | |
| + | Der Network-Manager lässt sich auch deaktivieren:<ref>Siehe http://xmodulo.com/disable-network-manager-linux.html . </ref> |
| + | Unter [[Linux Mint 17]] (wahrscheinlich auch unter Ubuntu 14.04 LTS Trusty) geht das so: |
| + | echo manual | sudo tee /etc/init/network-manager.override |
| + | |
| + | |
| + | === wicd === |
| + | |
| + | Eine Alternative zum Network-Manager ist wicd. Neben der grafischen Oberfläche (auch mit Tray-Icon) bietet wicd auch eine Kommandozeile und eine ncurses-Version zur halbgrafischen Bedienung im Terminal. |
| + | |
| + | Sollte wicd unter [[Linux Mint]] 17.3 vor dem Start nach einem Passwort fragen, hilft folgende Befehlsfolge (man beachte die Punkte).<ref>Siehe https://answers.launchpad.net/ubuntu/+source/wicd/+question/94845/ Post #7.</ref> |
| + | |
| + | === Ping ohne sudo === |
| + | |
| + | Sollte das einfache Pingen eines Rechners Root-Rechte benötigen, kann man Ping mit den nötigen Rechten ausstatten:<ref>Vgl. https://debianforum.de/forum/viewtopic.php?t=156254</ref> |
| + | sudo setcap cap_net_raw+ep /bin/ping |
| + | |
| + | === Fehlersuche === |
| + | |
| + | * Falls der Rechner etwas älter ist und die Netzwerkkarte nicht erkannt wird, hat es vielleicht mit einer Unverträglichkeit mit dem Power-Management zu tun. Vielleicht helfen dann die Boot-Optionen <code>noapic nolapic</code> weiter. |
| + | * Falls der Rechner seine IP-Adresse von einem DHCP-Server beziehen soll, hilft vielleicht |
| + | /sbin/dhcpcd -d -t 10 eth0 |
| + | |
| + | Mit |
| + | dmesg|less |
| + | kann man sich die Ausgaben während des Bootvorgangs ansehen. Siehe bei Netzwerk-Problemen unter Linux auch http://www.adsl4linux.de/howtos/lan22/ und das [http://www.tldp.org/HOWTO/Ethernet-HOWTO.html Ethernet-HOWTO]. |
| + | |
| + | * Eine Anleitung zu [http://www.oreilly.de/german/freebooks/linag2/netz0802.htm pppd] findet sich bei O'Reilly. |
| + | * Siehe |
| + | ** [[Synchronisation unter Linux]], [[Synchronisation Web-PC-Handy]]. |
| + | |
| + | |
| + | ==== Netzwerktool ip ==== |
| + | Siehe |
| + | * https://www.heise.de/ct/artikel/FAQ-Netzwerke-analysieren-und-konfigurieren-mit-ip-4769802.html |
| + | |
| + | ==== Netzwerktool ss ==== |
| + | |
| + | Mit |
| + | ss -ntlp |
| + | kann man sich die offenen Ports und die daran lauschenden Anwendungen anzeigen lassen. |
| + | |
| + | ==== Netzwerktool netstat ==== |
| + | |
| + | Zur Installation: |
| + | sudo aptitude install net-tools |
| + | |
| + | Zum Anzeigen der am Netzwerk lauschenden Programme: |
| + | |
| + | sudo netstat -tulpn |
| + | |
| + | ==== lsof ==== |
| + | |
| + | Mit Hilfe von |
| + | sudo lsof -nP -i | grep LISTEN |
| + | kann man sich ebenfalls die offenen Netzwerk-Ports (und die daran angedockten Prozesse) anzeigen lassen. |
| + | |
| + | ==== Netzwerkanalyse ==== |
| + | |
| + | Siehe [[Netzwerk]] |
| + | |
| + | === WLAN === |
| + | |
| + | ==== WLAN-Hardware ==== |
| + | |
| + | ===== USB-WLAN mit RT3070 Chip ===== |
| + | |
| + | Der RT3070 ist u.a. im [http://wiki.ubuntuusers.de/wlan/karten#LogiLink LogiLink WL00049A verbaut]. |
| + | |
| + | * Unter [[Ubuntu]] muss [http://linuxforums.org.uk/hardware-compatibility/ralink-rt2870-based-usb-wireless-n-adapters-(ubuntu)/ das Modul rt2800usb] gesperrt werden, indem es in die <code>/etc/modprobe.d/blacklist.conf</code> eingetragen wird. |
| + | |
| + | * Auch in [[Debian]] muss [http://vivahate.com/2011/04/04/ralink-rt2870rt3070-in-debian-6-squeeze/ das Modul rt2800usb] gesperrt werden und das Paket <code>firmware-ralink</code> aus dem <code>non-free</code>-Repository installiert werden. |
| + | |
| + | * den Treiber auf der [http://www.ralinktech.com/support.php?s=2 Hersteller-Website] |
| + | * http://lobmenschen.de/index.php/RALINK_RT3070_Linux_Treiber_Installation ([http://ubuntuforums.org/archive/index.php/t-1106034.html Ergänzung]) |
| + | * Ab Kernel 2.6.31 ist der Rt3070-Treiber (experimentell) integriert. |
| + | * OpenSuse scheint den Chip ab V 11.1 zu unterstützen.<ref>http://www.xadux.eu/wireless-lan-und-lan/3423-rt3070-2.html</ref> |
| + | * Auch unter [[Ubuntu]] gibt es dazu [http://forum.ubuntuusers.de/topic/wlan-an-fritzbox-7270-mit-rt3070-wpa-wpa2/ Versuche], z.B. [http://lifewithdebian.blogspot.com/ hier]. Unter Ubuntu 9.10 funktioniert der Chip jedoch bereits out-of-the-box. |
| + | * Für [[Debian]] gibt es [http://wiki.debian.org/rt2870sta hier] eine Anleitung zu einem ähnlichen Chip. |
| + | * Evtl. funktioniert er auch mit [http://www.openbsd.org/cgi-bin/man.cgi?query=run&sektion=4&format=html OpenBSD]. |
| + | |
| + | ===== RT2500 ===== |
| + | * unter [http://www.freebsd.org/cgi/man.cgi?query=ural&sektion=4&manpath=FreeBSD+6.0-RELEASE FreeBSD 6.0] |
| + | |
| + | ===== rt2070-Chip ===== |
| + | * [http://maxein08.wordpress.com/2009/11/04/guida-allinstallazione-di-una-chiavetta-wireless-sitecom-wl-608-su-ubuntu/ italienischer Tipp] |
| + | |
| + | ===== ZD1211-Chipsatz ===== |
| + | * [http://wiki.debian.org/zd1211rw Installation unter Debian] |
| + | * Unter [[OpenSuse]]: |
| + | zypper install zd1211-firmware |
| + | |
| + | ==== Vermeidung der Passwortabfrage ==== |
| + | |
| + | Wenn man unter [[Gnome]] ein [[WLAN]] einrichtet, kann man das dafür nötige Passwort im Gnome-Schlüsselbund abspeichern. Wenn man beim Hochfahren sich automatisch anmelden lässt (ohne Login mit Passwort), benötigt der [[NetworkManager]] Zugriff auf den Schlüsselbund. Daher wird man vor Aufbau der Verbindung nach dem Schlüsselbund-Passwort gefragt. Das lässt sich vermeiden, indem man dem Standardschlüsselbund ein leeres Passwort gibt<ref>http://wiki.ubuntuusers.de/GNOME_Schl%C3%BCsselbund#Automatische-Anmeldung-in-GDM</ref>. Das ist aber ein <code>Sicherheitsrisiko</code>. |
| + | |
| + | |
| + | ==== Linuxbox als WLAN-Accesspoint ==== |
| + | |
| + | Den Linux-Rechner kann man auch als Accesspoint für Geräte ohne WLAN nutzen, also Kabel zwischen Client und Linux-Rechner und drahtlose Übertragung zwischen Linux-Rechner und entferntem Internet-Router: |
| + | * http://www.nicolaskuttler.com/post/using-any-debian-box-as-wireless-access-point/ |
| + | * http://wiki.ubuntuusers.de/WLAN_Router |
| + | |
| + | === Bluetooth === |
| + | |
| + | Siehe [[Bluetooth]] |
| + | |
| + | |
| + | === Using Android-Phone as Internet-Modem === |
| + | |
| + | Normalerweise kann das [[Android]]-Smartphone einfach an einen [[USB]]-Port des [[Linux]]-Rechners angeschlossen werden. Im Android muss dann in den Einstellungen noch das USB-Tethering aktiviert werden. |
| + | |
| + | Leider funktioniert das nicht immer, eventuell hilft |
| + | * [http://www.upubuntu.com/2011/12/how-to-tether-your-android-phone-to.html diese Anleitung mit der App EasyTether] |
| + | |
| + | === Wake up on LAN === |
| + | |
| + | Siehe [[Wake up on LAN]] |
| + | |
| + | === Webserver === |
| + | |
| + | * [[Plattformübergreifende Software#Serversoftware|Serversoftware]] |
| + | * [[oldCt:Webhosting]] |
| + | * [[Verschlüsselung]] |
| + | |
| + | === Mail === |
| + | Siehe |
| + | * [[Mail unter Linux]] |
| + | * [[Postfix]] |
| + | |
| + | === Fernzugriff === |
| + | * [[Remote Desktop]] |
| + | ** [[ssh]] |
| + | |
| + | == Grafiksystem == |
| + | |
| + | === Monitorinfos === |
| + | |
| + | Ob der Monitor angeschaltet oder im StandBy ist, kann man mit |
| + | ddccontrol -p |
| + | erfahren. |
| + | |
| + | Ansonsten bekommt man auch noch über folgende Befehle Infos über den Monitor (ggf. <code>DISPLAY=:0</code> voranstellen): |
| + | xrandr |
| + | oder |
| + | xset -q |
| + | |
| + | === Framebuffer === |
| + | |
| + | Auch ohne X-System kann man unter Linux Grafiken anzeigen: Dazu gibt es den Framebuffer. |
| + | |
| + | Siehe z.B. |
| + | * mplayer zum Anzeigen von Videos |
| + | * [http://hacklab.cz/2012/04/22/usefulness-linux-framebuffer-virtual-console fbi] zum Anzeigen von Bildern |
| + | * fbtv zur Anzeige von Fernsehen |
| + | * directvnc, eine [[VNC]]-Client für den Framebuffer |
| + | |
| + | Weitere Infos |
| + | * [http://hacklab.cz/2012/04/22/usefulness-linux-framebuffer-virtual-console Übersicht über Anwendungen für Framebuffer] |
| + | * [https://github.com/notro/fbtft/wiki/Framebuffer-use weitere Anwendungsbeispiele für den Framebuffer] |
| + | |
| + | ==== mplayer für Framebuffer ==== |
| + | |
| + | Der Kommandozeilen-basierte Audio- und Video-Abspieler [[mplayer]] kann auch Videos auf der Linux-Konsole mittels Framebuffer anzeigen: |
| + | mplayer -vo fbdev2 VIDEO.MOV |
| + | |
| + | Evtl. muss der Nutzer der Gruppe <code>video</code> hinzugefügt werden. |
| + | |
| + | ==== vlc für Framebuffer ==== |
| + | |
| + | Auch [[vlc]] kann den FrameBuffer nutzen. Das funktioniert z.B. mit der [[NCURSES]]-basierten Oberfläche, die man mit |
| + | nvlc |
| + | oder |
| + | vlc -I |
| + | erreicht. |
| + | |
| + | Die Installation erfolgt über |
| + | sudo aptitude install nvlc |
| + | |
| + | oder |
| + | sudo aptitude install vlc-bin vlc-base-plugins |
| + | |
| + | Hier ist erforderlich, dass der ausführende Benutzer der Gruppe <code>video</code> hinzugefügt wird: |
| + | |
| + | sudo adduser USER video |
| + | |
| + | |
| + | Damit können z.B. auch rtsp-Streams (z.B. vom Kabeltuner der [[Fritz!box 6490]]) abgespielt werden: |
| + | nvlc 'rtsp://....' |
| + | |
| + | === X === |
| + | * [[X Server]] |
| + | |
| + | === Display Manager === |
| + | |
| + | Die Auswahl der Desktopumgebung wird nicht mehr unter <code>~/.dmrc</code> gespeichert, sondern in <code>/var/lib/AccountsService/users/$USER</code>. |
| + | |
| + | Man kann die Wahl aber auch über den [[dbus]] speichern: |
| + | |
| + | dbus-send --system --type=method_call --print-reply --dest=org.freedesktop.Accounts /org/freedesktop/Accounts/User1000 org.freedesktop.Accounts.User.SetXSession string:cinnamon |
| + | |
| + | === Window Manager === |
| + | |
| + | Siehe [http://www.knetfeder.de/linux/spezial/pz-spezial-fenstermanager.pdf Einführung in Nur-Fenstermanager]. |
| + | |
| + | [[Fluxbox]] ist ein im Verhältnis zu [[GNOME]] und [[KDE]] schneller und kleiner Window Manager. |
| + | |
| + | * [http://www.linuxmint.com/rel_helena_fluxbox.php Fluxbox-Tastenkürzel] |
| + | |
| + | * Das Umsteigen von Windows würde es erleichtern, wenn er nicht nur ein Startmenü durch Rechtsklick auf den Desktop hätte, sondern auch bei Klicken eines Icons links unten. Dazu gibt es wohl auch Lösungen: |
| + | ** [http://ubuntuforums.org/showthread.php?p=3130878#post3130878 Änderungen am Source-Code von Fluxbox] |
| + | |
| + | ==== Menüeinträge fürs "Startmenü" oder den Desktop ==== |
| + | |
| + | Mit Hilfe von .desktop-Dateien können Einträge fürs Startmenü oder den Schreibtisch zum Starten von Programmen ("Apps") erstellt werden. Siehe |
| + | * https://wiki.ubuntuusers.de/.desktop-Dateien/ |
| + | |
| + | Diese kann man auch nutzen, um die Programme beim Start des graphischen Desktops automatisch zu starten. Dazu müssen sie ins Verzeichnis <code>/etc/xdg/autostart/</code> bzw. <code>/home/USER/.config/autostart</code> eingefügt und als ausführbar markiert werden. |
| + | |
| + | ==== Programme minimiert starten ==== |
| + | |
| + | In den .desktop-Dateien fehlt leider eine Option zum minimierten Starten. |
| + | |
| + | Aber es gibt Abhilfe mittels wmctrl und xdotool: https://www.reddit.com/r/kde/comments/b0k01e/start_application_at_login_minimized/ |
| + | |
| + | Linux wäre nicht Linux, wenn es nicht noch einen zweiten Weg gäbe (hier devilspie): http://www.webupd8.org/2011/02/how-to-start-applications-minimized.html |
| + | |
| + | === Grafische Fernsteuerung === |
| + | |
| + | Siehe [[Remote Desktop]] |
| + | |
| + | == Multimedia == |
| + | * Siehe [[Multimedia]] |
| + | ** [[Plattformübergreifende Software#Multimedia]] |
| + | |
| + | === Audio === |
| + | |
| + | Siehe auch [[Audio#Linux%20und%20Audio]] |
| + | |
| + | Siehe auch [[Videotelefonie]] |
| + | |
| + | === Videos === |
| + | |
| + | |
| + | Siehe auch [[Fotografie#Film_und_Video]] |
| + | |
| + | ==== Abspielen ==== |
| + | Die Versorgung mit Codecs ist unter Linux ein - lösbares - Problem. Z.B. hilft die [[plattformübergreifend]]e Software [[VLC]]. |
| + | |
| + | Ein Projekt namens [http://abock.org/2009/02/11/announcing-moonshine-the-project-never-formerly-known-as-pornilus/ Moonshine] ermöglicht unter Linux Windows Media Content mit Original-Microsoft-Codecs abzuspielen. Es nutzt dazu [[Moonlight]]. |
| + | |
| + | ==== Herunterladen ==== |
| + | |
| + | Videos von [[YouTube]] lassen sich mit |
| + | youtube-dl -t http://www.youtube.com/watch?v=j09hpp3AxIE |
| + | herunterladen. Dabei ist die anzugebende URL diejenige, die man im Browser-Adressfeld beim Surfen auf youtube findet. |
| + | |
| + | Wenn der Download nicht funktioniert, hilft wahrscheinlich ein Update |
| + | youtube-dl -U |
| + | |
| + | ==== TV ==== |
| + | |
| + | Neben Projekten wie |
| + | * [[VDR]] |
| + | * [[MythTV]] |
| + | * [[XBMC]], nun [[Kodi]] |
| + | ** auch mit [http://linux.mjnet.eu/post/804/xbmc-pvr-tvheadend-ubuntu-12-04-install/ tvheadend] |
| + | |
| + | gibt es auch Konsolenprogramme: |
| + | * [[ttv]] |
| + | * [[fbtv]] - bietet TV im [[FrameBuffer]] |
| + | |
| + | Für den Electronic Program Guide - EPG gibt es |
| + | |
| + | * [http://sourceforge.net/projects/tvbrowser/ den TV-Browser], freie [[Java]]-Programmzeitschrift mit Aufzeichnungs-Plugin [[SimplePVR]] |
| + | |
| + | Wichtig ist, dass der den TV-Stick nutzende User der Gruppe <code>video</code> zugeordnet ist, z.B. für den [[Tvheadend]]-Nutzer: |
| + | sudo adduser hts video |
| + | |
| + | Die Pakete dvbsnoop, dvb-apps, dvb-tools und w-scan bieten Werkzeuge, um die Einrichtung von DVB-C-Adaptern zu debuggen. |
| + | Beispielsweise lässt sich mit |
| + | dvb-fe-tool -d DVBC/ANNEX_A |
| + | der ein DVB-T/C-Adapter auf DVB-C umschalten. |
| + | |
| + | |
| + | Siehe auch [[DVB-C]] |
| + | |
| + | === Webcam === |
| + | |
| + | * Einfach Bilder von der [[Shell]] aufnehmen geht mit dem Paket [http://ubuntu.online02.com/node/25 streamer]: |
| + | sudo aptitude install streamer |
| + | streamer -f jpeg -o test.jpeg |
| + | |
| + | * Alternativen sind [http://tldp.org/HOWTO/Webcam-HOWTO/framegrabbers.html camE etc.] |
| + | |
| + | === Videotelefonie === |
| + | ==== Skype ==== |
| + | [[Videotelefonie]] funktioniert auch unter [[Linux]], z.B. mit [[Skype]], auch wenn man zur Vermeidung von Abstürzen noch [http://dark.asengard.net/blog/2009/04/17/avoid-skype-crash-with-video-conversation-on-linux/ Workarounds] benötigt. |
| + | |
| + | * [https://help.ubuntu.com/community/SkypeTroubleshooting Skype Troubleshooting] für [[Ubuntu]] |
| + | * [http://blogs.skype.com/linux/ Skype for Linux Blog] |
| + | |
| + | ==== Alternativen ==== |
| + | Wer nur telefonieren will, findet [http://www.easylinux.de/Artikel/ausgabe/2006/06/026-skype/ freie Alternativen], die das [[SIP]]-Protokoll nutzen. |
| + | |
| + | Alternativen auch mit Video scheinen |
| + | * [https://bigbluebutton.org/ BigBlueButton] |
| + | * [https://jitsi.org/ Jitsi] |
| + | ** [https://jitsi.org/jitsi-meet/ Jitsi Meet] kann sofort (ohne Registrierung) auf https://meet.jit.si/ ausprobiert werden. |
| + | * https://opentalk.eu/de |
| + | * [https://www.golem.de/news/aus-dem-verlag-odin-rooms-macht-videocalls-sicher-und-klar-2409-188992.html Odin Rooms] |
| + | zu sein. |
| + | |
| + | Bekannte kommerzielle Alternativen zum veralteten Skype sind |
| + | * Microsoft Teams |
| + | * Cisco Webex |
| + | * Zoom |
| + | |
| + | === Digitalkameras unter Linux === |
| + | * Siehe dazu den Beitrag unter [http://www.pro-linux.de/berichte/digitalkameras.html Pro-Linux.de] |
| + | * [http://www.linuxdevcenter.com/pub/a/linux/2005/01/06/digicam.html Anleitung] für die Nutzung einer Kodak-Kamera |
| + | * [http://www.linuxnetmag.com/de/issue6/m6gphoto1.html Anleitung] für die Nutzung von [http://www.gphoto.org gphoto] |
| + | * [http://m4l.berlios.de/pub/Main/HowTo/DE-DIGITALKAMERA-HOWTO.html Digitalkamera HOWTO] (noch für den Kernel 2.4) |
| + | * Weitere Links: |
| + | ** http://blog.chip.de/chip-linux-blog/digitalkameras-fotografie-unter-linux-20070521/ |
| + | ** http://www.multimedia4linux.de/cameramodule.html |
| + | ** http://www.gphoto.org/cameras.html |
| + | ** http://www.qbik.ch/usb/devices/ |
| + | |
| + | === Bildanzeige === |
| + | |
| + | In den graphischen Desktop-Umgebungen ist die Anzeige von Bildern selbstverständlich kein Problem. |
| + | |
| + | Aber es gibt auch Möglichkeiten auf der Konsole: |
| + | |
| + | * [[fbi]] - benutzt Linux Frame Buffer System |
| + | ** [http://linuxers.org/howto/howto-open-images-linux-console-using-fbi-console-based-image-viewer Howto für FBI]] |
| + | * [[xli]] |
| + | * [[xloadimage]] benötigt [[X]] |
| + | * [[xwud]] bedarf einer [[X]]-Umgebung |
| + | * [[xzgv]] benötigt [[X]], hat angeblich gute Tastaturunterstützung |
| + | |
| + | === Bildbearbeitung === |
| + | Siehe |
| + | * [[Fotografie]] |
| + | * [[GIMP]] |
| + | * [[pixelize]] - ein Programm, mit dem man ein größeres Bild aus unzähligen kleineren Bildern zusammensetzen kann |
| + | |
| + | ==== ImageMagick ==== |
| + | Auf der Kommandozeile unter Linux helfen die Tools von ImageMagick: |
| + | * [http://www.linux-community.de/Internal/Artikel/Print-Artikel/LinuxUser/2012/08/Bildbearbeitung-mit-ImageMagick Anleitung auf LINUX-Community] |
| + | |
| + | Beispielsweise lassen sich mit folgendem Befehl Bilder als Kacheln auf einem neuen Bild getrennt mit einem transparenten Rahmen darstellen: |
| + | |
| + | montage -monitor -resize x200+0+0 -crop 300x200+20+0 -geometry 200x200+50+50 -background transparent bilder*.jpg uebersicht.png |
| + | |
| + | === Bildinformationen === |
| + | Mit den [http://exiflow.sourceforge.net/wiki/Main_Page Exiflow-Tools] können Bilddateien einfach gemäß dem Erstellungsdatum umbenannt werden. |
| + | |
| + | Mit [http://www.exiv2.org/index.html exiv2] lässt sich auf der Kommandozeile die Informationen eines Bildes auswerten. |
| + | |
| + | Auch [[exiftags]] und [[exif]] bieten die Informationen aus dem EXIF-Teil des JPEG-Bilds über die Kommandozeile an. |
| + | |
| + | ==== Aufnahmedatum in Dateinamen ==== |
| + | Schließlich bietet auch [http://www.sentex.net/~mwandel/jhead/ jhead] ([http://linux.die.net/man/1/jhead man-page]) alle textuellen Informationen. Dieses Programm läuft nicht nur unter Linux, sondern auch unter Windows. Ein [http://www.guckes.net/augsburg2006/bildbearbeitung_auf_der_console.txt Verwendungsbeispiel]: |
| + | jhead -nfhm%04Y.%02m.%02d-%H%M%S.%f *.jpg |
| + | Das macht aus der Datei p104711.jpg z.B. hm2007,11,12-110048.p104711.jpg. |
| + | |
| + | In den OpenSuse-Forums findet sich ein [http://forums.opensuse.org/archives/sf-archives/archives-programming-scripting/335342-rename-files-using-creation-date.html Shell-Skript zum Umbenennen von Movies (.MOV)] basierend auf dem Dateimodifikationsdatum. Damit lässt sich obiger jhead-Befehl nachbilden (der Unterschied bleibt natürlich, dass nicht das EXIF-Datum, sondern das Dateidatum in den Namen aufgenommen wird): |
| + | |
| + | #!/bin/sh |
| + | for file in ${@}; do |
| + | if [ -e $file ]; then |
| + | timestamp=`ls -l --time-style=+%Y.%m.%d-%H%M%S $file |cut -d' ' -f6` |
| + | newfile="hm$timestamp.$file" |
| + | echo Aus $file wird $newfile ... |
| + | mv -v "$file" "$newfile" |
| + | fi |
| + | done |
| + | |
| + | ==== Geotagging von Fotos ==== |
| + | |
| + | Möchte man seine Fotos von einer Kamera ohne GPS-Receiver mit GPS-Daten z.B. aus dem mitgeführten Smartphone aufwerten, dann hilft das exiftool, z.B.: |
| + | exiftool -api GeoMaxExtSecs=9999 -geotag '*.gpx' images |
| + | |
| + | Dieses Beispiel nutzt als Geodaten-Quelle alle Dateien mit der Endung gpx im aktuellen Verzeichnis und versieht alle Bilder im images-Ordner mit den entsprechenden Daten. Siehe dazu näher die [http://www.sno.phy.queensu.ca/~phil/exiftool/geotag.html Beschreibung auf der Projektseite]. |
| + | |
| + | Die Geodaten bekommt man z.B. mit der [[Android]] - [[Open Source]]-Software [https://github.com/mendhak/gpslogger gpslogger]. |
| + | |
| + | == Fernzugriff == |
| + | * [[Remote Desktop]] |
| + | ** [[ssh]] |
| + | |
| + | == Drucken == |
| + | === Allgemeines === |
| + | * Das CUPS-Drucksystem bietet unter http://localhost:631 eine Web-Verwaltungsoberfläche. |
| + | * CUPS verwendet das Internet Printing Protocol. Dies kann auch [http://www.heise.de/netze/Ueberall-drucken--/artikel/78252/0 Windows XP anbieten]. |
| + | * [http://hplipopensource.com/hplip-web/supported_devices/index.html Hewlett-Packard] und [http://solutions.brother.com/linux/en_us/index.html Brother] scheinen recht umfangreichen Linux-Treiber-Support für ihre Drucker zu leisten. Aber auch für [http://avasys.jp/hp/menu000000500/hpg000000442.htm Epson-Drucker] gibt es etliche Treiber. |
| + | * [http://www.linuxforen.de/forums/showthread.php?t=213560 Überblick über Drucken unter Linux] |
| + | * Einen Drucker am Linux-Rechner kann man [http://pda-und-co.de/linux/2009/05/03/eee-als-home-server-feste-ip-netzwerkdrucker-per-cups-einrichten/ auch vom Windows-PC als Netzwerkdrucker nutzen] |
| + | |
| + | Beim Netzwerk-Server, an den der Drucker angeschlossen ist, muss man den Clients den Zugriff auf den Drucker erlauben: |
| + | cupsctl --share-printers |
| + | |
| + | Von der Shell kann man einen Netzwerkdrucker folgendermaßen zum Client hinzufügen: |
| + | lpadmin -p "$PRINTER" -E -v "ipp://$SERVER/printers/$PRINTER" |
| + | wobei man <code>$PRINTER</code> jeweils durch die CUPS-Drucker-Bezeichnung, z.B. "DESKJET-840C" ersetzen muss. |
| + | |
| + | Mit |
| + | lpstat -p -d |
| + | kann man sich die vorhandenen Drucker anzeigen lassen. |
| + | |
| + | Mit |
| + | lpoptions -d DRUCKER |
| + | kann man den Standard-Drucker auswählen. |
| + | |
| + | |
| + | Mit |
| + | lpstat -o -a |
| + | kann man sich alle noch offenen Druckaufträge anzeigen lassen. |
| + | |
| + | Mit |
| + | lpstat -W completed -o -a |
| + | kann man sich alle abgeschlossenen Druckaufträge anzeigen lassen. |
| + | |
| + | Siehe auch |
| + | * [http://localhost:631/help/options.html CUPS-Hilfe zu Kommandozeilenbefehlen auf eigenem Rechner] |
| + | * [[Drucken]] allgemein |
| + | * https://www.linux-praxis.de/verwaltung-von-druckern-und-druckerwarteschlangen |
| + | |
| + | ==== Troubleshooting ==== |
| + | |
| + | |
| + | ===== HP 7740 verschiebt Seiteninhalt ===== |
| + | |
| + | Fehler: HP 7740 verschiebt die Seite auf dem Blatt Papier, so dass ein leerer oberer und rechter Rand entsteht. |
| + | |
| + | Mögliche Behebung: Avahi auch für IPv6 einstellen. |
| + | |
| + | In /etc/nsswitch.conf die folgende Zeile korrigieren: |
| + | |
| + | hosts: mymachines '''mdns_minimal''' [NOTFOUND=return] resolve [!UNAVAIL=return] files myhostname dns |
| + | |
| + | Das mdns_minimal hat also keine "4" mehr im Namen. |
| + | |
| + | Neustart von Avahi mit |
| + | |
| + | sudo systemctl restart avahi-daemon.service |
| + | |
| + | Der Drucker, der dann automatisch gefunden wird, druckt die Seitenränder richtig. |
| + | |
| + | Siehe https://wiki.archlinux.org/title/Avahi |
| + | |
| + | ===== CUPS in Docker ===== |
| + | |
| + | https://hub.docker.com/r/olbat/cupsd |
| + | |
| + | ===== Drucker deaktiviert sich von selbst ===== |
| + | |
| + | Um zu vermeiden, dass man jedes Mal den Drucker wieder auf "aktiviert" stellen muss, fügt man in der Datei <code>/etc/cups/printer.conf</code> die Zeile |
| + | ErrorPolicy retry-job |
| + | hinzu. Siehe |
| + | * https://debianforum.de/forum/viewtopic.php?t=126837 |
| + | |
| + | === Driverless Printing === |
| + | |
| + | Seit ca. 2020 wird die Linux-Druckerunterstützung auf "treiberlos" (driverless) umgestellt. |
| + | Stattdessen werden sowohl für Windows als auch für Linux verwendbare PPD-Dateien genutzt. |
| + | |
| + | Grundsätzlich gehen diese PPD-Dateien einem eigenen Treiber für Linux vor. |
| + | |
| + | Siehe |
| + | * https://linuxmint-user-guide.readthedocs.io/en/latest/printers.html |
| + | |
| + | === Xerox Drucker === |
| + | |
| + | Siehe [[Xerox_C325]] |
| + | |
| + | |
| + | === HP-Drucker === |
| + | |
| + | HP bietet mit HPLIP eine Open Source - Unterstützung für Linux. |
| + | |
| + | Falls HPLIP-Status sich wegen eines fehlenden Systray meldet, sollte man auf das GNOME-Panel gehen, rechts klicken -> "Zum Panel hinzufügen " -> "Benachrichtigungsfeld" wählen |
| + | |
| + | Um einen HP-All-In-One-Drucker/Scanner wie der [[HP OfficeJet 8600 Pro Plus]] im Netzwerk zu installieren, startet man als Root |
| + | hp-setup -i |
| + | und wählt 2 für <code>net</code> aus. |
| + | |
| + | ==== HP OfficeJet Pro 7740 ==== |
| + | |
| + | Jedenfalls im Zusammenspiel mit Linux hat der HP OfficeJet Pro 7740 nicht die Qualität und Zuverlässigkeit des HP OfficeJet 8600 Pro Plus. |
| + | |
| + | Aber er funktioniert, wenn nicht mal wieder ein Firmware-Update das Zusammenspiel mit Linux oder Windows zerschießt. |
| + | |
| + | Nach dem letzten Firmware-Update konnten manche Linux-Systeme den Drucker nicht finden. Bei den Systemen mit Ubuntu 24.04 musste der Drucker manuell eingerichtet werden. Beim Drucker hinzufügen musste man folgende URL angeben: |
| + | ipps://hpofficejet.fritz.box:443/ipp/print |
| + | |
| + | Dann hplip bzw. hpcups auswählen. Dann funktioniert es manchmal. |
| + | |
| + | Allerdings nicht überall. Dann kann man versuchen, die o.a. ipp-Adresse zu nutzen und den Drucker als generischen PCL-Drucker anzulegen. Ich habe als Marke '''"Generic"''' gewählt und als Modell '''"PCL 6/PCL XL"'''' und als Treiber '''"Generic ... /hpijs-pcl5e"''' (Ubuntu 24.04). Dann geht es aber nur schwarzweiß und nur in A4. Außerdem musste ich hpijs installieren: |
| + | |
| + | sudo aptitude install printer-driver-hpijs hpijs-ppds |
| + | |
| + | === Brother === |
| + | |
| + | Die Installation von Brother-Drucker wird seitens Brother mit eigenständigen rpm- bzw- deb-Paketen unterstützt. |
| + | |
| + | Bei der Installation des Brother MFC-260C unter Linux Mint 17 32bit bedarf es folgender Schritte nach dem Download der DEB-Files vom [http://support.brother.com/g/s/id/linux/en/instruction_prn1a.html?c=us_ot&lang=en&redirect=on Brother Solutions Center]: |
| + | |
| + | sudo mkdir /var/spool/lpd |
| + | sudo chgrp lp /var/spool/lpd |
| + | sudo dpkg -i mfc260clpr-1.0.1-1.i386.deb |
| + | sudo dpkg -i mfc260ccupswrapper-1.0.1-1.i386.deb |
| + | |
| + | Außerdem sollte der Benutzer in der Gruppe <code>lp</code> sein. |
| + | |
| + | Auf 64bit-Systemen müssen zusätzlich die Pakete ia32libs und libstdc++ installiert sein. |
| + | |
| + | == Scannen == |
| + | |
| + | === Scanner im Netzwerk === |
| + | |
| + | Siehe die Anleitung zum [http://wiki.ubuntuusers.de/SANE-Scanserver_im_Netzwerk Scannen im Netzwerk unter Ubuntu]. |
| + | |
| + | Zusätzlich muss noch in <code>/etc/default/saned</code> der Start von Saned eingestellt werden: |
| + | |
| + | RUN=yes |
| + | |
| + | |
| + | === Scannen und OCR === |
| + | |
| + | Mit Hilfe von scanimage und tesseract lassen sich auch PDFs mit per OCR erkanntem (überlagerndem) Text erstellen. |
| + | |
| + | Das Projekt [https://openpaper.work/de/ Paperwork] bietet auf dieser Basis eine Volltextsuche über sämtliche gescannten Dokumente. Die Installation hat bei mir gut über [[AppImage]] funktioniert. Siehe die [https://openpaper.work/de/download/linux#appimage Anleitung auf der Projekt-Seite]. |
| + | |
| + | === Einzelne Scanner === |
| + | |
| + | ==== Scanner '''Mustek 1200 UB Plus''' ==== |
| + | |
| + | Für den Scanner '''Mustek 1200 UB Plus''' ist neben einer SANE-Installation einschließlich des [http://www.meier-geinitz.de/sane/gt68xx-backend/index.html gt68xx-Backends] (bei OpenSuse 10.3 automatisch) noch Folgendes zu tun: |
| + | * Verzeichnis für Firmware anlegen |
| + | sudo mkdir -p /usr/share/sane/gt68xx |
| + | * Die Firmware-Datei [http://www.meier-geinitz.de/sane/gt68xx-backend/firmware/sbfw.usb sbfw.usb] herunterladen und im Verzeichnis <code>/usr/share/sane/gt68xx</code> speichern sowie |
| + | * Von der bisher in der Datei <code>/etc/sane.d/gt68xx.conf</code> enthaltene Zeile |
| + | #override "mustek-scanexpress-1200-ub-plus" |
| + | das führende Kommentarzeichen (#) entfernen. <small>Ansonsten wird der Scanner fälschlicherweise als Mustek BearPaw 1200 CU erkannt.</small> |
| + | * Das erkannte Scanner-Modell kann man sich ausgeben lassen: |
| + | scanimage -L |
| + | * Mit der Anwendung <code>xsane</code> kann man dann scannen. |
| + | |
| + | ==== Brother MFC 260C ==== |
| + | |
| + | Das Multifunktionsgerät Brother MFC 260 C lässt sich [http://ubuntuforums.org/showthread.php?t=590793 sowohl als Scanner als auch als Drucker] unter Linux einrichten. Dazu ist der Treiber brscan2 von [http://welcome.solutions.brother.com/bsc/public_s/id/linux/en/download_scn.html Brother herunterzuladen]. |
| + | |
| + | Für neuere Ubuntu / Linux Mint 64 bit -Versionen müssen symbolische Links angelegt werden:<ref>Vgl. https://wiki.ubuntuusers.de/Scanner/Brother/#Scanner-Treiber-ab-Bionic-Beaver-18-04-64-Bit</ref> |
| + | |
| + | sudo ln -sf /usr/lib64/sane/libsane-brother* /usr/lib/x86_64-linux-gnu/sane |
| + | sudo ln -sf /usr/lib64/libbrcolm* /usr/lib/x86_64-linux-gnu |
| + | sudo ln -sf /usr/lib64/libbrscandec* /usr/lib/x86_64-linux-gnu |
| + | |
| + | |
| + | Bei manchen Rechnern funktionieren die Treiber für den Brother MFC-260C nicht mit USB 3.0. Dann muss USB 3.0 im BIOS deaktiviert werden, so dass die Ports als USB 2.0-Ports genutzt werden können. |
| | | |
− | Bei der Installation des Brother MFC-260C unter Linux Mint 17 32bit bedarf es folgender Schritte nach dem Download der DEB-Files vom [http://support.brother.com/g/s/id/linux/en/instruction_prn1a.html?c=us_ot&lang=en&redirect=on Brother Solutions Center]:
| + | === Scannen in verschiedenen Distributionen === |
| + | ==== OpenSuse ==== |
| + | * Mit dem Scanner-Modul von yast kann man die korrekte Installation testen. |
| | | |
− | sudo mkdir /var/spool/lpd
| + | ==== Debian ==== |
− | sudo chgrp lp /var/spool/lpd
| + | * Unter [[Debian]] |
− | sudo dpkg -i mfc260clpr-1.0.1-1.i386.deb
| + | ** ist neben der Installation von <code>xsane</code> auch die Installation von <code>sane-utils</code> erforderlich. |
− | sudo dpkg -i mfc260ccupswrapper-1.0.1-1.i386.deb
| + | ** Außerdem muss der jeweilige Benutzer Mitglied der Gruppe <code>scanner</code> oder aber der Gruppe <code>lp</code><ref>Vgl. https://www.linuxquestions.org/questions/slackware-14/sane-and-usb-permission-4175421150/</ref> sein. |
| | | |
− | == Scannen == | + | ==== Ubuntu ==== |
| + | '''Achtung wohl veraltet''' |
| + | * Unter [[Ubuntu]] benötigt man jedenfalls in 9.10 Karmic Koala folgende Zeile in <code>/etc/fstab</code>: |
| + | none /proc/bus/usb usbfs auto 0 0 |
| | | |
− | === Scanner im Netzwerk === | + | Evtl. funktioniert auch |
| + | none /proc/bus/usb usbfs auto,devmode=0666 0 0 |
| | | |
− | Siehe die Anleitung zum [http://wiki.ubuntuusers.de/SANE-Scanserver_im_Netzwerk Scannen im Netzwerk unter Ubuntu].
| |
| | | |
− | Zusätzlich muss noch in <code>/etc/default/saned</code> der Start von Saned eingestellt werden:
| + | * Ob die Zeile funktioniert lässt sich mit mount testen: |
| + | sudo mount -a |
| | | |
− | RUN=yes | + | * Damit man auch als normaler User auf den Scanner zugreifen kann,<ref>http://www.ubuntu-forum.de/artikel/41977/scanner-wird-als-user-nicht-erkannt-nur-als-root.html</ref> kreiert man mit |
| + | sudo joe /etc/udev/rules.d/40-basic-permissions.rules |
| + | (oder irgendeinem anderen Editor) eine Datei mit folgendem Inhalt |
| + | # USB devices (usbfs replacement) |
| + | SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", MODE="0666" |
| + | SUBSYSTEM=="usb_device", MODE="0666" |
| + | |
| + | Anschließend muss man das udev-System neustarten: |
| + | sudo restart udev |
| + | |
| + | Hinweis: Auf [http://wiki.ubuntuusers.de/Scanner#USB ubuntuusers.de] findet sich eine davon leicht abweichende Möglichkeit für das Scannen als normaler User. |
| + | Hinweis 2: Für Ubuntu 9.10 muss man es wohl inzwischen [http://forum.ubuntuusers.de/topic/probleme-mit-scanner-seit-karmic-9-10/ anders machen]. |
| | | |
| + | == Energiemanagement == |
| | | |
− | === Scannen und OCR === | + | === Akku === |
| + | Mit <code>upower</code> kann man sich den Stand des Akkus anzeigen lassen.<ref>Siehe http://askubuntu.com/questions/69556/how-to-check-battery-status-using-terminal .</ref> |
| + | |
| + | upower -i /org/freedesktop/UPower/devices/battery_BAT0 |
| + | |
| + | Den Pfad für das oben angegebene Kommando findet man durch |
| + | upower -e |
| + | |
| + | Eine komplette Übersicht erhält man mit |
| + | upower --dump |
| | | |
− | Mit Hilfe von scanimage und tesseract lassen sich auch PDFs mit per OCR erkanntem (überlagerndem) Text erstellen.
| + | === Festplatte im Leerlauf ausschalten === |
| | | |
− | === Einzelne Scanner ===
| + | Siehe |
| + | * https://www.foxplex.com/sites/festplatten-standby-im-leerlauf-mit-hdparm-und-hd-idle/ |
| | | |
− | ==== Scanner '''Mustek 1200 UB Plus''' ==== | + | === Energieverbrauch minimieren === |
| + | Zur Ermittlung der Verbraucher helfen |
| + | * [http://manpages.ubuntu.com/manpages/focal/man8/powerstat.8.html powerstat] |
| + | * [https://01.org/sites/default/files/page/powertop_users_guide_201412.pdf powertop] |
| + | ** https://wiki.ubuntuusers.de/PowerTOP/ |
| + | ** https://www.admin-magazin.de/Das-Heft/2011/02/Energiefresser-unter-Linux-mit-PowerTOP-enttarnen/(offset)/2 |
| | | |
− | Für den Scanner '''Mustek 1200 UB Plus''' ist neben einer SANE-Installation einschließlich des [http://www.meier-geinitz.de/sane/gt68xx-backend/index.html gt68xx-Backends] (bei OpenSuse 10.3 automatisch) noch Folgendes zu tun:
| + | Siehe |
− | * Verzeichnis für Firmware anlegen | + | * http://www.thinkwiki.org/wiki/How_to_reduce_power_consumption |
− | sudo mkdir -p /usr/share/sane/gt68xx
| + | * https://metebalci.com/blog/a-minimum-complete-tutorial-of-cpu-power-management-c-states-and-p-states/ |
− | * Die Firmware-Datei [http://www.meier-geinitz.de/sane/gt68xx-backend/firmware/sbfw.usb sbfw.usb] herunterladen und im Verzeichnis <code>/usr/share/sane/gt68xx</code> speichern sowie
| |
− | * Von der bisher in der Datei <code>/etc/sane.d/gt68xx.conf</code> enthaltene Zeile
| |
− | #override "mustek-scanexpress-1200-ub-plus"
| |
− | das führende Kommentarzeichen (#) entfernen. <small>Ansonsten wird der Scanner fälschlicherweise als Mustek BearPaw 1200 CU erkannt.</small>
| |
− | * Das erkannte Scanner-Modell kann man sich ausgeben lassen:
| |
− | scanimage -L
| |
− | * Mit der Anwendung <code>xsane</code> kann man dann scannen.
| |
| | | |
− | ==== Brother MFC 260C ==== | + | == Verbindung mit Handy/PDA == |
| | | |
− | Das Multifunktionsgerät Brother MFC 260 C lässt sich [http://ubuntuforums.org/showthread.php?t=590793 sowohl als Scanner als auch als Drucker] unter Linux einrichten. Dazu ist der Treiber brscan2 von [http://welcome.solutions.brother.com/bsc/public_s/id/linux/en/download_scn.html Brother herunterzuladen].
| + | * [[Synchronisation Web-PC-Handy]] |
| + | ** [[Sony Ericsson K800i]] |
| + | *** [[Sony Ericsson K800i über Bluetooth an Linux-PC]] |
| + | * [[Synchronisation unter Linux]] |
| | | |
− | === Scannen in verschiedenen Distributionen === | + | == Weitere Anwendungen == |
− | ==== OpenSuse ====
| |
− | * Mit dem Scanner-Modul von yast kann man die korrekte Installation testen.
| |
| | | |
− | ==== Debian ==== | + | === Editoren === |
− | * Unter [[Debian]]
| |
− | ** ist neben der Installation von <code>xsane</code> auch die Installation von <code>sane-utils</code> erforderlich.
| |
− | ** Außerdem muss der jeweilige Benutzer Mitglied der Gruppe <code>scanner</code> sein.
| |
| | | |
− | ==== Ubuntu ==== | + | ==== Grafische Editoren und Entwicklungsumgebungen ==== |
− | '''Achtung wohl veraltet'''
| |
− | * Unter [[Ubuntu]] benötigt man jedenfalls in 9.10 Karmic Koala folgende Zeile in <code>/etc/fstab</code>:
| |
− | none /proc/bus/usb usbfs auto 0 0
| |
| | | |
− | Evtl. funktioniert auch
| + | * Geany |
− | none /proc/bus/usb usbfs auto,devmode=0666 0 0
| + | * [[Netbeans]] |
| + | * [[Eclipse]] |
| | | |
| + | ==== Editoren fürs Terminalfenster ==== |
| | | |
− | * Ob die Zeile funktioniert lässt sich mit mount testen: | + | * [[vim]] |
− | sudo mount -a
| + | * nano |
− | | + | * joe - Benutzerführung wie MS WordStar (etwas antiquiert) |
− | * Damit man auch als normaler User auf den Scanner zugreifen kann,<ref>http://www.ubuntu-forum.de/artikel/41977/scanner-wird-als-user-nicht-erkannt-nur-als-root.html</ref> kreiert man mit
| + | * emacs |
− | sudo joe /etc/udev/rules.d/40-basic-permissions.rules
| |
− | (oder irgendeinem anderen Editor) eine Datei mit folgendem Inhalt
| |
− | # USB devices (usbfs replacement)
| |
− | SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", MODE="0666"
| |
− | SUBSYSTEM=="usb_device", MODE="0666"
| |
− | | |
− | Anschließend muss man das udev-System neustarten:
| |
− | sudo restart udev
| |
− | | |
− | Hinweis: Auf [http://wiki.ubuntuusers.de/Scanner#USB ubuntuusers.de] findet sich eine davon leicht abweichende Möglichkeit für das Scannen als normaler User.
| |
− | Hinweis 2: Für Ubuntu 9.10 muss man es wohl inzwischen [http://forum.ubuntuusers.de/topic/probleme-mit-scanner-seit-karmic-9-10/ anders machen].
| |
− | | |
− | == Energiemanagement ==
| |
− | | |
− | Mit <code>upower</code> kann man sich den Stand des Akkus anzeigen lassen.<ref>Siehe http://askubuntu.com/questions/69556/how-to-check-battery-status-using-terminal .</ref>
| |
− |
| |
− | upower -i /org/freedesktop/UPower/devices/battery_BAT0
| |
− | | |
− | Den Pfad für das oben angegebene Kommando findet man durch
| |
− | upower -e
| |
− | | |
− | == Verbindung mit Handy/PDA ==
| |
− | | |
− | * [[Synchronisation Web-PC-Handy]]
| |
− | ** [[Sony Ericsson K800i]] | |
− | *** [[Sony Ericsson K800i über Bluetooth an Linux-PC]] | |
− | * [[Synchronisation unter Linux]] | |
| | | |
− | == Weitere Anwendungen == | + | === Textverarbeitung === |
| | | |
| + | Die Standard-Textverarbeitung unter Linux ist derzeit [[LibreOffice]] Writer. |
| | | |
| === Plattformübergreifende Software === | | === Plattformübergreifende Software === |
Zeile 1.406: |
Zeile 2.193: |
| * [http://sourceforge.net/apps/mediawiki/free-cad/index.php?title=Main_Page FreeCAD] ([[OpenSource]]) | | * [http://sourceforge.net/apps/mediawiki/free-cad/index.php?title=Main_Page FreeCAD] ([[OpenSource]]) |
| ** [http://sourceforge.net/apps/mediawiki/free-cad/index.php?title=Draft_tutorial Einstiegstutorial] | | ** [http://sourceforge.net/apps/mediawiki/free-cad/index.php?title=Draft_tutorial Einstiegstutorial] |
− | | + | * [[OpenSCAD]] - a simple CAD application based on scripts |
| | | |
| === Business Software === | | === Business Software === |
| | | |
| * [http://www.linux-community.de/Internal/Artikel/Online-Artikel/Versuch-einer-Entscheidungshilfe-fuer-die-richtige-Linux-Unternehmenssoftware Überblick über Linux-Business-Software] | | * [http://www.linux-community.de/Internal/Artikel/Online-Artikel/Versuch-einer-Entscheidungshilfe-fuer-die-richtige-Linux-Unternehmenssoftware Überblick über Linux-Business-Software] |
| + | |
| * Ein weiteres [[DMS]] ist [http://www.archivista.ch/de/pages/support/installation.php Archivista] | | * Ein weiteres [[DMS]] ist [http://www.archivista.ch/de/pages/support/installation.php Archivista] |
| + | |
| + | Siehe auch |
| + | * [[Informationstechnik#Dokumentenmanagementsystem]] |
| | | |
| === Groupware-Server === | | === Groupware-Server === |