How to Manage the Automatic ZFS Snapshot Service
The Time Slider automatic snapshot tool automatically takes snapshots of ZFS file systems and enables you to browse and recover snapshots of file systems.
This tool provides the following features:
- SMF snapshot service instances schedule recurring snapshots.
- Automatic snapshots are scheduled from the zfssnap crontab.
- Older snapshots are removed based on a predefined percentage of file system space used.
- Browse and recover files from snapshots by using the GNOME file manager.
When the Time Slider tool is enabled, ZFS file system snapshots are created based on the following criteria:
frequent snapshots every 15 mins, keeping 4 snapshots hourly snapshots every hour, keeping 24 snapshots daily snapshots every day, keeping 31 snapshots weekly snapshots every week, keeping 4 snapshots monthly snapshots every month, keeping 12 snapshots
Before You Begin
Use the steps below to add yourself to the zfssnap role if you want to modify the Time Slider behavior with the GNOME file manager.
- From the System menu, choose Administration
- Then, select the Users and Groups tool
- Select your user account and select the properties menu
- Select the User roles tab and select the zfssnap role
- Click the OK button
- From the Users and Group screen, click the OK button
- Confirm that you are added to the zfssnap role from a terminal window:
$ roles
root,zfssnap
Steps
Start a privileged shell.
user@opensolaris:-$ pfexec bash #
In this example, the bash shell is selected. You can choose to use any shell with the pfexec command. If you support multiple versions of the SolarisTM OS, use the standard su – root command. The su command works on all Solaris versions.
- Enable the Time Slider service, which is disabled by default.
You can enable or disable these services from the command line or from the System → Administration → Time Slider menu. From this menu, you can also customize which ZFS file systems to snapshot and adjust the file system capacity setting for when snapshots are removed. - Review the default automatic snapshot service instances that are started when the Time Slider service is enabled.
# svcs | grep auto-snapshot online Oct_22 svc:/system/filesystem/zfs/auto-snapshot:frequent online Oct_22 svc:/system/filesystem/zfs/auto-snapshot:hourly online Oct_22 svc:/system/filesystem/zfs/auto-snapshot:weekly online Oct_22 svc:/system/filesystem/zfs/auto-snapshot:monthly online Oct_22 svc:/system/filesystem/zfs/auto-snapshot:daily
- Confirm that automatic snapshots are created.
For example:# zfs list -t snapshot NAME USED AVAIL REFER MOUNTPOINT rpool@zfs-auto-snap:monthly-2009-05-12-15:46 0 - 78.5K - rpool@zfs-auto-snap:weekly-2009-05-12-15:46 0 - 78.5K - rpool@zfs-auto-snap:daily-2009-05-12-15:46 0 - 78.5K - rpool@zfs-auto-snap:hourly-2009-05-13-14:00 18K - 78.5K - rpool@zfs-auto-snap:frequent-2009-05-13-14:45 18K - 78.5K - rpool@zfs-auto-snap:hourly-2009-05-13-15:01 0 - 78.5K - rpool@zfs-auto-snap:frequent-2009-05-13-15:15 0 - 78.5K - rpool@zfs-auto-snap:frequent-2009-05-13-15:30 0 - 78.5K - . . .
- Disable or enable specific automatic snapshot services for the top-level dataset and all descendant datasets from the command line.
For example:# zfs set com.sun:auto-snapshot=false rpool # zfs set com.sun:auto-snapshot=true rpool/ROOT/opensolaris
- Choose to only take snapshots under a given schedule for a dataset and all direct descendant datasets from the command line.
For example:# zfs set com.sun:auto-snapshot=false rpool/export # zfs set com.sun:auto-snapshot:weekly=true rpool/export
- Change the frequency of a given snapshot schedule from the command line.
For example:# svccfg -s svc:/system/filesystem/zfs/auto-snapshot:frequent setprop zfs/period = 30 # svccfg -s svc:/system/filesystem/zfs/auto-snapshot:frequent refresh # svcadm restart svc:/system/filesystem/zfs/auto-snapshot:frequent
- Disable automatic snapshot services for the swap and dump volumes, from the command line, if necessary.
For example:# zfs set com.sun:auto-snapshot=false rpool/dump # zfs set com.sun:auto-snapshot=false rpool/swap
- Remove a range of unwanted snapshots, from the command line, if necessary.
In the following example, all automatic snapshots in the bash shell are removed.for s in $(zfs list -H -o name -t snapshot | grep @zfs-auto-snap); do zfs destroy $s; done
In the OpenSolaris 2009.06 release, you can remove automatic ZFS snapshots from the Time Slider tool.
For more information:


Comments (1)
Dec 24, 2008
Alysson_Troffer says:
In steps 5-9, is it necessary to say "from the command line"?In steps 5-9, is it necessary to say "from the command line"?