Misplaced Pages

Package format

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Type of computer archive

Package format is a type of archive containing computer programs and additional metadata needed by package managers; an instance of this type of archive is called a package. While the archive file format itself may be unchanged, package formats carry additional metadata, such as a manifest file or certain directory layouts. Packages may contain either source code or executable files.

Packages may be converted from one type to another with software such as Alien.

Software supply chain and security

Packages are an important component in managing the security and integrity of the software supply chain. Packages containing executables and configuration can be digitally signed to establish the integrity of running software and protect against tampering.

Package formats that support code signing include .deb (Debian), .msi (Microsoft Windows), .apk (Android) and .ipa (IOS, IPadOS).

Common formats

Specialized formats

Format Consumed by
AIR Adobe AIR
Bottle Homebrew

BSD-based formats

Format Consumed by
.ipa IOS, IPadOS
Ports (BSD) pkgsrc, FreeBSD, OpenBSD
PKG macOS, iOS, PlayStation 3, Solaris, SunOS, UNIX System V, Symbian, BeOS, Apple Newton

Linux-based formats

Format Consumed by
AAB Android
APK (Alpine) Alpine Linux
APK (Android) Android
AppImage Linux distribution-agnostic
Deb Debian and its derivatives, such as Raspberry Pi OS, Kali Linux, Ubuntu, and Linux Mint
ebuild Gentoo Linux
eopkg Solus
Nixpkg Nix, NixOS, Home Manager
Portage Gentoo Linux, ChromeOS
Flatpak Linux distribution-agnostic
.app, .hap HarmonyOS, OpenHarmony, Oniro OS and Linux based Unity Operating System
PISI Pardus
.pkg.tar.zst Arch Linux
PUP and PET Puppy Linux (PUP format is deprecated since version 3.0)
RPM Red Hat Enterprise Linux, Fedora, derivatives such as CentOS, and SUSE Linux Enterprise, openSUSE
Snap Linux distribution-agnostic, mainly developed for Ubuntu

Windows formats

Format Consumed by
APPX and APPXBundle Windows 8 and later, Windows Phone
Windows Installer package / MSI Windows Installer on Microsoft Windows

Generic formats

Arch Linux's Pacman and Slackware use 'tar' archives with generic naming but specific internal structures.

References

  1. Justin Angelo Cappos, Stork: Secure Package Management for VM Environments, ProQuest, 2008, p. 128;
  2. Cooper, David; Feldman, Larry; Witte, Gregory (May 23, 2018). "Protecting Software Integrity Through Code Signing". National Institute of Standards and Technology. ITL Bulletin.
  3. "Ports - Working with Ports". OpenBSD.org.
  4. "Alpine package format - Alpine Linux". wiki.alpinelinux.org. Retrieved May 19, 2016.
  5. "InstallingSoftware - Community Ubuntu Documentation". Help.ubuntu.com. Retrieved April 24, 2013.
  6. "ebuild". Retrieved July 29, 2015.
  7. "Basics to Package Management". Retrieved May 1, 2020.
  8. "Using Portage to Manage Packages in Gentoo". linode.com. July 15, 2021.
  9. "rpm - Trac". Retrieved September 29, 2014.
  10. "App packaging". Retrieved September 29, 2014.
  11. "makepkg.conf(5) Manual Page".
  12. "The Slackware Linux Project: Configuration Help". Retrieved September 29, 2014.
Archive formats
Archiving only
Compression only
Archiving and compression
Software packaging and distribution
Document packaging and distribution
Linux package management systems
dpkg
RPM
Embedded systems
Distribution-agnostic
Others (binary)
Others (source)
Front-ends
Related topics
Linux
Linux kernel
Controversies
Distributions
Organizations
Adoption
Media
Professional related certifications
Categories: