xref: /freebsd/sbin/bectl/bectl.8 (revision b4af4f93c682e445bf159f0d1ec90b636296c946)
1.\"
2.\" SPDX-License-Identifier: BSD-2-Clause-FreeBSD
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.\" $FreeBSD$
19.\"
20.Dd April 18, 2020
21.Dt BECTL 8
22.Os
23.Sh NAME
24.Nm bectl
25.Nd Utility to manage boot environments on ZFS
26.Sh SYNOPSIS
27.Nm
28.Cm activate
29.Op Fl t
30.Ar beName
31.Nm
32.Cm check
33.Nm
34.Cm create
35.Op Fl r
36.Op Fl e Brq Ar nonActiveBe | Ar beName Ns Cm @ Ns Ar snapshot
37.Ar newBeName
38.Nm
39.Cm create
40.Op Fl r
41.Ar beName@snapshot
42.Nm
43.Cm destroy
44.Op Fl \&Fo
45.Ar beName Ns Op Cm @ Ns Ar snapshot
46.Nm
47.Cm export
48.Ar sourceBe
49.Nm
50.Cm import
51.Ar targetBe
52.Nm
53.Cm jail
54.Op Fl bU
55.Oo Bro Fl o Ar key Ns Cm = Ns Ar value | Fl u Ar key Brc Oc Ns ...
56.Ar beName
57.Op Ar utility Op Ar argument ...
58.Nm
59.Cm list
60.Op Fl aDHs
61.Op Fl c Ar property
62.Op Fl C Ar property
63.Oo Bro Fl c Ar property | Fl C Ar property Brc Oc
64.Nm
65.Cm mount
66.Ar beName
67.Op Ar mountpoint
68.Nm
69.Cm rename
70.Ar origBeName
71.Ar newBeName
72.Nm
73.Brq Cm ujail | unjail
74.Brq Ar jailId | jailName
75.Ar beName
76.Nm
77.Brq Cm umount | unmount
78.Op Fl f
79.Ar beName
80.Pp
81.Nm
82.Op Fl h\&?
83.Sh DESCRIPTION
84The
85.Nm
86command is used to setup and interact with ZFS boot environments, which are
87bootable clones of datasets.
88.Pp
89Boot environments
90allow the system to be upgraded, while preserving the old system environment in
91a separate ZFS dataset.
92.Pp
93The following commands are supported by
94.Nm :
95.Bl -tag -width activate
96.It Xo
97.Cm activate
98.Op Fl t
99.Ar beName
100.Xc
101Activate the given
102.Ar beName
103as the default boot filesystem.
104If the
105.Op Fl t
106flag is given, this takes effect only for the next boot.
107.It Xo
108.Cm check
109.Xc
110Performs a silent sanity check on the current system.
111If boot environments are supported and used,
112.Nm
113will exit with a status code of 0.
114Any other status code is not currently defined and may, in the future, grow
115special meaning for different degrees of sanity check failures.
116.It Xo
117.Cm create
118.Op Fl r
119.Op Fl e Brq Ar nonActiveBe | Ar beName Ns Cm @ Ns Ar snapshot
120.Ar newBeName
121.Xc
122Create a new boot environment named
123.Ar newBeName .
124.Pp
125If the
126.Fl r
127flag is given, a recursive boot environment will be made.
128.Pp
129If the
130.Fl e
131flag is specified, the new environment will be cloned from the given
132.Ar nonActiveBe
133or
134.Ar beName Ns Cm @ Ns Ar snapshot .
135Otherwise, the new environment will be created from the currently booted environment.
136.Pp
137If
138.Nm
139is creating from another boot environment, a snapshot of that boot environment will be created to clone from.
140.It Xo
141.Cm create
142.Op Fl r
143.Ar beName@snapshot
144.Xc
145Create a snapshot of the boot environment named
146.Ar beName .
147.Pp
148If the
149.Fl r
150flag is given, a recursive snapshot of the boot environment will be created.
151A snapshot is created for each descendant dataset of the boot environment.
152.Pp
153No new boot environment is created with this command.
154.It Xo
155.Cm destroy
156.Op Fl \&Fo
157.Ar beName Ns Op Cm @ Ns Ar snapshot
158.Xc
159Destroy the given
160.Ar beName
161boot environment or
162.Ar beName Ns Cm @ Ns Ar snapshot
163snapshot without confirmation, unlike in
164.Xr beadm 1 .
165Specifying
166.Fl F
167will automatically unmount without confirmation.
168.Pp
169By default,
170.Nm
171will warn that it is not destroying the origin of
172.Ar beName .
173The
174.Fl o
175flag may be specified to destroy the origin as well.
176.It Cm export Ar sourceBe
177Export
178.Ar sourceBe
179to
180.Xr stdout 4 .
181.Xr stdout 4
182must be piped or redirected to a file.
183.It Cm import Ar targetBe
184Import
185.Ar targetBe
186from
187.Xr stdin 4 .
188.It Xo
189.Cm jail
190.Op Fl bU
191.Oo Bro Fl o Ar key Ns Cm = Ns Ar value | Fl u Ar key Brc Oc Ns ...
192.Ar beName
193.Op Ar utility Op Ar argument ...
194.Xc
195Create a jail of the given boot environment.
196Multiple
197.Fl o
198and
199.Fl u
200arguments may be specified.
201.Fl o
202will set a jail parameter, and
203.Fl u
204will unset a jail parameter.
205.Pp
206By default, jails are created in interactive mode and
207.Pa /bin/sh
208is
209executed within the jail.
210If
211.Ar utility
212is specified, it will be executed instead of
213.Pa /bin/sh .
214The jail will be destroyed and the boot environment unmounted when the command
215finishes executing, unless the
216.Fl U
217argument is specified.
218.Pp
219The
220.Fl b
221argument enables batch mode, thereby disabling interactive mode.
222The
223.Fl U
224argument will be ignored in batch mode.
225.Pp
226The
227.Va name ,
228.Va host.hostname ,
229and
230.Va path
231must be set, the default values are specified below.
232.Pp
233All
234.Ar key Ns Cm = Ns Ar value
235pairs are interpreted as jail parameters as described in
236.Xr jail 8 .
237The following default parameters are provided:
238.Bl -column "allow.mount.devfs" ""
239.It Va allow.mount Ta Cm true
240.It Va allow.mount.devfs Ta Cm true
241.It Va enforce_statfs Ta Cm 1
242.It Va name Ta Set to jail ID.
243.It Va host.hostname Ta Va bootenv
244.It Va path Ta Set to a path in Pa /tmp
245generated by
246.Xr libbe 3 .
247.El
248.Pp
249All default parameters may be overwritten.
250.It Xo
251.Cm list
252.Op Fl DHas
253.Oo Bro Fl c Ar property | Fl C Ar property Brc Oc
254.Xc
255.Pp
256Display all boot environments.
257The
258.Em Active
259field indicates whether the boot environment is active now
260.Pq Em \&N ;
261active on reboot
262.Pq Em \&R ;
263or both
264.Pq Em \&NR .
265.Pp
266.Bl -tag -width indent
267.It Fl a
268Display all datasets.
269.It Fl D
270Display the full space usage for each boot environment, assuming all
271other boot environments were destroyed.
272.It Fl H
273Used for scripting.
274Do not print headers and separate fields by a single tab instead of
275arbitrary white space.
276.It Fl s
277Display all snapshots as well.
278.It Fl c Ar property
279Sort boot environments by given property name.
280The following properties are supported:
281.Pp
282.Bl -tag -width 4n -offset indent -compact
283.It name (default output)
284.It creation
285.It origin
286.It used
287.It usedds
288.It usedsnap
289.It usedrefreserv
290.El
291.It Fl C Ar property
292Same as the
293.Fl c
294option, but displays in descending order.
295.El
296.Pp
297The
298.Fl D
299option is ignored when either the
300.Fl s
301or
302.Fl a
303option is used.
304.It Cm mount Ar beName Op Ar mountpoint
305Temporarily mount the boot environment.
306Mount at the specified
307.Ar mountpoint
308if provided.
309.It Cm rename Ar origBeName newBeName
310Rename the given
311.Ar origBeName
312to the given
313.Ar newBeName .
314The boot environment will not be unmounted in order for this rename to occur.
315.It Cm ujail Bro Ar jailId | jailName Brc Ar beName
316.It Cm unjail Bro Ar jailId | jailName Brc Ar beName
317Destroy the jail created from the given boot environment.
318.It Xo
319.Cm umount
320.Op Fl f
321.Ar beName
322.Xc
323.It Xo
324.Cm unmount
325.Op Fl f
326.Ar beName
327.Xc
328Unmount the given boot environment, if it is mounted.
329Specifying
330.Fl f
331will force the unmount if busy.
332.El
333.Pp
334.Nm
335prints usage information if
336.Fl h
337or
338.Fl \&?
339is specified.
340.Sh EXAMPLES
341.Bl -bullet
342.It
343To fill in with jail upgrade example when behavior is firm.
344.El
345.Sh SEE ALSO
346.Xr libbe 3 ,
347.Xr beinstall.sh 8 ,
348.Xr jail 8 ,
349.Xr zfs 8 ,
350.Xr zpool 8
351.Sh HISTORY
352.Nm
353is based on
354.Xr beadm 1
355and was implemented as a project for the 2017 Summer of Code, along with
356.Xr libbe 3 .
357.Sh AUTHORS
358.Nm
359was written by
360.An Kyle Kneitinger (kneitinger) Aq Mt kyle@kneit.in .
361.Pp
362.Xr beadm 1
363was written and is maintained by
364.An Slawomir Wojciech Wojtczak (vermaden) Aq Mt vermaden@interia.pl .
365.Pp
366.An Bryan Drewery (bdrewery) Aq Mt bryan@shatow.net
367wrote the original
368.Xr beadm 1
369manual page that this one is derived from.
370