Arch User Repository: Unterschied zwischen den Versionen

Aus wiki.archlinux.de
SiD (Diskussion | Beiträge)
Tuxnix (Diskussion | Beiträge)
K typo
 
(50 dazwischenliegende Versionen von 15 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
==Einführung==
Das [https://aur.archlinux.org/?setlang=de <u>A</u>rch Linux <u>U</u>ser Community <u>R</u>epository - AUR] ist eine Sammlung von Paketbau-Anleitungen den PKGBUILDs. Diese Anleitungen erstellen Programm-Pakete die auf Arch Linux installiert werden können. Jeder kann im AUR ohne weitere Prüfung seine Pakete nach einer [https://aur.archlinux.org/register/?setlang=de Registrierung] veröffentlichen und allen anderen Usern zur Verfügung stellen.
Das [http://aur.archlinux.org/index.php?setlang=de ArchLinux User-Community Repository (AUR)] ist eine Sammlung von Paketbeschreibungen (den PKGBUILDs) anhand derer Programmpakete für Arch Linux mittels [[Abs|ABS]] erstellt werden können. Jeder kann dort seine Pakete nach einer [http://aur.archlinux.org/account.php?setlang=de Registrierung] veröffentlichen und anderen zur Verfügung stellen.
 
==Vorbereitung==
Alle Programme sowohl für die Installation von AUR-Paketen als auch zu deren Erstellung werden im core-package base-devel zur Verfügung gestellt:
 
  pacman -S base-devel


==Ein Paket aus dem AUR installieren==
==Ein Paket aus dem AUR installieren==
===Voraussetzungen===
Alle Pakete, die zur Erstellung von Paketen notwendig sind, befinden sich in der Gruppe base-devel:


  pacman -S base-devel
(Als konkretes Beispiel siehe [[Trizen]])
 
{{Hinweis|Alle folgenden Befehle werden mit Userrechten ausgeführt!}}


===Paketdateien herunterladen===
git clone https://aur.archlinux.org/<Paketname>.git
Alle Dateien die nötig sind, um ein Paket zu erstellen, sind in einem Tarball gespeichert. Dieser kann von der entsprechenden Seite unter dem Link ''Tarball'' im AUR heruntergeladen werden.
Durch den Befehl werden das PKGBUILD und der Source Code heruntergeladen.


===Ein Verzeichnis für eigene Pakete wählen===
cd <Paketname>
Pakete sollten nicht als root erstellt werden. Deswegen ist es ratsam, die Paketdateien in einem Verzeichnis zu speichern, das einem normalen Benutzer zugänglich ist. Eine Möglichkeit ist ein Verzeichnis in ''/home'', dann sind keine weiteren Schritte notwendig.
Wechselt ins Verzeichnis


Wenn die Paketdateien im /home-Verzeichnis nicht gewünscht sind, sollte man sie in ''/var/abs/local'' speichern, da in ''/var/abs'' der [[Abs#Der_ABS-Verzeichnisbaum|ABS-Verzeichnisbaum]] liegt.
nano PKGBUILD
(Nur ''/var/abs/local'' ist unter ''/var/abs'' verwendbar, da die übrigen Verzeichnisse von [[Abs#Der_ABS-Verzeichnisbaum|abs]] überschrieben werden können.)
{{achtung| Beachte die [[AUR Sicherheitshinweise]]!}}


Um ''/var/abs/local'' für normale Benutzer zugänglich zu machen, sind folgende Schritte nötig:
makepkg -i
Das Paket wird gebaut und nach Abfrage des root Passworts auf dem System installiert.


* Gruppe ''abs'' erstellen
==Paketabhängigkeiten==
groupadd abs


* Benutzer der Gruppe ''abs'' hinzufügen (erst nach einem erneuten Anmelden wird das Hinzufügen wirksam)
Unter Umständen müssen noch Pakete installiert werden, die beim Bauen oder zur Laufzeit benötigt werden. Stammen diese aus dem core bzw. extra Repositorien dann ist zusätzlich die Option -s zu nutzen.
gpasswd -a <Benutzer> abs
Bei Abhängigkeiten, die selber nur aus dem AUR erhältlich sind, müssen diese Pakete nach dem hier geschilderten Verfahren erst gebaut und installiert werden, bis mit dem Weiterbau des gewünschten AUR-Pakets fortgefahren werden kann.


* Gruppe und Zugriffsrechte ändern
Muss mehrmals zum Bau eines AUR-Pakets angesetzt werden empfiehlt es sich zusätzlich die Option -f zu nutzen.
mkdir -p /var/abs/local
chown root:abs /var/abs/local
chmod 775 /var/abs/local


===Paket erstellen===
Die wichtigsten Optionen von makepkg sind:
{{achtung|Um Schäden am System zu verhindern, sollten Pakete niemals als Root gebaut werden!}}
* -i, --install    Installiere Paket nach erfolgreichem Build
Das Paket wird mittels ''[[makepkg]]'' erstellt. Dazu wechselt man in das Verzeichnis in dem sich der Tarball befindet, entpackt ihn, wechselt in das Paket-Verzeichnis und führt ''makepkg'' aus:
* -s, --syncdeps  Installiere fehlende Abhängigkeiten mit pacman
* -f, --force      Zuvor erstelltes Paket überschreiben


  tar -xvzf /<Pfad zum Tarball>/beispiel-paket.tar.gz
Alternativ zu diesem Vorgang, bietet sich die Verwendung eines der [[AUR Hilfsprogramme]] an. Wobei man bei Arch Linux dazu gezwungen ist, den ersten dieser Helfer nach obiger Anleitung zu installieren.
  cd beispiel-paket
  makepkg


===Paket installieren===
==Eigene Pakete erstellen==
Das soeben erstellte Paket kann nun (als root) mittels [[Pacman]] installiert werden:


  pacman -U beispiel-paket-*.pkg.tar.gz
Alle Dateien eines AUR-Pakets werden in einem eigenen Git-Repository gepflegt.
Daher ist also zunächst git zu installieren.
pacman -S git


==Hilfsprogramme für AUR==
Man benötigt einen User im AUR, den man über die Weboberfläche einrichten kann, und einen öffentlichen Schlüssel (ssh), der dort per Copy&Paste zu hinterlegen ist.
Es gibt eine Fülle von Hilfsprogrammen, die den Umgang mit dem AUR erleichtern. Sie verfolgen unterschiedliche Ziele.
===Allumfassende Hilfsprogramme===
Diese Programme decken vom automatischen Herunterladen über das Bauen bis zum Installieren alle Schritte ab, verstecken also den eigentlichen pacman-Aufruf vor dem Benutzer.
====[[yaourt]]====
Mit [[yaourt]] bietet das AUR ein sehr komfortables Shellskript, welches die oben genannten Schritte auf ein


  yaourt -S aur-beispiel-programm
In der lokalen Konfigurationsdatei {{ic|~/.ssh/config}} ist folgendes einzutragen:


reduziert.
Host aur.archlinux.org
====[[paktahn]]====
  IdentityFile ~/.ssh/aur
[[paktahn]] ist ein in Common Lisp geschriebenes Programm, das sich hinsichtlich Aufruf und Wirkungsweise an [[yaourt]] orientiert. Das auzurufende Programm heißt pak.  
  User aur
====[[packer]]====
Ein weiteres Shellskript mit ähnlichem Funktionsumfang wie [[yaourt]].
===Hilfsprogramme, die Teilaspekte abdecken===


====Aurcheck====
Dann ist etwa folgendes einzugeben:
Mit {{AUR|aurcheck}} kann man sich anzeigen lassen, ob es für installierte Pakete aus dem AUR Updates gibt.
<nowiki>git clone ssh://aur@aur.archlinux.org/<paketname>.git</nowiki>
Das Bash Script, ermittelt mittels 'pacman -Qm' alle installierten Pakete, die in keinem Repo sind, sucht diese dann im AUR und vergleicht die Versionsnummern.
wobei <paketname> entsprechend zu ersetzen ist.


====cower====
Die Datei [https://www.archlinux.org/pacman/PKGBUILD.5.html PKGBUILD] ist im Wurzelverzeichnis des neu geklonten Git-Repositories zu erstellen.
{{AUR|cower}} ist in C geschrieben und lädt die Tarbälle nur herunter. Es wird also weder gebaut noch installiert.
Ferner '''''muss''''' jeder Git-Commit die Datei ''.SRCINFO'' beinhalten.
Diese kann mittels
makepkg --printsrcinfo > .SRCINFO
oder {{ic|mksrcinfo}} aus dem Paket {{paket|pkgbuild-introspection}} erstellt werden.


====[[burp]]====
==Siehe auch==
Vom selben Autor wie [[cower]], aber zum Hochladen der PKGBUILDs ins AUR gedacht.
* [[Arch Build System]]
* [[AUR Sicherheitshinweise]]
* [[AUR Hilfsprogramme]]
* [[AUR benutzen (Beispiele)]]
* [[Trizen]]


==Links==
[[ar:Arch User Repository]]
* [http://aur.archlinux.org/index.php?setlang=de ArchLinux User-Community Repository (AUR)]
[[cs:Arch User Repository]]
* [[Pacman]]
[[da:Arch User Repository]]
* [[Abs|ABS]]
[[en:Arch User Repository]]
[[el:Arch User Repository]]
[[es:Arch User Repository]]
[[fi:AUR]]
[[fr:AUR]]
[[it:Arch User Repository]]
[[ja:Arch User Repository]]
[[nl:Arch User Repository]]
[[pl:Arch User Repository]]
[[pt:Arch User Repository]]
[[ro:AUR]]
[[ru:Arch User Repository]]
[[sr:Arch User Repository]]


[[Kategorie:ArchLinux Projekte]]
[[Kategorie:Arch-Linux-Projekte]]
[[Kategorie:Paketverwaltung]]
[[Kategorie:Paketverwaltung]]
[[en:Arch User Repository]]

Aktuelle Version vom 12. August 2024, 20:09 Uhr

Das Arch Linux User Community Repository - AUR ist eine Sammlung von Paketbau-Anleitungen den PKGBUILDs. Diese Anleitungen erstellen Programm-Pakete die auf Arch Linux installiert werden können. Jeder kann im AUR ohne weitere Prüfung seine Pakete nach einer Registrierung veröffentlichen und allen anderen Usern zur Verfügung stellen.

Vorbereitung

Alle Programme sowohl für die Installation von AUR-Paketen als auch zu deren Erstellung werden im core-package base-devel zur Verfügung gestellt:

 pacman -S base-devel

Ein Paket aus dem AUR installieren

(Als konkretes Beispiel siehe Trizen)

Hinweis: Alle folgenden Befehle werden mit Userrechten ausgeführt!

git clone https://aur.archlinux.org/<Paketname>.git

Durch den Befehl werden das PKGBUILD und der Source Code heruntergeladen.

cd <Paketname>

Wechselt ins Verzeichnis

nano PKGBUILD

Achtung: Beachte die AUR Sicherheitshinweise!


makepkg -i

Das Paket wird gebaut und nach Abfrage des root Passworts auf dem System installiert.

Paketabhängigkeiten

Unter Umständen müssen noch Pakete installiert werden, die beim Bauen oder zur Laufzeit benötigt werden. Stammen diese aus dem core bzw. extra Repositorien dann ist zusätzlich die Option -s zu nutzen. Bei Abhängigkeiten, die selber nur aus dem AUR erhältlich sind, müssen diese Pakete nach dem hier geschilderten Verfahren erst gebaut und installiert werden, bis mit dem Weiterbau des gewünschten AUR-Pakets fortgefahren werden kann.

Muss mehrmals zum Bau eines AUR-Pakets angesetzt werden empfiehlt es sich zusätzlich die Option -f zu nutzen.

Die wichtigsten Optionen von makepkg sind:

  • -i, --install Installiere Paket nach erfolgreichem Build
  • -s, --syncdeps Installiere fehlende Abhängigkeiten mit pacman
  • -f, --force Zuvor erstelltes Paket überschreiben

Alternativ zu diesem Vorgang, bietet sich die Verwendung eines der AUR Hilfsprogramme an. Wobei man bei Arch Linux dazu gezwungen ist, den ersten dieser Helfer nach obiger Anleitung zu installieren.

Eigene Pakete erstellen

Alle Dateien eines AUR-Pakets werden in einem eigenen Git-Repository gepflegt. Daher ist also zunächst git zu installieren.

pacman -S git

Man benötigt einen User im AUR, den man über die Weboberfläche einrichten kann, und einen öffentlichen Schlüssel (ssh), der dort per Copy&Paste zu hinterlegen ist.

In der lokalen Konfigurationsdatei ~/.ssh/config ist folgendes einzutragen:

Host aur.archlinux.org
  IdentityFile ~/.ssh/aur
  User aur

Dann ist etwa folgendes einzugeben:

git clone ssh://aur@aur.archlinux.org/<paketname>.git

wobei <paketname> entsprechend zu ersetzen ist.

Die Datei PKGBUILD ist im Wurzelverzeichnis des neu geklonten Git-Repositories zu erstellen. Ferner muss jeder Git-Commit die Datei .SRCINFO beinhalten. Diese kann mittels

makepkg --printsrcinfo > .SRCINFO

oder mksrcinfo aus dem Paket pkgbuild-introspection erstellt werden.

Siehe auch