- libpkg
- pkgng package format
- Local Database
- Installation of packages
- Upgrades of packages
- Deletion of packages
- pkgng in Ports
- A quick usage introduction to pkgng
- Installing pkgng
- Getting help on the commands usage
- Installing packages
- Querying the local package database
- Working with a remote package repository
- Working with multiple remote package repositories
- Updating remote repositories
- Searching in remote package repositories
- Installing from remote repositories
- Backing up your package database
- Creating a package repository
- Additional resources
pkgng is built on top of libpkg, a new library to interface with package registration backends. It abstracts package management details such as registration, remote repositories, package creation, updating, etc.
pkgng package format is a tar archive which can be raw, or use the following compression: gz, bzip2 and xz, defaulting in xz format.
The tar itself is composed in two types of elements:
- the special files at the beginning of the archive, starting with a "+"
- the data.
pkgng supports two files for metadata:
- +MANIFEST
- +MTREE_DIRS (optional)
The manifest is in YAML format, it contains all the information about the package:
name: foo
version: 1.0
origin: category/foo
comment: this is foo package
arch: i386
www: http://www.foo.org
maintainer: foo@bar.org
prefix: /usr/local
licenselogic: or
licenses: [MIT, MPL]
flatsize: 482120
users: [USER1, USER2]
groups: [GROUP1, GROUP2]
options: { OPT1: off, OPT2: on }
desc: |-
This is the descrpition
Of foo
A component of bar
categories: [bar, plop]
deps:
libiconv: {origin: converters/libiconv, version: 1.13.1_2}
perl: {origin: lang/perl5.12, version: 5.12.4 }
files:
/usr/local/bin/foo: 'sha256sum'
/usr/local/bin/i_am_a_link: '-'
/usr/local/share/foo-1.0/foo.txt: 'sha256sum'
dirs:
- /usr/local/share/foo-1.0
scripts:
post-install: |-
#!/bin/sh
echo post-install
pre-install: |-
#!/bin/sh
echo pre-install
Valid scripts are:
- pre-install
- post-install
- install
- pre-deinstall
- post-deinstall
- deinstall
- pre-upgrade
- post-upgrade
- upgrade
Script MUST be in sh format nothing else would work. shebang is not necessary.
When the manifest is read by pkg_create files and dirs accept another format:
files:
/usr/local/bin/foo, 'sha256sum'
/usr/local/bin/bar: {sum: 'sha256sum', uname: baruser, gname: foogroup, perm: 0644 }
dirs:
- /usr/local/share/foo-1.0
- /path/to/directory: {uname: foouser, gname: foogroup, perm: 0755}
This allows to override the users, groups and mode of files and directories during package creation, like for example this allows to create a package containing root files without being packaged by the root user.
This is optional, this is used by the package the same way it is done by the legacy tools which means the MTREE is extracted in prefix before each installation.
In the future we hope that mtree will be deprecated in favour of a hier package or in single MTREE that won't be customisable in per package basis and because pkgng supports packing of empty directories, per package MTREE makes no sense any more.
Once a package is installed, it is registered to a SQLite database.
The SQLite database allow fast queries and ACID transactions. It also allow to query the reverse dependencies without a +REQUIRED_BY hack.
In order to save space the MTREE is only stored once, which save 18K per installed package.
pkgng supports a register
command to register packages into the SQLite
database from the ports. The register command can execute the install script,
show pkg-message, ...
pkg add
can install a package archive from the local disk, or from a
remote FTP/HTTP server.
If only a package name is given, it will search the repository catalogue and download and install the package if it exists. The dependencies will be downloaded and installed first.
This is possible because we have the dependency information in the catalogue of the remote repository.
pkg add
will check if the user attempts to install a package built for another
arch or release.
pkgng will also support upgrades of binary packages.
pkgng will compare the versions of installed packages and those available on the repository. It will compute the proper update order and apply them.
Directory leftovers are automatically removed if they are not in the MTREE.
pkgng-1.0 release was committed to the the ports tree on 30th August 2012, and a series of further releases are planned. To install the latest release version:
$ make -C /usr/ports/ports-mgmt/pkg install clean
$ echo "WITH_PKGNG=yes" >> /etc/make.conf
In this section of the document we will try to give a quick and dirty introduction on the practical usage of pkgng - installing packages, searching in remote package repositories, updating remote package repositories and installing from them, etc.
In order to build pkgng from source, you will need to have Gnu autotools installed.
# pkg install autoconf automake libtool
The next thing to do is to get the pkgng sources installed on your machine. You can grab a development snapshot of pkgng from the pkgng Github repository
To get the latest version of pkgng from the Git repo, just clone it:
% git clone https://github.com/freebsd/pkg
Or you can take an already tagged release of pkgng from the above web page as well.
Just open your browser and download the release you want.
Once you have the pkgng sources, installing it is fairly easy:
% cd pkgng
% ./autogen.sh
% ./configure
% make
# make install
Now you should have the latest pkgng installed on your system.
If you're on a 9.x system or earler and did not have a release version of pkg(8) installed previously, you will need to run the pkg2ng script. This is only necesaary when converting your system from the old pkg_tools style packages.
In order to register your installed packages to pkgng, execute the commands below:
# cd pkgng/ports
# sh pkg2ng
Otherwise, running any pkg(8) command that will attempt to write to the local package database will automatically apply any schema updates. Be aware that these may not be backwards compatible -- although usually you should see no more than a warning message if you try and run an older version of pkg(8) against a newer database schema.
In order to get help on any of the pkgng commands you should use the pkg help <command>
command, which will take the man page of the specified command.
In order to get the available commands in pkgng, just execute pkg help
# pkg help
# pkg help <command>
Packages can be installed from either a local directory on the file system or from a remote location using the FTP/HTTP protocol in order to fetch the packages.
In order to install the package foo-1.2.3 from a local directory, you will use a command similar to the following below:
# pkg add /path/to/packages/foo-1.2.3.txz
You need to make sure that all dependencies of foo-1.2.3 are also in the directory, which you use in order to install the package.
You can also install the package foo-1.2.3 from a remote location using the FTP/HTTP protocol. In order to do that you could use a command similar to the following:
# pkg add http://example.org/pkgng-repo/foo-1.2.3.txz
This will also install the package foo-1.2.3 and it's dependencies from the remote server example.org using the HTTP protocol for fetching the packages.
For more information on installing packages on your FreeBSD system, please refer to pkg-add(1)
In order to get information about installed packages you need to use the pkg info
command.
pkg info
will query the local package database and display you information about the
package you are intrested in.
To list all install/registered packages in the local database, you will use the following command:
# pkg info -a
For more information on querying the local package database, please refer to pkg-info(1) man page.
pkgng is able to work with remote package repositories as well.
A remote package repository contains a collection of packages which can be fetched, searched and installed into your systems.
In order to use a remote repository you need to define the PACKAGESITE environment variable, so that it points to a remote location, which contains packages that can be installed by pkgng, or set PACKAGESITE in the pkg.conf(5) configuration file.
In order to work with a single remote package repository, you would define PACKAGESITE to your remote server with packages, like for example (or use ${LOCALBASE}/etc/pkg.conf* to set it there):
TCSH users:
# setenv PACKAGESITE http://example.org/pkgng-repo/
SH users:
# export PACKAGESITE=http://example.org/pkgng-repo/
Then fetch the repository catalogue using the command:
# pkg update
This would fetch the remote package database to your local system. Now in order to install
packages from the remote repository, you would use the pkg install
command:
# pkg install zsh cfengine3
Note: With pkg-1.1 the setup changes significantly. See pkg.conf(5) for more information.
pkgng is also able to work with multiple remote repositories. In the previous section we are using only a single remote repository, which is defined by the PACKAGESITE option.
In order to be able to work with multiple remote repositories and instead of changing PACKAGESITE each time, you can tell pkg(8) to work in multi-repos mode as well.
To do this, simply enable multi-repos in pkg.conf(5) like this:
# echo "PKG_MULTIREPOS : YES" >> /usr/local/etc/pkg.conf
The next thing is to define your remote repositories in the pkg.conf(5) file.
Below is a part from example configuration file, which defines three remote repositories - repo1, repo2 and the default repository.
repos:
default : http://example.org/pkgng/
repo1 : http://somewhere.org/pkgng/repo1/
repo2 : http://somewhere.org/pkgng/repo2/
It is important that you always define a default repository - this is the repository that is being
used when no remote repositories are specified via the -r <repo>
flag.
Next, fetch all the repository catalogues:
# pkg update
And now you can install from the remote repositories using the pkg install
command like this:
# pkg install -r repo1 zsh cfengine3
Example repo entries in pkg.conf(5) would look like this:
default : http://example.com/repos
second : http://somewhere.com/repos
If you want to mirror the repositories and make them public as well, please get in contact with us, so that we can add your repository to the list as well :)
The first thing to do when working with remote repositories is to update from them.
Updating remote repositories is done by the pkg update
command.
If PACKAGESITE environment variable is defined to point to a remote package repository then only this repository will be updated. Otherwise all remote repositories defined in the /etc/pkg/repositories file will be updated.
So, to update your remote repositories, you would execute this command:
# pkg update
For more information on the remote repositories, please refer to pkg-update(1).
You can search in the remote package repositories using the pkg search
command.
In order to search in multiple package repositories the environment variable
PACKAGESITE should NOT be defined, in which case pkg search
will query
the remote package databases found in the /etc/pkg/repositories file.
An example search for a package could be done like this:
# pkg search -x apache
For more information on the repositories search, please refer to pkg-search(1)
In order to install a package from a remote repository you need to set the PACKAGESITE environment variable to point to the remote server.
If PACKAGESITE is not defined then the installation process will use multiple repositories as defined in the /etc/pkg/repositories file.
During installation from multiple repositories the first repository that is found to has the package is the first one that pkgng will use during the installation. If that repository is not accessible for some reason, then the next repository which contains the package is the one that is tried.
The process continues until the package is fetched and installed, or all remote repositories fail to fetch the package.
Remote installations of packages using pkgng are done by the pkg install
command.
Here's an example installation of few packages:
# pkg install www/apache22
# pkg install zsh
# pkg install perl-5.12.4
Or you could also install the packages using only one command, like this:
# pkg install www/apache22 zsh perl-5.12.4
For more information on the remote package installs, please refer to pkg-install(1)
It is a good idea that you backup your local package database on regular basis.
In order to backup the local package database, you should use the pkg backup
command.
# pkg backup -d /path/to/pkgng-backup.dump
The above command will create a compressed tar archive file of your local package database in /path/to/pkgng-backup.dump.txz
For more information on backing up your local package database, please refer to pkg-backup(1)
You can also use pkgng, so that you create a package repository.
In order to create a package repository you need to use the pkg create
command.
Here's an example that will create a repository of all your currently installed packages:
# cd /path/with/enough/space
# pkg create -a
# pkg repo .
The above commands will create a repository of all packages on your system.
Now you can share your repo with other people by letting them know of your repository :)
-
The Git repository of pkgng is hosted on Github
-
The pkgng Wiki page
In order to get in contact with us, you can find us in the #pkgng@FreeNode IRC channel.
If you hit a bug when using pkgng, you can always submit an issue in the pkgng issue tracker.