Check out my first novel, midnight's simulacra!

Updating FreeBSD: Difference between revisions

From dankwiki
(add info on adding 32 bit libs)
 
(5 intermediate revisions by the same user not shown)
Line 9: Line 9:


==Base system sources==
==Base system sources==
Use <tt>freebsd-update</tt>, which comes as part of the Base System.
* <tt>freebsd-update fetch</tt>
* <tt>freebsd-update -r NEWVERSION upgrade</tt>
The installer (/stand/sysinstall) can unpack the src distribution wholesale or piecemeal (see "source collections" below) into your /usr/src. cvsup(1) or cvs(1) can be used to both check out base system sources and keep them up-to-date. CVS is part of the base FreeBSD system, whereas CVSup is a port. Otherwise, however, CVSup is generally superior; it is faster, generates less network load and disk I/O, and understands source collections.
The installer (/stand/sysinstall) can unpack the src distribution wholesale or piecemeal (see "source collections" below) into your /usr/src. cvsup(1) or cvs(1) can be used to both check out base system sources and keep them up-to-date. CVS is part of the base FreeBSD system, whereas CVSup is a port. Otherwise, however, CVSup is generally superior; it is faster, generates less network load and disk I/O, and understands source collections.


Line 16: Line 20:
==Ports collection==
==Ports collection==
The installer (/stand/sysinstall) can unpack the ports distribution into /usr/ports. portsnap(8), cvsup(1) and cvs(1) can all be used to both check out the ports collection and keep it up-to-date. CVS is part of the base FreeBSD system, whereas CVSup and portsnap are ports. Of these, portsnap is preferred, due to its superior security.
The installer (/stand/sysinstall) can unpack the ports distribution into /usr/ports. portsnap(8), cvsup(1) and cvs(1) can all be used to both check out the ports collection and keep it up-to-date. CVS is part of the base FreeBSD system, whereas CVSup and portsnap are ports. Of these, portsnap is preferred, due to its superior security.
''UPDATE'': as of at least FreeBSD 9.0, portsnap is part of the base system, and needn't be installed from ports itself. Furthermore, it comes with a sensible default configuration file. Thus,
<code>portsnap fetch extract</code>
is sufficient to update the ports tree on a fresh install.
===poudriere===
As of FreeBSD 14, portsnap has been removed. Use <tt>poudriere</tt>. Create the ports tree:
* <tt>poudriere ports -c</tt>
Update it:
* <tt>poudriere ports -u</tt>
But <tt>portupgrade</tt> is then still used to actually rebuild ports.


===Portsnap===
===Portsnap===
The first time portsnap(8) is run, use the following method: <tt>portsnap fetch extract</tt> (on older versions of portsnap, you'll also need append a configuration file argument via <tt>-f</tt>; the default works just fine for most cases, ie <tt>portsnap fetch extract -f /usr/local/etc/portsnap.conf.sample</tt>). Following this (time-consuming) run, <tt>portsnap fetch upgrade</tt> is sufficient to pull in package updates (the same rule about <tt>-f</tt> applies).
The first time portsnap(8) is run, use the following method: <tt>portsnap fetch extract</tt> (on older versions of portsnap, you'll also need append a configuration file argument via <tt>-f</tt>; the default works just fine for most cases, ie <tt>portsnap fetch extract -f /usr/local/etc/portsnap.conf.sample</tt>). Following this (time-consuming) run, <tt>portsnap fetch upgrade</tt> is sufficient to pull in package updates (the same rule about <tt>-f</tt> applies).
This can be followed with <tt>portupgrade -ai</tt> to actually rebuild ports.


===Cvsup===
===Cvsup===
Line 54: Line 71:
* make install32
* make install32
* ldconfig -32 /usr/lib32
* ldconfig -32 /usr/lib32
===Binary updates===
* <tt>freebsd-update fetch</tt>
* <tt>freebsd-update install</tt>


==Installed ports==
==Installed ports==
The list of ports installed on the machine can be displayed with pkg_info. Ports generally confine themselves to /usr/local. After syncing the ports collection, installed ports can be rebuilt and upgraded automatically using portupgrade(1) or the make(1) mechanism of the ports collection. Use portsclean -L to clean old, duplicate and/or orphaned shared libraries. I typically use <tt>portupgrade -uap</tt> to rebuild all ports, and make new packages as well.
The list of ports installed on the machine can be displayed with pkg_info. Ports generally confine themselves to /usr/local. After syncing the ports collection, installed ports can be rebuilt and upgraded automatically using portupgrade(1) or the make(1) mechanism of the ports collection. Use portsclean -L to clean old, duplicate and/or orphaned shared libraries. I typically use <tt>portupgrade -uap</tt> to rebuild all ports, and make new packages as well.
[[CATEGORY:FreeBSD]]

Latest revision as of 23:52, 14 January 2025

There's four parts of a FreeBSD machine which must be individually maintained: base system sources (/usr/src), the ports collection (/usr/ports), the installed system (/), and the installed ports (/usr/local).

Tools referenced, and where to get them

  • cvs: base system
  • cvsup: net/cvsup or net/cvsup-without-gui
  • portsnap: ports-mgmt/portsnap (base system in 5-RELENG+)
  • portupgrade: ports-mgmt/portupgrade
  • portsclean: base system

Base system sources

Use freebsd-update, which comes as part of the Base System.

  • freebsd-update fetch
  • freebsd-update -r NEWVERSION upgrade

The installer (/stand/sysinstall) can unpack the src distribution wholesale or piecemeal (see "source collections" below) into your /usr/src. cvsup(1) or cvs(1) can be used to both check out base system sources and keep them up-to-date. CVS is part of the base FreeBSD system, whereas CVSup is a port. Otherwise, however, CVSup is generally superior; it is faster, generates less network load and disk I/O, and understands source collections.

The base system sources are broken up into source collections:

  • src-all: The master source collection, it includes all sources for the base system.

Ports collection

The installer (/stand/sysinstall) can unpack the ports distribution into /usr/ports. portsnap(8), cvsup(1) and cvs(1) can all be used to both check out the ports collection and keep it up-to-date. CVS is part of the base FreeBSD system, whereas CVSup and portsnap are ports. Of these, portsnap is preferred, due to its superior security.

UPDATE: as of at least FreeBSD 9.0, portsnap is part of the base system, and needn't be installed from ports itself. Furthermore, it comes with a sensible default configuration file. Thus, portsnap fetch extract is sufficient to update the ports tree on a fresh install.

poudriere

As of FreeBSD 14, portsnap has been removed. Use poudriere. Create the ports tree:

  • poudriere ports -c

Update it:

  • poudriere ports -u

But portupgrade is then still used to actually rebuild ports.

Portsnap

The first time portsnap(8) is run, use the following method: portsnap fetch extract (on older versions of portsnap, you'll also need append a configuration file argument via -f; the default works just fine for most cases, ie portsnap fetch extract -f /usr/local/etc/portsnap.conf.sample). Following this (time-consuming) run, portsnap fetch upgrade is sufficient to pull in package updates (the same rule about -f applies).

This can be followed with portupgrade -ai to actually rebuild ports.

Cvsup

To use the less preferred cvsup method (madness, because it is less secure and uses 10 times the bandwidth of portsnap) create a file /usr/local/etc/ports-supfile with the following contents (based off /usr/share/examples/cvsup/ports-supfile):

* default base=/var/db
* default prefix=/usr
* default release=cvs tag=.
* default delete use-rel-suffix
* default compress
ports-all

and then run cvsup -g -L 2 /usr/local/etc/ports-supfile to update the Ports Collection.

FreeBSD-4.x gotcha

The most recent FreeBSD ports collections will not work on FreeBSD 4.x. You will need to check out something older than 2007. No method is known to specify this for portsnap(8), but a working methodology for cvsup under 4.10 is to add *default date=2006.12.31.00.00.00 to your ports-supfile.

Installed system

Configure /etc/make.conf, based off /etc/defaults/make.conf and the make.conf(5) man page.

  • make buildworld
  • make buildkernel
  • make installkernel
  • reboot
  • mergemaster -p
  • make installworld
  • make delete-old
  • mergemaster
  • reboot
  • make delete-old-libs

Consult the toplevel Makefile and the FreeBSD Handbook for more information.

Adding 32-bit libs to an amd64 system

  • ensure EMUL_32BIT is defined in make.conf
  • make build32
  • make install32
  • ldconfig -32 /usr/lib32

Binary updates

  • freebsd-update fetch
  • freebsd-update install

Installed ports

The list of ports installed on the machine can be displayed with pkg_info. Ports generally confine themselves to /usr/local. After syncing the ports collection, installed ports can be rebuilt and upgraded automatically using portupgrade(1) or the make(1) mechanism of the ports collection. Use portsclean -L to clean old, duplicate and/or orphaned shared libraries. I typically use portupgrade -uap to rebuild all ports, and make new packages as well.