Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 22 Apr 2010 18:48:43 +0000
From:      "b. f." <bf1783@googlemail.com>
To:        freebsd-hackers@FreeBSD.org
Subject:   Re: regenerating /var/db/pkg
Message-ID:  <v2sd873d5be1004221148r1f1c653fr608bae6341439beb@mail.gmail.com>

next in thread | raw e-mail | index | archive | help
Doug Barton wrote:
>On 4/20/2010 7:11 PM, Aryeh M. Friedman wrote:
>> I acciddentally rm'ed my /var/db/pkg and want to know is it possible to
>> rgenerate it (I have portmaster and portupgrade installed)
>
>Portmaster certainly can't do this, it uses the information from
>/var/db/pkg. I'm not sure if portupgrade can do it or not.
>
>Your most likely course of success is to generate a list of ports that
>you know you're using ("root" and "leaf" ports in portmaster
>terminology), back up any config or other key files from /usr/local,
>then delete everything and reinstall.

With regard to portupgrade, if your pkgdb file is intact, you should
be able to reconstruct /var/db/pkg, although it may not be very
convenient to do so. Unfortunately, by default the pkgdb file is
/var/db/pkg/pkgdb.db, so it is often wiped out along with the rest of
/var/db/pkg.  However, if it is intact, make sure you first back it up
before attempting to use it's contents, because most of the pkgtools
attempt to edit it to correspond with the current state of /var/db/pkg
(performing the equivalent of pkgdb -u/-aF) when invoked.  You may be
able to disable this editing via the "-O" flag, but I haven't checked
this lately.

If you have a list of installed packages, and a corresponding ports
tree, you could reconstruct most but probably not all of /var/db/pkg
by running "make generate-plist fake-pkg" in the ports tree origin of
each package (if you built the packages with non-default options, you
should have an intact /var/db/ports for this to fully work).   The
directories for packages with dynamic plists might not be fully
restored without rebuilding the ports, but this may be enough for a
first pass.  You could then prune or account for files in
PREFIX/LOCALBASE that aren't listed as belonging to a registered
package, via something like:

find /usr/local -type f -print0 | xargs -0 pkg_which -v | fgrep '?'

or with something similar using "pkg_info -W..." instead of "pkg_which -v".

Alternatively, if you have backups of all the installed packages, or
can obtain them from a server, you could use their packing lists to
restore /var/db/pkg.

But as Doug suggests, a full cleanup of PREFIX/LOCALBASE and
reinstallation of all leaf packages may be easier than a
reconstruction of /var/db/pkg.

b.



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?v2sd873d5be1004221148r1f1c653fr608bae6341439beb>