Von Anfang an stand bei mir fest das ich umsteigen wollte, alleine schon wegen der Sytemupdates unter Windows 10 die mir immer wieder Probleme bereiteten. Immer wieder hatte ich einen Umstieg auf Linux angegangen und immer wieder bin ich in letzter Konsequenz daran gescheitert für alle meinerseits benötigten Einsatzgebiete passende alternativen zu finden, doch diese Mal kam es anders.
Client Installation
Zuerst hatte ich mir eine Liste zusammen gestellt was meine Mindestanforderungen an meinen Entwicklungsrechner mit seinem System und der Entwicklungsumgebung sind.
- ein System das ein besseres Rechtesystem hat, aber nicht für den Nutzer zu kompliziert wird
- Firefox als Browser, unter Ubuntu Standard, unter Windows immer noch meine erste Wahl als Entwickler
- Thunderbird als E-Mail-Client, unter Ubuntu Standard, unter Windows mein bisheriger E-Mail-Client
- Lazarus / Free Pascal (FPCUPdeluxe) läuft unter Ubuntu wie auch unter Windows
- Remote Desktop Betrieb zum Server (nicht nur Konsole) unter Ubuntu über Remmina
- Dateifreigabe im Netzwerk, unter Ubuntu in Nautilus über Samba
- SVN und Git, unter Ubuntu Git Cola/DAG (in Nautilus mit RabbitVCS), als Alternative zu Windows im Explorer mit TortoiseSVN und TortoiseGit
- ein Ersatz für Notepad++, unter Ubuntu kein equivalentes Gegenstück aber als teilweiser Ersatz SciTE, GEdit, GHex, Meld, ...
- ein Ersatz für Paint.net, unter Ubuntu Pinta
- Inkscape läuft unter Ubuntu wie auch unter Windows
Sicherlich gibt es einige Wege um ein Entwicklungsrechner aufzusetzen, aber gerade Umsteiger von Windows haben es am Anfang nicht gerade leicht mit Ubuntu.
Gestartet bin ich mit einem USB-Stick mit Ubuntu 18.04 Bionic Beaver und der Standard Installation, dieses Vorgehen möchte ich nicht weiter beschreiben denn hiervon gibt es zahlreiche Beschreibungen im Netz.
Starten möchte ich den anschließenden Schritten, der Installation und Konfiguration der Komponenten.
Tritt in den folgenden Passagen [user] im Text oder Code auf ist an dieser Stelle der eigene Benutzer gemeint.
Vorbereitungen
Nautilus um die Funktion "Neue Dokument" anlegen erweitern, im Verzeichnis "/home/[user]/Vorlagen" eine Datei leer.txt anlegen
Unter Ubuntu werden viele Vorgänge im Terminal-Fenster durchgeführt und oft sind es Befehle für die man Administrationsrechte benötigt also "SUDO", was ist da naheliegender als sich ein Terminal-Fenster mit sudo-Rechten zu öffnen damit man nicht vor jeden Befehl sudo tippen muss.
Terminal Fenster mit root Rechten (sudo)
Einmal das Passwort eingeben für alle folgenden Befehle.
Ein Update der Paketeliste durchführen
Nautilus um die Dateibehandlung "Als Administrator bearbeiten" erweitern, damit das Bearbeiten von geschützten Dateien vereinfacht wird
Entwicklungsumgebung installieren
Die fehlenden Pakete für Free Pascal und Lazarus nachinstallieren
Möchte man mit OpenGL ( TOpenGLControl ) entwickeln ist auch noch das folgende Paket erforderlich
SVN / Git installieren
SVN / Git GUI installieren
Free Pascal und Lazarus installieren
fpcupdeluxe-x86_64-linux auf https://github.com/LongDirtyAnimAlf/fpcupdeluxe/releases herunter laden und im persönlichen Ortner (/home/[user]/) unter fpcupdeluxe ablegen und in Nautilus mit Rechts-Klick auf die Datei, die Eigenschaften bearbeiten, im Reiter Zugriffsrechte Ausführen Haken setzen. (Properties-->Permissions-->Allow executing file as program). Nun lässt sich das Programm einfach starten, im folgenden habe ich einfach das Installations-Verzeichnis im Benutzerverzeichnis /home/[user]/fpcupdeluxe angegeben und sowohl Free Pascal als auch Lazarus in der Trunk Version installiert (dieses lief unter Ubuntu wesentlich schneller als unter Windows).
Damit man in Zukunft dieses Programm zum Updaten von Free Pascal als auch Lazarus benutzen kann empflielt es sich eine Verknüpfungsdatei anzulegen (desktop shortcut launcher)
Eine Datei FPCUPdeluxe.desktop im eigenen persönlichen Ortner (/home/[user]/) unter .local/share/applications anlegen (das Icon habe ich mir aus dem fpcupdelux Projekt besorgt):
Um diese Datei startbar zu machen auch hier in Nautilus mit Rechts-Klick auf die Datei, die Eigenschaften bearbeiten, im Reiter Zugriffsrechte Ausführen Haken setzen.
Falls fpcdeluxe es immer noch nicht schafft eine funktionierende Verknüfungsdatei anzulegen folgt hier nun noch die passende Datei für Lazarus
Eine Datei Lazarus.desktop im eigenen persönlichen Ortner (/home/[user]/) unter .local/share/applications anlegen:
Nun sollten sowohl FPCUPdeluxe als auch Lazarus in der Anwendungsliste (Anwendungen anzeigen) angezeigt werden, dort sind sie auch aufrufbar, ich habe sie mir direkt zu den Favoriten hinzugefügt.
Tools zur Bildbearbeitung/Optimierung installieren
libpodofo-utils um uncompress von pdf zu ermöglichen
jpegoptim und jpegtran zur jpeg Optimierung
optipng zur png Optimierung
gifsicle zur gif Optimierung
Erweiterung für Nautilus zum anzeigen von Video-Thumbnails
Allgemeiner mp4 support
WebP support
pdftohtml - poppler 0.62.0 braucht nicht installiert werden
Installieren der paint.net alternative pinta und inkscape als Bild/Vektor-Bearbeitungsprogramme
Erweiterung für Nautilus zum Reduzieren der Größe von JPG/PNG Dateien
Komprimierungs-Tools
zlib
7zip
brotli
OpenSSL aus den Sourcen erzeugen
OpenSSL download der Sourcen
OpenSSL Installation
link libraries konfigurieren
Datei anlegen /etc/ld.so.conf.d/openssl-1.1.1.conf (in Nautilus "Als Administrator öffnen", Neues Dokument leer, "Als Administrator bearbeiten", im KEdit speichern unter)
Datei /etc/manpath.config bearbeiten (in Nautilus "Als Administrator bearbeiten") und die folgende Zeile einfügen
manual database Update
Datei /etc/environment (in Nautilus "Als Administrator bearbeiten") /usr/local/ssl/bin hinzufügen
Erfolgreiche Änderung überprüfen
Um etwas mehr an den Desktop Einstellungen verändern zu können oder sogar ein Windows ähnlicheres Aussehen zu erreichen kann man ein paar nützliche Tools installieren
dconf installieren
Windows look
restart
dconf -> Tweaks: Optimierungen -> Erweiterungen -> Dash to Panel
Firefox und Thunderbird
Das Firefox Profile welches ich unter Windows gesichert habe wie auch das Thunderbird Profile in den Ordner (/home/[user]/) unter .mozilla/firefox/[profilename] bzw. ,thunderbird/[profilename] ablegen, falls die Ordner noch nicht existieren einfach die Anwendung einmal starten.
Im Termninal lassen sich die beiden Anwendungen mit Übergabeparameter -p aufrufen danach erscheint ein Dialog zur Profile-Auswahl und zur Einstellung des Standard-Profiles.
Dateifreigabe über Samba
Datei /etc/libuser.conf anlegen (in Nautilus "Als Administrator öffnen", Neues Dokument leer, "Als Administrator bearbeiten", im KEdit speichern unter)
Grafisches Benutzerinterface für Samba
Samba Neustart
Tools
SciTE
GHex Editor
Bei Einrichtung eines Dual-Boot Systems ist eine ntfs Partition zum Datenaustausch zwischen den Systemen sinnvol (ntfs data patition mount)
Datei /etc/fstab (in Nautilus "Als Administrator bearbeiten" im KEdit nach der ntfs Partition suchen und die Zeile bearbeiten)
Fingerprint Scanner unterstützung einrichten
Datei /etc/pam.d/common-auth (in Nautilus "Als Administrator bearbeiten" im KEdit folgende Zeile einfügen)
System aufräumen
alte Kernel entfernen
überflüssige Abhängigkeiten entfernen
Paket-Cache leeren
Server Installation
Für den Server kann man natürlich ein spezielles Ubuntu Server Image herunterladen, da ich aber eine grafische Benutzeroberfläche bevorzuge auf die ich Remote zugreifen kann habe ich das Selbe Image wie zur Client Installation genommen, allerdings nur die minimale Installation durchgeführt.
Nach der Installation habe ich die selben Vorbereitungen wie bei der Client Installation durchgeführt
Installation des Remote Desktop Freigabe
Unter Einstellungen -> Freigabe sowohl in der Kopfleiste Einschalten als auch die Bildschirmfreigabe aktivieren, hier das passende Netzwerk auswählen, Verbindungen zur Steuerung des Bildschirms erlauben und ein Passwort vergeben.
Mit Remmina auf die Remote Desktop Freigabe zugreifen
In Remmina über den Plusbutton ein neues Verbindungsprofil erstellen, Protokoll VNC auswählen, Bezeichnug vergeben, bei Server den Rechnername und bei Benutzerpasswort das Passwort der Freigabe eingeben, anschließend speichern.
Je nach gewünschter Qualität, Einschränkungen und bezüglich eines SSH-Tunnel können auch noch Einstellungen vorgenommen werden, die sind aber nicht unbedingt erforderlich.
Dateifreigabe über Samba
Die Dateifreigabe wie bei der ClientInstallation durchgeführt.
Installation des eigenen Servers oder LAMP (Apache, PHP 7.2 und MySQL) Installation
Installation nützlicher Netzwerktools
Hosts Entry des Services in /etc/hosts eintragen
dhcp freigabe ipv6
Datei /etc/dhcpcd.conf bearbeiten (in Nautilus "Als Administrator bearbeiten") und folgende Zeile hinzufügen
Einstellungen überprüfen
Eine Service für den eigens geschrieben daemon anlegen, hier am Beispiel meines Webservers (httpServer.service)
Das Verzeichnis /etc/systemd/system (in Nautilus "Als Administrator bearbeiten") /etc/systemd/system/httpServer.service hinzufügen
Zum Ausführen hier noch die passenden Komandos
Let's encrypt certbot installieren und einrichten
Certificate erzeugen
Hier wieder am Beispiel von meinem Webauftritt.
result is in /etc/letsencrypt