Zeile 1: |
Zeile 1: |
− | Siehe [[oldCt:Linux-Tipps]]
| + | |
| | | |
| == Linux und andere Betriebssysteme == | | == Linux und andere Betriebssysteme == |
Zeile 54: |
Zeile 54: |
| | | |
| * [http://www.radiotux.de/ RadioTux] liefert PodCasts rund um Linux. | | * [http://www.radiotux.de/ RadioTux] liefert PodCasts rund um Linux. |
| + | |
| + | * [http://www.guug.de/uptimes/index.html Uptimes] - Mitgliederzeitschrift der German Unix User Group |
| | | |
| == Distributionen == | | == Distributionen == |
Zeile 87: |
Zeile 89: |
| ** Auf [[Ubuntu]] baut die Netbook-Distribution [http://www.geteasypeasy.com/ Easy Peasy] auf. | | ** Auf [[Ubuntu]] baut die Netbook-Distribution [http://www.geteasypeasy.com/ Easy Peasy] auf. |
| ** Ebenfalls auf [[Ubuntu]] basiert die normale Version von [[Linux Mint]]. | | ** Ebenfalls auf [[Ubuntu]] basiert die normale Version von [[Linux Mint]]. |
| + | |
| + | === 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. |
| + | |
| + | |
| + | === 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 138: |
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 === |
| + | Siehe [[Audio#Linux und Audio]] |
| | | |
− | Zum Einrichten des Sounds hilft | + | <small>Zum Einrichten des Sounds hilft |
| alsaconf | | alsaconf |
| + | </small> |
| | | |
| === (De-)Installation von Programmen aus dem Quelltext === | | === (De-)Installation von Programmen aus dem Quelltext === |
Zeile 193: |
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 208: |
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 217: |
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 248: |
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 284: |
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 296: |
Zeile 335: |
| * [http://wiki.ubuntuusers.de/booten Kernel-Parameter (Auswahl auf ubuntuusers)] | | * [http://wiki.ubuntuusers.de/booten Kernel-Parameter (Auswahl auf ubuntuusers)] |
| * [http://www.cyberciti.biz/tips/10-boot-time-parameters-you-should-know-about-the-linux-kernel.html Kernel-Parameter(Auswahl)] | | * [http://www.cyberciti.biz/tips/10-boot-time-parameters-you-should-know-about-the-linux-kernel.html Kernel-Parameter(Auswahl)] |
| + | * [https://wiki.archlinux.org/index.php/kernel_modules Laden und Nicht-Laden von Kernel-Modulen] unter [[ArchLinux]] |
| + | |
| * Achtung der Kernel-Parameter <code>root=</code> kann sich ändern. Passte bei einer früheren Version noch <code>/dev/hda1</code> als Argument, kann es jetzt <code>/dev/sda1</code> sein. | | * Achtung der Kernel-Parameter <code>root=</code> kann sich ändern. Passte bei einer früheren Version noch <code>/dev/hda1</code> als Argument, kann es jetzt <code>/dev/sda1</code> sein. |
| | | |
Zeile 321: |
Zeile 362: |
| Systemd scheint nach der Entscheidung von [[Debian]] zur Umstellung auf Systemd das alte *NIX-Init-System abzulösen. | | Systemd scheint nach der Entscheidung von [[Debian]] zur Umstellung auf Systemd das alte *NIX-Init-System abzulösen. |
| * https://wiki.archlinux.org/index.php/Systemd_FAQ | | * https://wiki.archlinux.org/index.php/Systemd_FAQ |
| + | * [http://www.heise.de/open/artikel/Das-Init-System-Systemd-Teil-2-1563461.html Heise-Artikel zur Benutzung von systemctl] |
| | | |
| ==== Standard-Ziel ==== | | ==== Standard-Ziel ==== |
Zeile 339: |
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 352: |
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 == |
| | | |
| === Troubleshooting Tastatur === | | === Troubleshooting Tastatur === |
| + | |
| + | ==== Linux Mint 17.1 Rebecca ==== |
| + | |
| + | Siehe zunächst das Vorgehen bei [[Linux-Tipps#Debian 8.0 Jessie]] |
| + | |
| + | Bei mir hat allerdings die Einstellungen für cups, in der blacklist und der Kernel-Parameter <code>atkbd.reset</code> nicht geholfen. Mittels <code>aptitude</code> habe ich dann das System auf den aktuellen Stand gebracht (im Recovery-Modus). Außerdem habe ich den <code>openssh-server</code> installiert, um auch bei normalem Start von einem Zweitrechner auf die Mint-Installation zugreifen zu können. Die Module lp, ppdev, parport_pc und parport habe ich sowohl in GRUB (z.B. lp.blacklist=yes) als auch in <code>/etc/modprobe.d/uebeltaeter.conf</code> ausgeschlossen. |
| + | |
| + | Das Laden der Module lp, parport und parport_pc in <code>/etc/modules-load.d/cups-filters.conf</code> wird durch Auskommentieren (Raute '#' am Anfang der Zeile) unterbunden. |
| + | |
| + | Eventuell hilft auch das ausdrückliche Laden von <code>atkbd</code> mittels der Kernel-Parameter <code>earlymodules=atkbd modules-load=atkbd</code>.<ref> https://www.archlinux.org/news/linux-313-warning-ps2-keyboard-support-is-now-modular/</ref> |
| + | |
| + | Der Recovery-Modus einer Linux-Mint-Installation ist meist ein guter Weg, um die notwendigen Änderungen vorzunehmen. |
| + | |
| + | ==== Ubuntu 14.04.2 ==== |
| + | In <code>/etc/modules-load.d/cups-filter.conf</code> sind die Module lp, ppdev und parport_pc auszukommentieren. |
| | | |
| ==== Debian 8.0 Jessie ==== | | ==== Debian 8.0 Jessie ==== |
Zeile 369: |
Zeile 441: |
| aptitude remove cups-server-common | | aptitude remove cups-server-common |
| | | |
− | Der eigentliche Übeltäter ist jedoch das Modul <code>parport_pc</code><ref>Siehe http://www.aptosidusers.de/index.php?name=PNphpBB2&file=viewtopic&p=12101</ref>, das CUPS für Drucker am Parallelport lädt. Dies lässt sich durch Erstellung folgender <code>/etc/modprobe.d/uebeltaeter.conf</code> beheben: | + | Der eigentliche Übeltäter ist jedoch das Modul <code>parport_pc</code><ref>Siehe http://www.aptosidusers.de/index.php?name=PNphpBB2&file=viewtopic&p=12101</ref>, das CUPS für Drucker am Parallelport lädt. Dies lässt sich durch Erstellung folgender <code>/etc/modprobe.d/blacklist-uebeltaeter.conf</code> beheben: |
| | | |
| #Ermoeglicht wieder die PS_2 Tastatur zu nutzen: | | #Ermoeglicht wieder die PS_2 Tastatur zu nutzen: |
Zeile 426: |
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 == |
| + | |
| + | Einen USB-RS232-Adapter kann man auch an einen Linux-PC anschließen.<ref>Siehe https://blog.mypapit.net/2008/05/how-to-use-usb-serial-port-converter-in-ubuntu.html, http://www.linux-usb.org/USB-guide/x356.html</ref> |
| + | |
| + | Allerdings muss man dazu [https://blog.mypapit.net/2008/05/how-to-use-usb-serial-port-converter-in-ubuntu.html entsprechende Kernel-Module laden]. |
| + | |
| + | Die RS232-Schnittstelle lässt sich aus einem in [[C]] geschriebenen Programm mittels einer [http://www.teuniz.net/RS-232/ recht neuen Open Source Bibliothek] ansprechen. |
| + | |
| + | == Infrarot-Schnittstelle == |
| + | |
| + | === IrDA === |
| + | Datenübertragung per Infrarot geht nach dem IrDA-Standard. Dazu gibt es unter Linux beispielsweise die irda-utils. |
| + | |
| + | === 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.<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 |
| + | ir-keytable |
| + | können die installierten IR-Receiver angezeigt werden. Eingabegeräte ganz allgemein lassen sich auch mit |
| + | cat /proc/bus/input/devices |
| + | anzeigen. |
| + | |
| + | 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 |
| + | |
| + | Zunächst gibt man beim Testen alle unterstützten Protokolle an: |
| + | ir-keytable -p jvc,rc-5,rc-6,other -t |
| + | |
| + | 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 |
| + | |
| + | Hier mal meine Beispiel-Tabelle <code>/etc/rc_keymaps/meine_tt</code> für die Nutzung einer alten Technotrend-Fernbedienung für [[Kodi]]: |
| + | <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> |
| + | |
| + | Mit |
| + | ir-keytable --read |
| + | kann man sich die eingelesenen Keycodes anzeigen lassen. |
| + | |
| + | Hier ist mit dem reinen Kernel-Treiber Schluss. |
| + | |
| + | 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. |
| + | |
| + | |
| + | Für die /etc/lirc/lircd.conf greift man auf die devinput-Datei zurück: |
| + | sudo cp -av /usr/share/lirc/remotes/devinput/lircd.conf.devinput /etc/lirc/lircd.conf |
| + | |
| + | 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: |
| + | <remote device="/dev/input/event6"> |
| + | |
| + | |
| + | 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" |
| + | |
| + | 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. |
| + | |
| + | |
| + | 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. |
| + | |
| + | |
| + | |
| + | 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] |
| + | |
| + | ==== InputLirc ==== |
| + | |
| + | 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. |
| + | |
| + | Installation: |
| + | sudo aptitude install lirc lirc-x inputlirc |
| + | |
| + | |
| + | 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). |
| + | |
| + | [[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 --> |
| + | |
| + | <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> |
| + | |
| + | <!-- extensions --> |
| + | <back>KEY_EXIT</back> |
| + | </remote> |
| + | </lircmap |
| + | </pre> |
| + | Siehe |
| + | * http://www.pro-linux.de/artikel/2/1682/einstieg-in-lirc-mit-inputlirc.html |
| + | |
| + | ==== ir-keytable und Kodi ==== |
| + | |
| + | 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> |
| + | |
| + | |
| + | Diese schreibt man auf den Intel-IR-Receiver (hier: <code>rc0</code>) mit |
| + | sudo ir-keytable -c -w /etc/rc_keymaps/meine_tt -s rc0 |
| + | |
| + | 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 |
| + | |
| + | Kodi muss zur Wirksamkeit wohl neu gestartet werden. |
| + | |
| + | ==== IR Probleme ==== |
| + | |
| + | Zu Testzwecken hilft das Anzeigen einzelner Tastendrücke: |
| + | irw |
| + | |
| + | |
| + | 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> |
| + | |
| + | 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> |
| + | |
| + | Möglicherweise gibt es auf einem Debian Jessie ein LIRC zuviel und die Tasten werden ununterbrochen wiederholt. Dann hilft evtl.: |
| + | sudo service lircd-uinput stop |
| + | Den <code>lircd-uinput</code> - Service kann man auch dauerhaft deaktivieren: |
| + | sudo systemctl disable lircd-uinput |
| + | |
| + | ===== IR-Fernbedienung erzeugt doppelte Tastendrücke ===== |
| + | |
| + | 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 |
| + | |
| + | Dazu gibt es auch [https://bugs.launchpad.net/ubuntu/+source/linux/+bug/663651/comments/23 ein fertiges Skript]. |
| | | |
| == Prozessverwaltung == | | == Prozessverwaltung == |
Zeile 464: |
Zeile 847: |
| run-parts --test /etc/cron.daily | | run-parts --test /etc/cron.daily |
| ausführen. Es wird eine Liste derjenigen Skripte ausgegeben, die die Namenskonvention einhält. | | ausführen. Es wird eine Liste derjenigen Skripte ausgegeben, die die Namenskonvention einhält. |
| + | |
| + | |
| + | ==== Feststellen, ob Script von Cron gestartet wurde ==== |
| + | |
| + | Siehe https://stackoverflow.com/questions/33354864/how-to-check-if-linux-shell-script-is-executed-by-a-cronjob : |
| + | <pre> |
| + | |
| + | if [ -t 0 ]; then |
| + | echo "I'm on a TTY, this is interactive." |
| + | else |
| + | logger "My output may get emailed, or may not. Let's log things instead." |
| + | fi |
| + | </pre> |
| | | |
| == Benutzerverwaltung == | | == Benutzerverwaltung == |
Zeile 509: |
Zeile 905: |
| | | |
| * [ftp://ftp.freiesmagazin.de/2009/freiesMagazin-2009-05.pdf freiesmagazin.de Mai 2009] zeigt, wie man einen virtuellen Rechner mittels KVM am Heimrechner einrichtet. | | * [ftp://ftp.freiesmagazin.de/2009/freiesMagazin-2009-05.pdf freiesmagazin.de Mai 2009] zeigt, wie man einen virtuellen Rechner mittels KVM am Heimrechner einrichtet. |
| + | * Open VirtualBox (von Oracle) wird z.B. bei Ubuntu mitgeliefert. |
| | | |
| + | * [[Docker]] ist im Standardpaketumfang von [[Linux Mint]] enthalten. |
| + | |
| + | * LXC ist ebenfalls eine Container-Lösung |
| | | |
| == Shells == | | == Shells == |
Zeile 518: |
Zeile 918: |
| * [http://mywiki.wooledge.org/BashPitfalls Häufige Fehler bei der Bash-Programmierung] | | * [http://mywiki.wooledge.org/BashPitfalls Häufige Fehler bei der Bash-Programmierung] |
| * [http://linuxconfig.org/Bash_scripting_Tutorial Bash Tutorial] | | * [http://linuxconfig.org/Bash_scripting_Tutorial Bash Tutorial] |
| + | |
| + | === Tab-Completion === |
| + | |
| + | 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. |
| + | |
| + | Eine deutliche Erweiterung dieser Funktionalität auch für Optionen für verschiedene Kommandozeilentools bietet das Paket <code>bash-completion</code>: |
| + | sudo aptitude install bash-completion |
| + | |
| + | ==== Autovervollständigung für Rechnernamen ==== |
| + | 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>. |
| + | 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> |
| + | export HOSTFILE="/home/USER/myhostfile" |
| + | 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. |
| + | |
| + | |
| + | In der entsprechenden Datei (im Beispiel /home/USER/myhostfile) werden die Rechner Zeile für Zeile eingetragen: |
| + | fritz.box |
| + | pia2016.de |
| + | |
| + | === Gefrorene Shell === |
| + | |
| + | Mittels Strg-S kann man das Terminal anhalten (XOFF). Mittels Strg-Q geht es wieder weiter (XON). |
| | | |
| === Ablaufsteuerung === | | === Ablaufsteuerung === |
Zeile 556: |
Zeile 978: |
| | | |
| [http://www.mkssoftware.com/docs/man1/getopts.1.asp getopts], ein in der Bash enthaltenes Kommando, hilft Kommandozeilenoptionen zu 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 |
| | | |
| === Exit-Status === | | === Exit-Status === |
Zeile 583: |
Zeile 1.008: |
| set -e | | set -e |
| wird grundsätzlich das Script bei einem erfolglosen Befehl abgebrochen. | | wird grundsätzlich das Script bei einem erfolglosen Befehl abgebrochen. |
| + | |
| + | === Unit Tests === |
| + | |
| + | [https://github.com/pgrange/bash_unit Bash_unit] ist ein Paket zum Erstellen von Unit-Tests für Bash. |
| | | |
| === Verarbeiten von Textstreams === | | === Verarbeiten von Textstreams === |
| | | |
− | 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.
| |
− |
| |
− | * [http://www.easylinux.de/2005/09/084-umleitungen/ Einführung in Pipes]
| |
| * Sinnvolle Hilfen zum Verarbeiten von Textstreams/Auslesen von Dateien | | * Sinnvolle Hilfen zum Verarbeiten von Textstreams/Auslesen von Dateien |
| ** [[wc]] zählt Worte und Zeilen | | ** [[wc]] zählt Worte und Zeilen |
Zeile 596: |
Zeile 1.022: |
| ** [[printf]] ermöglicht wie in der Programmiersprache C das formatierte Ausgeben von Zahlen und Zeichen | | ** [[printf]] ermöglicht wie in der Programmiersprache C das formatierte Ausgeben von Zahlen und Zeichen |
| printf '%s mit führenden Nullen: %05d' Zahl 76 | | printf '%s mit führenden Nullen: %05d' Zahl 76 |
| + | |
| + | 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> |
| + | |
| + | ==== Piping ==== |
| + | |
| + | |
| + | 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. |
| + | Beispiel: |
| + | find / -name '*.mp3' 2> /dev/null |
| + | |
| + | * [http://www.easylinux.de/2005/09/084-umleitungen/ Einführung in Pipes] |
| + | |
| + | ==== heredoc ==== |
| + | |
| + | Man kann auch kleine Textschnipsel in ein Skript selbst schreiben und dann weiterleiten: |
| + | |
| + | cat <<EOF |
| + | Dies ist ein Text, der |
| + | an cat weitergegeben wird. |
| + | EOF |
| + | |
| + | Statt EOF kann in den so genannten "heredocs" auch irgendein anderes Wort |
| + | zur Bezeichnung des Endes des heredocs geschrieben werden. Es muss nur |
| + | das Gleiche am Anfang und am Ende sein. |
| | | |
| ==== sed ==== | | ==== sed ==== |
Zeile 602: |
Zeile 1.054: |
| In der neuen Playlist | | In der neuen Playlist |
| * ist der Pfadanfang geändert von ../Musik/Musik nach dhMusic und | | * ist der Pfadanfang geändert von ../Musik/Musik nach dhMusic und |
− | * sind die Trackziffern inklusive dies Leerzeichens weggelassen. | + | * 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. |
| + | * 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. | | Mit dem Modifizierer <code>-i</code> (oder <code>--in-place</code>) kann eine Datei geändert werden, die zugleich als Eingabestream fungiert. |
Zeile 654: |
Zeile 1.115: |
| | | |
| 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]. | | 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]. |
| + | |
| + | ==== Terminalfenstertitel ==== |
| + | |
| + | 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! |
| + | |
| + | 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: |
| + | PS1="\u@\h:\w\$ " |
| + | |
| + | Siehe |
| + | * http://askubuntu.com/questions/22413/how-to-change-gnome-terminal-title |
| + | |
| + | ==== Interaktion der Shell mit Maus ==== |
| + | |
| + | Siehe |
| + | * 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 |
| | | |
| == Dateiverwaltung == | | == Dateiverwaltung == |
| | | |
| === Dateisuche === | | === Dateisuche === |
| + | |
| + | ==== Suchen auch in Unterordnern ==== |
| Ein rekursives MS-DOS-<code>dir</code> lässt sich mit dem Befehl find erreichen: | | Ein rekursives MS-DOS-<code>dir</code> lässt sich mit dem Befehl find erreichen: |
| | | |
Zeile 663: |
Zeile 1.147: |
| | | |
| 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. | | 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. |
| + | |
| + | ==== Suchen nach Dateinamen und Wörtern im Dateiinhalt ==== |
| + | |
| + | 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: |
| + | |
| + | find . -name package.json -print0 | xargs -0 grep mylib |
| + | |
| + | Dieser Befehl sucht im aktuellen Verzeichnis und dessen Unterverzeichnissen nach Dateien mit dem Namen package.json. In diesen sucht es nach der Zeichenfolge "mylib". |
| | | |
| === Berechtigungen === | | === 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. | | * '''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. |
− | * 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] | + | * 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 |
| + | |
| + | Mit |
| + | namei -om PATH |
| + | können die einzelnen Berechtigungen eines Pfades PATH angezeigt werden. |
| + | |
| + | ==== SUID ==== |
| + | Mit Setzen des SUID-Bits für ein binäres Programm (also keinem Shell-Skript) mit |
| + | 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. |
| + | |
| + | ==== SGID ==== |
| + | Mit Setzen des SGID-Bits für ein Verzeichnis erben neu angelegte Dokumente/Verzeichnisse in diesem Verzeichnis dessen Gruppe als Gruppenzugehörigkeit. |
| + | |
| + | ==== umask ==== |
| + | |
| + | 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). |
| + | |
| + | 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 |
| | | |
| === Speicherplatz === | | === Speicherplatz === |
Zeile 672: |
Zeile 1.184: |
| df -h | | df -h |
| * Den vom aktuellen Verzeichnis und seinen Unterverzeichnis '''belegten Platz''' erfährt man durch | | * Den vom aktuellen Verzeichnis und seinen Unterverzeichnis '''belegten Platz''' erfährt man durch |
− | du --human-readable --summarize | + | 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' |
| | | |
| === Mounten === | | === Mounten === |
Zeile 710: |
Zeile 1.224: |
| sudo ntfsfix /dev/sdb1 | | 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> | | 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> |
| + | |
| + | ==== USB-Datenträger unter Systemd ==== |
| + | |
| + | 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> |
| + | |
| + | 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> |
| + | |
| + | Siehe |
| + | * http://www.wrigley.me.uk/wp/2012/12/03/automounting-usb-disk-on-boot-with-systemd-in-fedora/ |
| + | * https://bbs.archlinux.org/viewtopic.php?id=147478 |
| | | |
| ==== Mounten eines CD-Images ==== | | ==== Mounten eines CD-Images ==== |
Zeile 721: |
Zeile 1.245: |
| | | |
| aushängen | | aushängen |
− |
| |
− |
| |
| | | |
| ==== Mounten eines FTP-Verzeichnisses ==== | | ==== Mounten eines FTP-Verzeichnisses ==== |
Zeile 749: |
Zeile 1.271: |
| 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): | | 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.mediencenter.t-online.de/ /home/USER/t-online davfs noauto,user,rw 0 0 | + | https://webdav.magentacloud.de/ /home/USER/t-online davfs noauto,user,rw 0 0 |
| | | |
| Zusätzlich muss der Mountpunkt noch angelegt werden: | | Zusätzlich muss der Mountpunkt noch angelegt werden: |
Zeile 769: |
Zeile 1.291: |
| Dann kann das WebDAV-Verzeichnis gemountet werden: | | Dann kann das WebDAV-Verzeichnis gemountet werden: |
| mount /home/USER/t-online | | mount /home/USER/t-online |
| + | |
| + | 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> |
| | | |
| | | |
Zeile 803: |
Zeile 1.327: |
| 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: | | 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: |
| sudo mount -t overlayfs -o lowerdir=lower,upperdir=upper overlayfs together | | sudo mount -t overlayfs -o lowerdir=lower,upperdir=upper overlayfs together |
− | Ist <code>upper</upper> beim Einhängen leer, sieht man alle Änderungen im Verzeichnis <code>together</code> in <code>upper</code>. <code>lower</code> ändert sich nicht. | + | 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 | | Siehe |
Zeile 812: |
Zeile 1.336: |
| Ähnliche Funktionalität wie OverlayFS scheint '''Ovl.o''' zu bringen: | | Ähnliche Funktionalität wie OverlayFS scheint '''Ovl.o''' zu bringen: |
| * [http://home.comcast.net/~artn/ovlfs/ovl.man.txt Manpage für ovl.o] | | * [http://home.comcast.net/~artn/ovlfs/ovl.man.txt Manpage für ovl.o] |
| + | |
| + | ==== Mounten eines iPhone-Dateisystems ==== |
| + | |
| + | 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>: |
| + | sudo aptitude install ifuse |
| + | |
| + | |
| + | ==== weitere Infoquelle für mount ==== |
| + | |
| + | Siehe |
| + | * [http://pclosmag.com/html/issues/200709/page07.html Beschreibung von Mount-Optionen]. |
| + | |
| + | === Kopieren einer Audio-CD === |
| + | |
| + | Angeblich funktioniert [[dd]] nicht mit Audio-CDs. |
| + | |
| + | Das einfachste Kommando zum Kopieren einer CD ist<ref>Siehe http://www.togaware.com/linux/survivor/Duplicate_Audio.html</ref> |
| + | cdrdao copy |
| + | |
| + | 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>: |
| + | |
| + | 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 |
| + | |
| + | Falls man beim Lesen Probleme bekommt und cdrdao an einer bestimmten Stelle hängen bleibt, sollte man den Paranoia-Mode reduzieren: |
| + | cdrdao read-cd --device /dev/cdrom ''--paranoia-mode 0'' --read-raw --datafile INHALT.bin VERZEICHNIS.toc |
| | | |
| === Backup === | | === Backup === |
Zeile 824: |
Zeile 1.374: |
| | | |
| Open-Source Backup Produkte: | | 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://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.amanda.org/ Amanda] |
Zeile 832: |
Zeile 1.385: |
| [http://linuxwiki.de/rsync/SnapshotBackups Umfangreiche Anleitung zu inkrementellem Backup] mit Hilfe von <code>rsync</code> | | [http://linuxwiki.de/rsync/SnapshotBackups Umfangreiche Anleitung zu inkrementellem Backup] mit Hilfe von <code>rsync</code> |
| | | |
− | * Andere Hilfsmittel: <code>unison</code> | + | * Andere Hilfsmittel: <code>[[unison]]</code> |
| | | |
| * [[MediaWiki]]: [http://www.mediawiki.org/wiki/Manual:Backing_up_a_wiki Anleitung zum Backup eines MediaWiki-Systems] | | * [[MediaWiki]]: [http://www.mediawiki.org/wiki/Manual:Backing_up_a_wiki Anleitung zum Backup eines MediaWiki-Systems] |
| + | |
| + | ==== Backup mit Borg ==== |
| + | |
| + | ===== Backup ===== |
| + | Initialisiere Repository mit [https://borgbackup.readthedocs.io/en/stable/ Borg Backup] |
| + | |
| + | borg init --encrypt none <repoPath> |
| + | |
| + | |
| + | Erstelle Snapshot |
| + | borg create --stats --progress <repopath>::documents_$(date -I) $(realpath ~/documents) |
| + | |
| + | |
| + | Man kann auch einen Lauf starten, bei dem nichts verändert wird: |
| + | borg create --dry-run --list \ |
| + | --progress <repopath>::documents_$(date -I) $(realpath ~/documents) |
| + | |
| + | ===== Borg-Repo-Pfad ===== |
| + | |
| + | Auf dem lokalen Rechner ist <repopath> eine schlichte Pfadangabe wie <code>/mnt/externUSB/backup</code>. |
| + | |
| + | 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. |
| + | |
| + | ==== Backup mit Restic ==== |
| + | |
| + | Anlegen eines Backup-Repositorys mit [https://restic.readthedocs.io/en/stable/manual_rest.html restic]: |
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository init |
| + | |
| + | Eine Passwortdatei ist eine einfache Textdatei mit dem Passwort in einer Zeile. |
| + | |
| + | Anzeigen der vorhandenen Snapshots |
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository -p /pfad/zur/Passwortdatei snapshots |
| + | |
| + | Backup |
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository -p /pfad/zur/Passwortdatei backup /pfad/zu/den/zu/sichernden/dateien |
| + | |
| + | 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: |
| + | |
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository -p /pfad/zur/Passwortdatei backup $(readlink -f /pfad/zum/Symlink) |
| + | |
| + | restic hat [https://restic.readthedocs.io/en/stable/050_restore.html viele Möglichkeiten zum Wiederherstellen]. Beispiel: |
| + | |
| + | restic -r sftp:BACKUP_RECHNER:/pfad/zum/repository -p /pfad/zur/Passwortdatei restore latest \ |
| + | --target /pfad/wo/die/dateien/wiederhergestellt/werden/sollen --path "/pfad/der/wiederhergestellt/werden/soll" |
| + | |
| + | === Festplatten in Ruhezustand versetzen === |
| + | 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> |
| + | |
| + | Mittels |
| + | hdparm -S 30 /dev/sdc |
| + | lässt sich eine Festplatte nach 30*5=150 Sekunden in den Ruhezustand versetzen. |
| + | |
| + | Ü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]. |
| + | |
| + | === Festplattenfehler === |
| + | |
| + | Festplattenfehler lassen sich u.a. mit |
| + | * smartmontools |
| + | * badblocks |
| + | * e2fsck |
| + | * dd_rescue |
| + | * debugfs |
| + | finden. |
| + | |
| + | Z.B. kann man ein fehlerhaftes EXT2/EXT3/EXT4-Dateisystem mit folgendem Befehl (interaktiv) reparieren lassen: |
| + | sudo e2fsck /dev/sda5 |
| + | |
| + | Siehe |
| + | * https://recoverit.wondershare.de/harddrive-tips/repair-linux-disk.html |
| + | * http://www.technologyblog.de/2014/06/defekte-sektoren-reparieren-unter-linux-mit-badblocks/ |
| + | * http://www.linux-community.de/Internal/Artikel/Print-Artikel/LinuxUser/2010/08/Integritaet-gespeicherter-Daten-sicherstellen |
| | | |
| === Verschlüsselung === | | === Verschlüsselung === |
Zeile 870: |
Zeile 1.501: |
| | | |
| == Netzwerk == | | == Netzwerk == |
− | Siehe [[oldCt:Linux-Tipps#Netzwerk]] | + | * Siehe [[Netzwerk]] |
| * Siehe [[Samba]] | | * Siehe [[Samba]] |
| * Siehe zudem [[Installation von OpenSuse über PXE]] | | * Siehe zudem [[Installation von OpenSuse über PXE]] |
Zeile 878: |
Zeile 1.509: |
| | | |
| === Allgemeines === | | === Allgemeines === |
| + | |
| + | ==== Konfiguration in <code>/etc/network/interfaces</code> ==== |
| | | |
| 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. | | 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. |
| | | |
− | | + | ==== Konfiguration des Netzwerks mit systemd ==== |
| + | |
| + | Systemd kann alles, aber hält sich nicht an das KISS-Prinzip (Keep it simple stupid). So kann Systemd auch das Netzwerk konfigurieren. Siehe |
| + | * https://www.debian.org/doc/manuals/debian-reference/ch05.de.html#_the_modern_network_configuration_without_gui |
| + | |
| + | === Network-Manager === |
| + | In Desktop-Distributionen ist üblicherweise der "Network-Manager" installiert. Er lässt sich auch auf der Kommandozeile nutzen: |
| + | |
| + | 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 === | | === Fehlersuche === |
| | | |
Zeile 895: |
Zeile 1.557: |
| * Siehe | | * Siehe |
| ** [[Synchronisation unter Linux]], [[Synchronisation Web-PC-Handy]]. | | ** [[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 === |
Zeile 961: |
Zeile 1.653: |
| | | |
| === Mail === | | === Mail === |
| + | Siehe |
| * [[Mail unter Linux]] | | * [[Mail unter Linux]] |
| + | * [[Postfix]] |
| | | |
| === Fernzugriff === | | === Fernzugriff === |
Zeile 968: |
Zeile 1.662: |
| | | |
| == Grafiksystem == | | == 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 === | | === Framebuffer === |
| | | |
Zeile 973: |
Zeile 1.679: |
| | | |
| Siehe z.B. | | Siehe z.B. |
| + | * mplayer zum Anzeigen von Videos |
| * [http://hacklab.cz/2012/04/22/usefulness-linux-framebuffer-virtual-console fbi] zum Anzeigen von Bildern | | * [http://hacklab.cz/2012/04/22/usefulness-linux-framebuffer-virtual-console fbi] zum Anzeigen von Bildern |
| * fbtv zur Anzeige von Fernsehen | | * 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 === |
| * [[X Server]] | | * [[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 === | | === Window Manager === |
Zeile 989: |
Zeile 1.738: |
| * 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 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] | | ** [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 === | | === Grafische Fernsteuerung === |
Zeile 1.000: |
Zeile 1.764: |
| === Audio === | | === Audio === |
| | | |
− | Siehe auch [[Audio]] | + | Siehe auch [[Audio#Linux%20und%20Audio]] |
| | | |
| Siehe auch [[Videotelefonie]] | | Siehe auch [[Videotelefonie]] |
| | | |
| === Videos === | | === Videos === |
| + | |
| + | |
| + | Siehe auch [[Fotografie#Film_und_Video]] |
| | | |
| ==== Abspielen ==== | | ==== Abspielen ==== |
Zeile 1.025: |
Zeile 1.792: |
| * [[VDR]] | | * [[VDR]] |
| * [[MythTV]] | | * [[MythTV]] |
− | * [[XBMC]] | + | * [[XBMC]], nun [[Kodi]] |
| ** auch mit [http://linux.mjnet.eu/post/804/xbmc-pvr-tvheadend-ubuntu-12-04-install/ tvheadend] | | ** auch mit [http://linux.mjnet.eu/post/804/xbmc-pvr-tvheadend-ubuntu-12-04-install/ tvheadend] |
| | | |
Zeile 1.035: |
Zeile 1.802: |
| | | |
| * [http://sourceforge.net/projects/tvbrowser/ den TV-Browser], freie [[Java]]-Programmzeitschrift mit Aufzeichnungs-Plugin [[SimplePVR]] | | * [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 === | | === Webcam === |
Zeile 1.053: |
Zeile 1.831: |
| ==== Alternativen ==== | | ==== Alternativen ==== |
| Wer nur telefonieren will, findet [http://www.easylinux.de/Artikel/ausgabe/2006/06/026-skype/ freie Alternativen], die das [[SIP]]-Protokoll nutzen. | | 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 === | | === Digitalkameras unter Linux === |
Zeile 1.084: |
Zeile 1.875: |
| * [[pixelize]] - ein Programm, mit dem man ein größeres Bild aus unzähligen kleineren Bildern zusammensetzen kann | | * [[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] |
| | | |
− | Auf der Kommandozeile unter Linux helfen die Tools von ImageMagik:
| + | Beispielsweise lassen sich mit folgendem Befehl Bilder als Kacheln auf einem neuen Bild getrennt mit einem transparenten Rahmen darstellen: |
− | * [http://www.linux-community.de/Internal/Artikel/Print-Artikel/LinuxUser/2012/08/Bildbearbeitung-mit-ImageMagick Anleitung auf LINUX-Community]
| + | |
| + | montage -monitor -resize x200+0+0 -crop 300x200+20+0 -geometry 200x200+50+50 -background transparent bilder*.jpg uebersicht.png |
| | | |
| === Bildinformationen === | | === Bildinformationen === |
Zeile 1.095: |
Zeile 1.890: |
| Auch [[exiftags]] und [[exif]] bieten die Informationen aus dem EXIF-Teil des JPEG-Bilds über die Kommandozeile an. | | Auch [[exiftags]] und [[exif]] bieten die Informationen aus dem EXIF-Teil des JPEG-Bilds über die Kommandozeile an. |
| | | |
− | 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]: | + | ==== 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 | | 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. | | Das macht aus der Datei p104711.jpg z.B. hm2007,11,12-110048.p104711.jpg. |
Zeile 1.110: |
Zeile 1.906: |
| fi | | fi |
| done | | 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 == | | == Fernzugriff == |
Zeile 1.127: |
Zeile 1.932: |
| | | |
| Von der Shell kann man einen Netzwerkdrucker folgendermaßen zum Client hinzufügen: | | Von der Shell kann man einen Netzwerkdrucker folgendermaßen zum Client hinzufügen: |
− | lpadmin -p printer -E -v ipp://server/printers/printer | + | 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. | + | 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 | | Siehe auch |
| + | * [http://localhost:631/help/options.html CUPS-Hilfe zu Kommandozeilenbefehlen auf eigenem Rechner] |
| * [[Drucken]] allgemein | | * [[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-Drucker === |
Zeile 1.142: |
Zeile 2.015: |
| hp-setup -i | | hp-setup -i |
| und wählt 2 für <code>net</code> aus. | | 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 === | | === Brother === |
Zeile 1.153: |
Zeile 2.041: |
| sudo dpkg -i mfc260clpr-1.0.1-1.i386.deb | | sudo dpkg -i mfc260clpr-1.0.1-1.i386.deb |
| sudo dpkg -i mfc260ccupswrapper-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 == | | == Scannen == |
Zeile 1.163: |
Zeile 2.055: |
| | | |
| RUN=yes | | 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 === | | === Einzelne Scanner === |
Zeile 1.182: |
Zeile 2.081: |
| | | |
| 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]. | | 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. |
| | | |
| === Scannen in verschiedenen Distributionen === | | === Scannen in verschiedenen Distributionen === |
Zeile 1.190: |
Zeile 2.098: |
| * Unter [[Debian]] | | * Unter [[Debian]] |
| ** ist neben der Installation von <code>xsane</code> auch die Installation von <code>sane-utils</code> erforderlich. | | ** 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. | + | ** 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. |
| | | |
| ==== Ubuntu ==== | | ==== Ubuntu ==== |
Zeile 1.219: |
Zeile 2.127: |
| == Energiemanagement == | | == Energiemanagement == |
| | | |
| + | === 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> | | 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> |
| | | |
Zeile 1.225: |
Zeile 2.134: |
| Den Pfad für das oben angegebene Kommando findet man durch | | Den Pfad für das oben angegebene Kommando findet man durch |
| upower -e | | upower -e |
| + | |
| + | Eine komplette Übersicht erhält man mit |
| + | upower --dump |
| + | |
| + | === Festplatte im Leerlauf ausschalten === |
| + | |
| + | Siehe |
| + | * https://www.foxplex.com/sites/festplatten-standby-im-leerlauf-mit-hdparm-und-hd-idle/ |
| + | |
| + | === 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 |
| + | |
| + | Siehe |
| + | * http://www.thinkwiki.org/wiki/How_to_reduce_power_consumption |
| + | * https://metebalci.com/blog/a-minimum-complete-tutorial-of-cpu-power-management-c-states-and-p-states/ |
| | | |
| == Verbindung mit Handy/PDA == | | == Verbindung mit Handy/PDA == |
Zeile 1.235: |
Zeile 2.163: |
| == Weitere Anwendungen == | | == Weitere Anwendungen == |
| | | |
| + | === Editoren === |
| + | |
| + | ==== Grafische Editoren und Entwicklungsumgebungen ==== |
| + | |
| + | * Geany |
| + | * [[Netbeans]] |
| + | * [[Eclipse]] |
| + | |
| + | ==== Editoren fürs Terminalfenster ==== |
| + | |
| + | * [[vim]] |
| + | * nano |
| + | * joe - Benutzerführung wie MS WordStar (etwas antiquiert) |
| + | * emacs |
| + | |
| + | === Textverarbeitung === |
| + | |
| + | Die Standard-Textverarbeitung unter Linux ist derzeit [[LibreOffice]] Writer. |
| | | |
| === Plattformübergreifende Software === | | === Plattformübergreifende Software === |
Zeile 1.247: |
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 === |