Check out my first novel, midnight's simulacra!
Updating FreeBSD: Difference between revisions
m (1 revision) |
|||
(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. | |||
===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 48: | Line 58: | ||
Consult the toplevel Makefile and the FreeBSD Handbook for more information. | 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=== | |||
* <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 22:29, 17 January 2021
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.
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.