OPKG (en): Unterschied zwischen den Versionen
Zeile 79: | Zeile 79: | ||
opkg update | opkg update | ||
− | {{Warnung| | + | {{Warnung|Please keep in mind, packages from external sources can damage the system!}} |
− | {{Achtung| | + | {{Achtung|Use the correct [[OPKG_(en)#Package_architecture_for_local_installations| package architecture]], for the different Dreamboxes and used OpenEmbedded versions!}} |
− | === Installation | + | === Installation of one package === |
− | + | Use the following command for the installation. | |
<syntaxhighlight> | <syntaxhighlight> | ||
− | opkg install /tmp/$ | + | opkg install /tmp/$file_name_of_the_package |
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | Keep in mind, the '''complete''' file name must be specified. E.g. if installing the skin <code>gp-skin-ln.hd_gp32-20130903_all.ipk</code>, the command is as follows. Use the {{Taste|TAB}} to complete the file name automatically. | |
<syntaxhighlight> | <syntaxhighlight> | ||
opkg install /tmp/gp-skin-ln.hd_gp32-20130903_all.ipk | opkg install /tmp/gp-skin-ln.hd_gp32-20130903_all.ipk | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | Of course it's also possible to use an asterisk as wildcard, this way you don't need to write the complete name. E.g: | |
<syntaxhighlight> | <syntaxhighlight> | ||
opkg install /tmp/gp-skin* | opkg install /tmp/gp-skin* | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | === Installation | + | === Installation of multiple packages === |
− | + | The installation of multiple packages is also easy, once all files are copied with [[FTP (en)|FTP]] in the directory <code>/tmp</code> on the Dreambox. Use the following command to install all packages. By the way, this works also for the installation of one package ;) | |
<syntaxhighlight> | <syntaxhighlight> | ||
opkg install /tmp/*.ipk | opkg install /tmp/*.ipk | ||
Zeile 103: | Zeile 103: | ||
=== Deinstallation === | === Deinstallation === | ||
− | + | The removal of a package is also done with the package name (without the version and the extention ipk) and the following command: | |
<syntaxhighlight> | <syntaxhighlight> | ||
− | opkg remove $ | + | opkg remove $package_name |
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | Of course the <code>'''$package_name'''</code> needs to be replaced by the correct name. If you want to remove the <code>ln.hd</code> skin, use the command: | |
<syntaxhighlight> | <syntaxhighlight> | ||
root@dm8000:~# opkg remove gp-skin-ln.hd | root@dm8000:~# opkg remove gp-skin-ln.hd |
Version vom 14. September 2013, 16:11 Uhr
- auf Deutsch | - in English |
OPKG (short for Open PacKaGe Management) is a leightweight package management system for embedded systems such as the Dreambox. OPKG is a fork of IPKG and was introduced in the Deambox world since OE 1.6.
The package management in the shell is a powerful tool for the Dreambox, and offers far more possibilities compared to the package management with the remote control. Of course, using the remote control is easy and most of the time adequate. But maybe this article can convince you to give it a try via telnet or SSH.
This article explains how to search / install / remove packages and some more interesting commands which offers OPKG. If you want to learn all options of OPKG, enter following command in the Terminal:
opkg
Inhaltsverzeichnis
- 1 Install packages via internet
- 2 Install local packages
- 3 Weitere interessante Befehle
- 3.1 Paketquellen aktualisieren
- 3.2 Firmware aktualisieren
- 3.3 Befehle verknüpfen
- 3.4 Mehrere Pakete aus den Softwarequellen installieren
- 3.5 Mehrere Pakete deinstallieren
- 3.6 Alle verfügbaren Pakete der Softwarequellen anzeigen
- 3.7 Alle installierten Pakete anzeigen
- 3.8 Installiertes Paket anzeigen
- 3.9 Aktualisierbare Pakete anzeigen
- 3.10 Pakete seitenweise anzeigen
- 3.11 Pakete von einer Web-Adresse installieren
- 3.12 Pakete aus den Softwarequellen herunterladen
- 3.13 Paketinformationen anzeigen
- 3.14 Paket Abhängigkeiten anzeigen
- 3.15 Abhängigkeiten zu einem Paket anzeigen
- 3.16 Paketinstallation simulieren
- 3.17 Paket und seine Abhängigkeiten entfernen
- 3.18 Paket auf hold setzen
- 3.19 Paket freigeben
- 3.20 Auflisten der kompatiblen Paketarchitekturen
- 4 Tipps und Tricks
Install packages via internet
To be able to install a package, the feed defined in the /etc/opkg
, should be updated. If this is not done, the installation will be terminated with the error message: Unknown package ....
. Always enter the following command before installing:
opkg update
Be careful when integrating 3rd party package feeds. If the feed is not available, or not maintained correctly, upgrading the firmware or installing packages will fail! |
Installation
The installation of a package is done with the following command:
opkg install $package_name
$package_name
should be replaced by the correct name. E.g. when installing webadmin, the command is:
root@dm8000:~# opkg install enigma2-plugin-extensions-webadmin Installing enigma2-plugin-extensions-webadmin (4.0) to root... Downloading http://dreamboxupdate.com/opendreambox/2.0.3/ipk/mips32el/enigma2-plugin-extensions-webadmin_4.0_mips32el.ipk. Configuring enigma2-plugin-extensions-webadmin.
The question is, how can you know the correct package name. The name can be found here in the wiki, or in the board. Or you can search with the package management system, as described below.
Search package
There are different ways to search a package. First of all the package management offers the option search
, but unfortunately this option doesn't work quite well. Better results are obtained with the option list
. The following command shows how to use grep
to search for any string.
opkg list | grep search_term
E.g. when searching for webadmin, the search result is as follows. The name of the package, which is needed for the installation, is on the left side. The correct package name for the webadmin
is enigma2-plugin-extensions-webadmin
.
root@dm8000:~# opkg list | grep webadmin enigma2-plugin-extensions-webadmin - 4.0 - Additional plugins for Enigma2
It's also possible to use an Asterisk symbol as wildcard in the search term. The search for *webadmin*
, results iin:
root@dm8000:~# opkg list *webadmin* enigma2-plugin-extensions-webadmin - 4.0 - Additional plugins for Enigma2 Extension for enigma2 webinterface to install Ipkgs telnet client
Constrain the package search
Once you know the naming convention for packages (plugins, skin etc.), the search can be optimized to find faster the desired package. With the following search terms it's easy to filter the package names from the available feeds.
- gemini → shows the different GP3 Addons
- gp-skin → shows all the available GP3 Skins
- gp-icons → shows all the different GP3 Icon Packages
- enigma2-plugin-systemplugins → shows the Enigma2 System Plugins
- enigma2-plugin-extensions → shows Enigma2 extentions
Deinstallation
Removing a package is done like this:
opkg remove $package_name
For $package_name
the correct name must be used. E.g. for removing the webadmin, use the following command:
root@dm8000:~# opkg remove enigma2-plugin-extensions-webadmin
Removing package enigma2-plugin-extensions-webadmin from root...
Install local packages
Packages (e.g. skins, plugin, ets.) which are offered in the IhaD board, but which are not on a feed, can be installed easily by the package management. Of course we don't use the software management, the GP3 File Browser or the eCommander, but we use telnet or SSH.
Download the package and use FTP to copy the file in the directory /tmp
of the Dreambox. Now update the package lists, this way the dependencies (if required) for the package will be resolved and installed. The command is:
opkg update
Please keep in mind, packages from external sources can damage the system! |
Use the correct package architecture, for the different Dreamboxes and used OpenEmbedded versions! |
Installation of one package
Use the following command for the installation.
opkg install /tmp/$file_name_of_the_package
Keep in mind, the complete file name must be specified. E.g. if installing the skin gp-skin-ln.hd_gp32-20130903_all.ipk
, the command is as follows. Use the TAB to complete the file name automatically.
opkg install /tmp/gp-skin-ln.hd_gp32-20130903_all.ipk
Of course it's also possible to use an asterisk as wildcard, this way you don't need to write the complete name. E.g:
opkg install /tmp/gp-skin*
Installation of multiple packages
The installation of multiple packages is also easy, once all files are copied with FTP in the directory /tmp
on the Dreambox. Use the following command to install all packages. By the way, this works also for the installation of one package ;)
opkg install /tmp/*.ipk
Deinstallation
The removal of a package is also done with the package name (without the version and the extention ipk) and the following command:
opkg remove $package_name
Of course the $package_name
needs to be replaced by the correct name. If you want to remove the ln.hd
skin, use the command:
root@dm8000:~# opkg remove gp-skin-ln.hd
Removing package gp-skin-ln.hd from root...
Weitere interessante Befehle
Paketquellen aktualisieren
Aktualisiert die Paketquellen immer vor Paketmanipulationen (z.B. Installationen, Suchen, Herunterladen von Paketen), mit folgendem Befehl:
opkg update
Firmware aktualisieren
Mit dem folgenden Befehl könnt ihr die Dreambox immer auch den neusten Softwarestand (Firmwareaktualisierung) bringen, sofern Aktualisierungen zur Verfügung stehen.
opkg upgrade
Befehle verknüpfen
Mit zwei Und-Zeichen (&&) könnt ihr Befehle miteinander verknüpfen. So wird der zweite Befehl ausgeführt, sobald der erste erfolgreich abgearbeitet ist. Ein sehr oft benutzter Befehl, um Paketlisten und die Firmware zu aktualisieren, ist wie folgt.
opkg update && opkg upgrade
Mehrere Pakete aus den Softwarequellen installieren
opkg install &paketname &paketname &paketname &paketname
Mehrere Pakete deinstallieren
opkg remove &paketname &paketname &paketname &paketname
Alle verfügbaren Pakete der Softwarequellen anzeigen
opkg list
Alle installierten Pakete anzeigen
opkg list-installed
Installiertes Paket anzeigen
Mit folgendem Befehl könnt ihr gezielt nach einem installierten Paket suchen. Erscheint der gesuchte Paketname, inklusive Version, dann ist es installiert. Erfolgt keine Ausgabe, dann ist es nicht installiert oder der Name des Pakets ist falsch geschrieben.
opkg list-installed $paketname
Aktualisierbare Pakete anzeigen
opkg list-upgradable
Pakete seitenweise anzeigen
Pakete könnt ihr seitenweise anzeigen lassen, mittels dem Befehl more
. Benutzt die Leertaste oder ↵ Enter um das auflisten zu beeinflussen.
opkg list | more opkg list-installed | more opkg list-upgradable | more
Pakete von einer Web-Adresse installieren
Pakete können direkt von einer Web-Adresse installiert werden, z.B. mit folgendem Befehl.
opkg install http://www.yyy.com/zzzz/&paketname.ipk
Pakete aus den Softwarequellen herunterladen
opkg download &paketname
Paketinformationen anzeigen
opkg info &paketname
Paket Abhängigkeiten anzeigen
Listet Pakete auf, welche für eine Installation zwingend erforderlich sind.
opkg depends &paketname
Abhängigkeiten zu einem Paket anzeigen
Zeigt die Pakete, welche den &paketnamen als Abhängigkeit benötigen.
opkg whatdepends &paketname
Paketinstallation simulieren
Lädt das Paket und simuliert die Installation. Ideal um zu sehen, ob eine Installation erfolgreich verlaufen wird.
opkg --noaction &paketname
Paket und seine Abhängigkeiten entfernen
Entfernt ein Paket mit seinen Abhängigkeiten, die installiert sind.
opkg --autoremove &paketname
Paket auf hold setzen
Aktualisierung eines Pakets verhindern (durch setzen des hold
flags).
opkg hold &paketname
Paket freigeben
Ein auf hold
gesetztes Paket freigeben.
opkg flag user &paketname
Auflisten der kompatiblen Paketarchitekturen
Zeigt den Inhalt der Datei /etc/opkg/arch.conf
.
opkg print-architecture
Tipps und Tricks
Proxy Server
Wenn ihr über einen Proxy Server Pakete installieren wollt, dann editiert bitte die Konfigurationsdatei /etc/opkg/opkg.conf
. Die Eingaben sollten selbsterklärend sein ;)
Package architecture for local installations
Beachtet, dass je nach Enigma2 Dreamboxtyp und verwendeter Openembedded Version (OE 1.6 / OE 2.0), die korrekten Pakete für manuelle Installation verwendet werden müssen. Ansonsten bricht die Installation mit dem Fehler - ....incompatible with the architectures configured
ab. Wenn ihr also Pakete aus dem Forum holt, dann lest den entsprechenden Beitrag und beachtet immer die Dateiendungen und folgende Punkte.
Plattformunabhängige Pakete
- *.all.ipk
OE 1.6
- *.mipsel.ipk Pakete
OE 2.0
- *.mips32el.ipk für alle Boxtypen, ausser der DM 800HD PVR.
- *.mips32el-nf.ipk nur für DM 800HD PVR
IPK Pakete entpacken
Pakete können am heimischen PC einfach entpackt werden. Unter Linux klappt das ohne Umwege, für Windows Benutzer ist z.B. das Programm 7-Zip interessant. Und für MAC Benutzer das Programm BetterZIP.