Diskussion:Linux/Programme kompilieren: Unterschied zwischen den Versionen
Die Seite wurde neu angelegt: „'''Kompilierung''' von Quellarchiven == Beschreibung == Bevor Linux auf der Bildfläche erschien, wurden Programm-Pakete in Source-Form zur Verfügung gestellt, die in komprimierte Tar-Archive (auch als Tar-Ball bezeichnet) verpackt wurden * Während früher hauptsächlich das Unix-eigene compress zum Komprimieren verwendet wurde, ist es inzwischen weitgehend von gzip verdrängt worden, das einen besseren Komprimierungs-Faktor erzielt * Vereinzelt wird…“ |
K Dirkwagner verschob die Seite Diskussion:GCC auf Debian nach Diskussion:Linux/Programme kompilieren |
(kein Unterschied)
|
Version vom 22. November 2024, 10:57 Uhr
Kompilierung von Quellarchiven
Beschreibung
Bevor Linux auf der Bildfläche erschien, wurden Programm-Pakete in Source-Form zur Verfügung gestellt, die in komprimierte Tar-Archive (auch als Tar-Ball bezeichnet) verpackt wurden
- Während früher hauptsächlich das Unix-eigene compress zum Komprimieren verwendet wurde, ist es inzwischen weitgehend von gzip verdrängt worden, das einen besseren Komprimierungs-Faktor erzielt
- Vereinzelt wird auch bzip2 eingesetzt, da es noch besser ist, hier wurde zum Vergleich die Tar-Datei von tkcvs 6.4 herangezogen)
Typische Komprimierung von compress, gzip und bzip2
Endung | komprimiert mit | auspacken mit |
.tar | (ohne) | tar xvf .. |
.tar.Z | compress | tar Zxvf .. |
.tar.gz | gzip | tar zxvf .. |
.tgz | gzip | tar zxvf .. |
.tar.bz2 | bzip2 | tar jxvf .. |
Das GNU-tar-Kommando, das üblicherweise bei allen Linux-Distributionen verwendet wird, kann mit komprimierten Tar-Archiven umgehen
Bevor Linux auf der Bildfläche erschien, wurden Programm-Pakete in Source-Form zur Verfügung gestellt, die in komprimierte Tar-Archive (auch als Tar-Ball bezeichnet) verpackt wurden
- Während früher hauptsächlich das Unix-eigene compress zum Komprimieren verwendet wurde, ist es inzwischen weitgehend von gzip verdrängt worden, das einen besseren Komprimierungs-Faktor erzielt
- Vereinzelt wird auch bzip2 eingesetzt, da es noch besser ist, hier wurde zum Vergleich die Tar-Datei von tkcvs 6.4 herangezogen)
- Typische Komprimierung von compress, gzip und bzip2
Endung | komprimiert mit | auspacken mit |
.tar | (ohne) | tar xvf .. |
.tar.Z | compress | tar Zxvf .. |
.tar.gz | gzip | tar zxvf .. |
.tgz | gzip | tar zxvf .. |
.tar.bz2 | bzip2 | tar jxvf .. |
- GNU-tar-Kommando
, wird üblicherweise bei allen Linux-Distributionen verwendet wird, kann mit komprimierten Tar-Archiven umgehen (s. Tabelle)
- Andere Unix-Systeme (z. B. SunOS) verwenden eine andere Tar-Implementierung
- Hier muss man zuerst das Archiv dekomprimieren (mit uncompress, gunzip oder bunzip2), ehe man die Tar-Datei auspacken kann
Vereinzelt findet man auch im Linux-Bereich Zip-Archive vor, erkennbar an der Endung .zip
- Diese werden mit unzip ausgepackt
Nachdem das Tar-Archiv erfolgreich ausgepackt ist, sollte man nach einer Datei README oder INSTALL Ausschau halten
- Dort steht beschrieben, wie das Paket übersetzt und installiert wird
- Unabhängig von der Plattform und Distribution sind es meist folgende Schritte, die ausgeführt werden:
./configure oder make config
Im ersten Schritt wird untersucht, um was für ein System (Linux, Unix, ...) es sich handelt, welche Bibliotheken vorhanden sind und ob die zur Kompilierung benötigten Tools wie C-Compiler (gcc) oder Linker (ld) installiert sind, um daraus ein Makefile zu generieren
make
Mithilfe des Makefiles, das im ersten Schritt erzeugt wurde, wird das Paket übersetzt
make test (optional)
Mit diesem Schritt wird überprüft, ob die Kompilation erfolgreich war
make install
Damit wird das Paket installiert
- Hilfreich
bei der Übersetzung ist die Option -n des make-Kommandos
- Damit kann man make erst einmal trocken ausführen, um zu sehen, welche Kommandos alle ausgeführt werden und in welches Verzeichnis welche Dateien kopiert werden, um nötigenfalls das Makefile noch anpassen zu können
- Auch wenn dieses Verfahren meist problemlos funktioniert, hat die Sache einen Haken
- An die Deinstallation hat der Autor meistens nicht gedacht, d. h. ein make uninstall wird in den wenigsten Fällen klappen
- Und so bleiben die installierten Dateien bis in alle Ewigkeit im System, es sei denn, man hat sich bei der Installation gemerkt, welche Dateien wohin kopiert wurden und löscht sie manuell
- Weitere Nachteile der manuellen Installation
Auf dem Zielsystem müssen alle Werkzeuge (Compiler, Linker, Make etc.), Bibliotheken und Headerdateien zum Kompilieren des Programmes vorhanden sein
- Bei der Installation einer neueren Version eines Programmes (Update) werden evtl. die bereits vorhandenen, an das System angepassten Konfigurationsdateien der alten Version überschrieben
- Andere Unix-Systeme (z. B. SunOS) verwenden eine andere Tar-Implementierung
- Hier muss man zuerst das Archiv dekomprimieren (mit uncompress, gunzip oder bunzip2), ehe man die Tar-Datei auspacken kann
Vereinzelt findet man auch im Linux-Bereich Zip-Archive vor, erkennbar an der Endung .zip
- Diese werden mit unzip ausgepackt
Nachdem das Tar-Archiv erfolgreich ausgepackt ist, sollte man nach einer Datei README oder INSTALL Ausschau halten
- Dort steht beschrieben, wie das Paket übersetzt und installiert wird
- Unabhängig von der Plattform und Distribution sind es meist folgende Schritte, die ausgeführt werden:
./configure oder make config
Im ersten Schritt wird untersucht, um was für ein System (Linux, Unix, ...) es sich handelt, welche Bibliotheken vorhanden sind und ob die zur Kompilierung benötigten Tools wie C-Compiler (gcc) oder Linker (ld) installiert sind, um daraus ein Makefile zu generieren
make
Mithilfe des Makefiles, das im ersten Schritt erzeugt wurde, wird das Paket übersetzt
make test (optional)
Mit diesem Schritt wird überprüft, ob die Kompilation erfolgreich war
make install
Damit wird das Paket installiert
Hilfreich bei der Übersetzung ist die Option -n des make-Kommandos
- Damit kann man make erst einmal trocken ausführen, um zu sehen, welche Kommandos alle ausgeführt werden und in welches Verzeichnis welche Dateien kopiert werden, um nötigenfalls das Makefile noch anpassen zu können
Auch wenn dieses Verfahren meist problemlos funktioniert, hat die Sache einen Haken: an die Deinstallation hat der Autor meistens nicht gedacht, d. h. ein make uninstall wird in den wenigsten Fällen klappen
- Und so bleiben die installierten Dateien bis in alle Ewigkeit im System, es sei denn, man hat sich bei der Installation gemerkt, welche Dateien wohin kopiert wurden und löscht sie manuell
- Weitere Nachteile der manuellen Installation
- Auf dem Zielsystem müssen alle Werkzeuge (Compiler, Linker, Make etc.), Bibliotheken und Headerdateien zum Kompilieren des Programmes vorhanden sein
- Bei der Installation einer neueren Version eines Programmes (Update) werden evtl. die bereits vorhandenen, an das System angepassten Konfigurationsdateien der alten Version überschrieben
Installation
Aufruf
Optionen
Parameter
Umgebungsvariablen
Exit-Status
Anwendung
Problembehebung
Konfiguration
Dateien
Anhang
Siehe auch
- Linux
- Linux/Benutzer
- Linux/Besitzrechte
- Linux/Bilder/optimieren
- Linux/CPU
- Linux/Capabilities
- Linux/Datei
- Linux/Datei/Eigenschaft
- Linux/Datei/Link
- Linux/Datei/Name
- Linux/Datei/Name/bereinigen
- Linux/Datei/Pipe
- Linux/Datei/Typ
- Linux/Datei/Vergleich
- Linux/Datei/Zeit
- Linux/Datei/komprimierenArchivieren
- Linux/Datei/~/.bashrc
- Linux/Dateinamen/Bindestrich
- Linux/Dateinamen/bereinigen/Skripte
- Linux/Dateisystem
- Linux/Dateisystem/Bereinigen
- Linux/Dateisystem/Hierarchie
- Linux/Dateisystem/Zugiff
- Linux/Dateisystem/ext
- Linux/Dateisystem/ext/Attribute
- Linux/Datensicherung und -archivierung
- Linux/Datenträgerverwaltung
- Linux/Dienst
- Linux/Distribution
- Linux/Dokumentation
- Linux/Dokumentation/HowTo's
- Linux/Doppelte Dateien
- Linux/Editoren
- Linux/GRUB Legacy
- Linux/GUI
- Linux/Hardware
- Linux/Kernel/Module
- Linux/Logging
- Linux/Logging/Dienstprogramme
- Linux/Logging/Syslog
- Linux/Netzwerk/IPv6
- Linux/Netzwerk/IPv6/Privacy Extension
- Linux/Netzwerk/Virtuelle Schnittstelle
- Linux/Netzwerkkonfiguration
- Linux/Paketverwaltung
- Linux/Programme kompilieren
- Linux/Prozess
- Linux/Prozesse
- Linux/Prozesse/Prozess erstellen
- Linux/Prozessverwaltung
- Linux/Root-Passwort zurücksetzen
- Linux/Runlevel/Default
- Linux/Server/Dienste
- Linux/Shell
- Linux/Shell/Grundlagen
- Linux/Shells und Shell-Skripte
- Linux/Shells und Shell-Skripte/Aliase und Funktionen
- Linux/Shells und Shell-Skripte/Umgebungsvariablen und Shellvariablen
- Linux/Sicherheit/Tools
- Linux/Sicherheit/Verschlüsselung
- Linux/Software-RAID
- Linux/Software-RAID/Alignment
- Linux/Software-RAID/Anlegen
- Linux/Software-RAID/Aufgaben
- Linux/Software-RAID/Fehlerbehebung
- Linux/Software-RAID/Vorbereitung
- Linux/Software-RAID/Wartung
- Linux/Software-RAID/tmp
- Linux/Software/Verwaltung
- Linux/SoftwareRAID
- Linux/Systemstart
- Linux/Troubleshooting
- Linux/Umgebung/Variable
- Linux/YubiKey
- Linux/Zeit/Synchronisation
- Linux/Zugriffskontrollliste
- Linux/Zugriffsrechte
- Linux/Zugriffsrechte/Kopieren
- Linux/lmSensors
- Linux (Kernel)
- Linux From Scratch
- Linux Port Mirroring
- Linux tunnel
Dokumentation
Man-Page
Info-Pages
Links
Projekt
Weblinks