xref: /freebsd/sbin/bectl/bectl.8 (revision edf8578117e8844e02c0121147f45e4609b30680)
1.\"
2.\" SPDX-License-Identifier: BSD-2-Clause
3.\"
4.\" Copyright (c) 2017 Kyle J. Kneitinger <kyle@kneit.in>
5.\"
6.\" Redistribution and use in source and binary forms, with or without
7.\" modification, are permitted provided that the following conditions
8.\" are met:
9.\" 1. Redistributions of source code must retain the above copyright
10.\"    notice, this list of conditions and the following disclaimer.
11.\" 2. Redistributions in binary form must reproduce the above copyright
12.\"    notice, this list of conditions and the following disclaimer in the
13.\"    documentation and/or other materials provided with the distribution.
14.\"
15.\"
16.\"     @(#)be.1
17.\"
18.Dd October 5, 2023
19.Dt BECTL 8
20.Os
21.Sh NAME
22.Nm bectl
23.Nd Utility to manage boot environments on ZFS
24.Sh SYNOPSIS
25.Nm
26.Op Fl h\&?
27.Nm
28.Op Fl r Ar beroot
29.Cm activate
30.Op Fl t | Fl T
31.Ar beName
32.Nm
33.Op Fl r Ar beroot
34.Cm check
35.Nm
36.Op Fl r Ar beroot
37.Cm create
38.Op Fl r
39.Op Fl e Brq Ar nonActiveBe | Ar beName Ns Cm @ Ns Ar snapshot
40.Ar newBeName
41.Nm
42.Op Fl r Ar beroot
43.Cm create
44.Op Fl r
45.Ar beName@snapshot
46.Nm
47.Op Fl r Ar beroot
48.Cm destroy
49.Op Fl \&Fo
50.Ar beName Ns Op Cm @ Ns Ar snapshot
51.Nm
52.Op Fl r Ar beroot
53.Cm export
54.Ar sourceBe
55.Nm
56.Op Fl r Ar beroot
57.Cm import
58.Ar targetBe
59.Nm
60.Op Fl r Ar beroot
61.Cm jail
62.Op Fl bU
63.Oo Bro Fl o Ar key Ns Cm = Ns Ar value | Fl u Ar key Brc Oc Ns ...
64.Ar beName
65.Op Ar utility Op Ar argument ...
66.Nm
67.Op Fl r Ar beroot
68.Cm list
69.Op Fl aDHs
70.Op Fl c Ar property
71.Op Fl C Ar property
72.Oo Bro Fl c Ar property | Fl C Ar property Brc Oc
73.Nm
74.Op Fl r Ar beroot
75.Cm mount
76.Ar beName
77.Op Ar mountpoint
78.Nm
79.Op Fl r Ar beroot
80.Cm rename
81.Ar origBeName
82.Ar newBeName
83.Nm
84.Op Fl r Ar beroot
85.Brq Cm ujail | unjail
86.Brq Ar jailId | jailName | beName
87.Nm
88.Op Fl r Ar beroot
89.Brq Cm umount | unmount
90.Op Fl f
91.Ar beName
92.Sh DESCRIPTION
93The
94.Nm
95command is used to setup and interact with ZFS boot environments, which are
96bootable clones of datasets.
97.Pp
98A boot environment allows the system to be upgraded, while preserving the
99pre-upgrade system environment.
100.Pp
101.Nm
102itself accepts an
103.Fl r
104flag specified before the command to indicate the
105.Ar beroot
106that should be used as the boot environment root, or the dataset whose children
107are all boot environments.
108Normally this information is derived from the bootfs property of the pool that
109is mounted at
110.Pa / ,
111but it is useful when the system has not been booted into a ZFS root or a
112different pool should be operated on.
113For instance, booting into the recovery media and manually importing a pool from
114one of the system's resident disks will require the
115.Fl r
116flag to work.
117.Ss Supported Subcommands and Flags
118.Bl -tag -width activate
119.It Xo
120.Fl h |
121.Fl \&?
122.Xc
123Print usage information.
124.It Xo
125.Cm activate
126.Op Fl t | Fl T
127.Ar beName
128.Xc
129Activate the given
130.Ar beName
131as the default boot filesystem.
132If the
133.Fl t
134flag is given, this takes effect only for the next boot.
135Flag
136.Fl T
137removes temporary boot once configuration.
138Without temporary configuration, the next boot will use zfs dataset specified
139in boot pool
140.Ar bootfs
141property.
142.It Xo
143.Cm check
144.Xc
145Performs a silent sanity check on the current system.
146If boot environments are supported and used,
147.Nm
148will exit with a status code of 0.
149Any other status code is not currently defined and may, in the future, grow
150special meaning for different degrees of sanity check failures.
151.It Xo
152.Cm create
153.Op Fl r
154.Op Fl e Brq Ar nonActiveBe | Ar beName Ns Cm @ Ns Ar snapshot
155.Ar newBeName
156.Xc
157Create a new boot environment named
158.Ar newBeName .
159.Pp
160If the
161.Fl r
162flag is given, a recursive boot environment will be made.
163See
164.Sx Boot Environment Structures
165for a discussion on different layouts.
166.Pp
167If the
168.Fl e
169flag is specified, the new environment will be cloned from the given
170.Ar nonActiveBe
171or
172.Ar beName Ns Cm @ Ns Ar snapshot .
173Otherwise, the new environment will be created from the currently booted
174environment.
175.Pp
176If
177.Nm
178is creating from another boot environment, a snapshot of that boot environment
179will be created to clone from.
180.It Xo
181.Cm create
182.Op Fl r
183.Ar beName@snapshot
184.Xc
185Create a snapshot of the boot environment named
186.Ar beName .
187.Pp
188If the
189.Fl r
190flag is given, a recursive snapshot of the boot environment will be created.
191A snapshot is created for each descendant dataset of the boot environment.
192See
193.Sx Boot Environment Structures
194for a discussion on different layouts.
195.Pp
196No new boot environment is created with this subcommand.
197.It Xo
198.Cm destroy
199.Op Fl \&Fo
200.Ar beName Ns Op Cm @ Ns Ar snapshot
201.Xc
202Destroy the given
203.Ar beName
204boot environment or
205.Ar beName Ns Cm @ Ns Ar snapshot
206snapshot without confirmation, unlike in
207.Xr beadm 1 .
208Specifying
209.Fl F
210will automatically unmount without confirmation.
211.Pp
212By default,
213.Nm
214will warn that it is not destroying the origin of
215.Ar beName .
216The
217.Fl o
218flag may be specified to destroy the origin as well.
219.It Cm export Ar sourceBe
220Export
221.Ar sourceBe
222to
223.Xr stdout 4 .
224.Xr stdout 4
225must be piped or redirected to a file.
226.It Cm import Ar targetBe
227Import
228.Ar targetBe
229from
230.Xr stdin 4 .
231.It Xo
232.Cm jail
233.Op Fl bU
234.Oo Bro Fl o Ar key Ns Cm = Ns Ar value | Fl u Ar key Brc Oc Ns ...
235.Ar beName
236.Op Ar utility Op Ar argument ...
237.Xc
238Create a jail of the given boot environment.
239Multiple
240.Fl o
241and
242.Fl u
243arguments may be specified.
244.Fl o
245will set a jail parameter, and
246.Fl u
247will unset a jail parameter.
248.Pp
249By default, jails are created in interactive mode and
250.Pa /bin/sh
251is
252executed within the jail.
253If
254.Ar utility
255is specified, it will be executed instead of
256.Pa /bin/sh .
257The jail will be destroyed and the boot environment unmounted when the command
258finishes executing, unless the
259.Fl U
260argument is specified.
261.Pp
262The
263.Fl b
264argument enables batch mode, thereby disabling interactive mode.
265The
266.Fl U
267argument will be ignored in batch mode.
268.Pp
269The
270.Va name ,
271.Va host.hostname ,
272and
273.Va path
274must be set, the default values are specified below.
275.Pp
276All
277.Ar key Ns Cm = Ns Ar value
278pairs are interpreted as jail parameters as described in
279.Xr jail 8 .
280The following default parameters are provided:
281.Bl -column "allow.mount.devfs" ""
282.It Va allow.mount Ta Cm true
283.It Va allow.mount.devfs Ta Cm true
284.It Va enforce_statfs Ta Cm 1
285.It Va name Ta Set to jail ID.
286.It Va host.hostname Ta Va bootenv
287.It Va path Ta Set to a path in Pa /tmp
288generated by
289.Xr libbe 3 .
290.El
291.Pp
292All default parameters may be overwritten.
293.It Xo
294.Cm list
295.Op Fl aDHs
296.Oo Bro Fl c Ar property | Fl C Ar property Brc Oc
297.Xc
298.Pp
299Display all boot environments.
300The
301.Em Active
302field indicates whether the boot environment is active now
303.Pq Em \&N ;
304active on reboot
305.Pq Em \&R ;
306is used on next boot once
307.Pq Em \&T ;
308or combination of
309.Pq Em \&NRT .
310.Bl -tag -width indent
311.It Fl a
312Display all datasets.
313.It Fl D
314Display the full space usage for each boot environment, assuming all
315other boot environments were destroyed.
316.It Fl H
317Used for scripting.
318Do not print headers and separate fields by a single tab instead of
319arbitrary white space.
320.It Fl s
321Display all snapshots as well.
322.It Fl c Ar property
323Sort boot environments by the given ZFS dataset property.
324The following properties are supported:
325.Pp
326.Bl -tag -width 4n -offset indent -compact
327.It name (the default)
328.It creation
329.It origin
330.It used
331.It usedbydataset
332.It usedbyrefreservation
333.It usedbysnapshots
334.El
335.Pp
336Short forms usedds, usedrefreserv and usedsnap are also supported.
337.It Fl C Ar property
338Same as the
339.Fl c
340option, but displays in descending order.
341.El
342.Pp
343The
344.Fl D
345option is ignored when either the
346.Fl s
347or
348.Fl a
349option is used.
350.It Cm mount Ar beName Op Ar mountpoint
351Mount the given boot environment.
352.Pp
353If a nonexistent
354.Ar mountpoint
355is given:
356.Nm
357will make the directory, including intermediate directories as required.
358.Pp
359If no
360.Ar mountpoint
361is given:
362.Nm
363will make a directory such as
364.Pa be_mount.c6Sf
365in
366.Pa /tmp .
367Randomness in the last four characters of the directory name will prevent
368mount point conflicts.
369Unmount of an environment, followed by mount of the same environment
370without giving a
371.Ar mountpoint ,
372will result in a different randomly-named mountpoint.
373.It Cm rename Ar origBeName newBeName
374Rename the given
375.Ar origBeName
376to the given
377.Ar newBeName .
378The boot environment will not be unmounted in order for this rename to occur.
379.It Cm ujail Brq Ar jailId | jailName | beName
380.It Cm unjail Brq Ar jailId | jailName | beName
381Destroy the jail created from the given boot environment.
382.It Xo
383.Cm umount
384.Op Fl f
385.Ar beName
386.Xc
387.It Xo
388.Cm unmount
389.Op Fl f
390.Ar beName
391.Xc
392Unmount the given boot environment, if it is mounted.
393Specifying
394.Fl f
395will force the unmount if busy.
396.Pp
397Unmount will not remove the mount point.
398.El
399.Ss Boot Environment Structures
400The traditional
401.Fx
402boot environment layout, as created by the Auto ZFS option to
403.Xr bsdinstall 8 ,
404is a
405.Dq shallow
406boot environment structure, where boot environment datasets do not have any
407directly subordinate datasets.
408Instead, they're organized off in
409.Pa zroot/ROOT ,
410and they rely on datasets elsewhere in the pool having
411.Dv canmount
412set to
413.Dv off .
414For instance, a simplified pool may be laid out as such:
415.Bd -literal -offset indent
416% zfs list -o name,canmount,mountpoint
417NAME			CANMOUNT	MOUNTPOINT
418zroot
419zroot/ROOT		noauto		none
420zroot/ROOT/default	noauto		none
421zroot/home		on		/home
422zroot/usr		off		/usr
423zroot/usr/src		on		/usr/src
424zroot/var		off		/var
425.Ed
426.Pp
427In that example,
428.Pa zroot/usr
429has
430.Dv canmount
431set to
432.Dv off ,
433thus files in
434.Pa /usr
435typically fall into the boot environment because this dataset is not mounted.
436.Pa zroot/usr/src
437is mounted, thus files in
438.Pa /usr/src
439are not in the boot environment.
440.Pp
441The other style of boot environments in use, frequently called
442.Dq deep boot environments ,
443organizes some or all of the boot environment as subordinate to the boot
444environment dataset.
445For example:
446.Bd -literal -offset indent
447% zfs list -o name,canmount,mountpoint
448NAME				CANMOUNT	MOUNTPOINT
449zroot
450zroot/ROOT			noauto		none
451zroot/ROOT/default		noauto		none
452zroot/ROOT/default/usr		noauto		/usr
453zroot/ROOT/default/usr/local	noauto		/usr/local
454zroot/var			on		/var
455.Ed
456.Pp
457Note that the subordinate datasets now have
458.Dv canmount
459set to
460.Dv noauto .
461These are more obviously a part of the boot environment, as indicated by their
462positioning in the layout.
463These subordinate datasets will be mounted by the
464.Dv zfsbe
465.Xr rc 8
466script at boot time.
467In this example,
468.Pa /var
469is excluded from the boot environment.
470.Pp
471.Nm
472subcommands that have their own
473.Fl r
474operate on this second,
475.Dq deep
476style of boot environment, when the
477.Fl r
478flag is set.
479A future version of
480.Nm
481may default to handling both styles and deprecate the various
482.Fl r
483flags.
484.\" .Sh EXAMPLES
485.\" .Bl -bullet
486.\" .It
487.\" To fill in with jail upgrade example when behavior is firm.
488.\" .El
489.Sh SEE ALSO
490.Xr libbe 3 ,
491.Xr zfsprops 7 ,
492.Xr beinstall.sh 8 ,
493.Xr jail 8 ,
494.Xr zfs 8 ,
495.Xr zpool 8
496.Sh HISTORY
497.Nm
498is based on
499.Xr beadm 1
500and was implemented as a project for the 2017 Summer of Code, along with
501.Xr libbe 3 .
502.Sh AUTHORS
503.Nm
504was written by
505.An Kyle Kneitinger (kneitinger) Aq Mt kyle@kneit.in .
506.Pp
507.Xr beadm 1
508was written and is maintained by
509.An Slawomir Wojciech Wojtczak (vermaden) Aq Mt vermaden@interia.pl .
510.Pp
511.An Bryan Drewery (bdrewery) Aq Mt bryan@shatow.net
512wrote the original
513.Xr beadm 1
514manual page that this one is derived from.
515