Bcache Basic
Update
After finished first round of writing, I think it needs to be described in clearer way.
During first time setup, I got very confused by the document I was using, and didn't understand fully. After observation of the devices behavior, I think I will review this document later.
Install
apt install bcache-toolsConcept
Bcache adds in one more layer between the actual filesystem and the block device (partition, raid, etc.) which filesystem located in. This is done by relocating filesystem header behind bcache header in block device, which offset the ordinary filesystem header and data 8KiB behind.
Note: Use partition as example
Ordinary filesystem partition = (Ordinary filesystem header + Ordinary filesystem data)
bcache partition = bcache header (8KiB) + (Ordinary filesystem header + Ordinary filesystem data)
                                          -------------------------------------------------------
                                                                  bcache dataIn such case, the device (partition) is represented as a bcache partition, and bcache driver creates a new device called /dev/bcacheX without bcache header, then OS will detect /dev/bcacheX as ordinary filesystem.
This method is widely used in disk encryption as well, which allows encryption driver translates encrypted data device to OS in a newly created device.
Mount a filesystem bypass bcache header
By using following method, the ordinary filesystem in bcache partition can be mounted by ordinary filesystem driver without bcache driver.
- Create Loopback Device
losetup -o 8192 /dev/loop0 /dev/[BCACHE DEVICE]- Mount Device
mount /dev/loop0 -o loop /mnt/[LOCATION]Devices
Backing Device
Backing device is the actual device holding data, for example, /dev/sdb1, it can be 10TB hard disk, disk raid, software raid, etc. It can be created by following command
make-bcache -B /dev/sdb1It will create a bcache device as well, such as /dev/bcache0
Bcache device
Bcache device is the device created together with backing device (/dev/sdb1), such as /dev/bcache0, all ordinary filesystem operation will be operated on bcache device (/dev/bcache0), such as mkfs, etc.
Caching Device
Caching device is the temporary device used as cache, for example /dev/sdc1, it can be 128GB SSD. It can be created using following command
make-bcache -C /dev/sdc1It has cset.uuid as below
# bcache-super-show /dev/sdc1 | grep cset
cset.uuid       f0e01318-f4fd-4fab-abbb-d76d870503ecBefore recreate caching device, use following command clean up the device header.
wipefs -a /dev/<device>Attach
Attach action allows caching device starts working for backing device.
# echo <caching_device_uuid> > /sys/block/<bcache_device>/bcache/attach
echo f0e01318-f4fd-4fab-abbb-d76d870503ec > /sys/block/bcache0/bcache/attach
# or to the backing device
echo f0e01318-f4fd-4fab-abbb-d76d870503ec > /sys/block/sdb/sdb1/bcache/attachNote: If following error occurred, and no output when ran bcache-status command, then run partprobe command to rescan partition tables
# bcache-status
#
# echo f0e01318-f4fd-4fab-abbb-d76d870503ec > /sys/block/bcache0/bcache/attach
-bash: echo: write error: No such file or directory
# partprobe*Note: bcache-status is a free bcache tool can be downloaded from github.
Operation on backing device and bcache device
The backing device and the bcache device have 1-to-1 relationship, because they are created at same time using one make-bcache -C command.
In fact, both bcache folders in both bcache and backing device are the same.
# ls -Hdi /sys/block/sdb/sdb1/bcache
64954 /sys/block/sdb/sdb1/bcache
# ls -Hdi /sys/block/bcache0/bcache
64954 /sys/block/bcache0/bcacheI think the correct thinking should be attaching to bcache device, but the bcache folder is created under backing device.
# readlink -f /sys/block/bcache0/bcache
/sys/devices/platform/host2/session1/target2:0:0/2:0:0:1/block/sdb/sdb1/bcacheI think this is because that bcache device is a virtual device created during backing device (real device) creation, so the actual device structure should assign to real device (backing device).
With or without caching device
Without caching device, bcache driver will directly translate ordinary filesystem driver read/write into bcache device read/write.
With cache device, bcache driver will utilize caching device before backing device operation.
ordinary filesystem operation => bcache driver => bcache filesystem operation => backing device
                                       ||
                                       ||
                                 caching deviceSo, without caching device, bcache is still operating correctly.
Attach caching device to multiple bcache devices
One caching device can support multiple bcache devices as below
# echo f0e01318-f4fd-4fab-abbb-d76d870503ec > /sys/block/bcache0/bcache/attach
# echo 4b05ce02-19f4-4cc6-8ca0-1f765671ceda > /sys/block/bcache1/bcache/attach
# echo 4b05ce02-19f4-4cc6-8ca0-1f765671ceda > /sys/block/bcache2/bcache/attach
# echo 4b05ce02-19f4-4cc6-8ca0-1f765671ceda > /sys/block/bcache3/bcache/attach
# echo 75ff0598-7624-46f6-bcac-c27a3cf1a09f > /sys/block/bcache4/bcache/attachA bcache device has only one caching device
The uuid of caching device which attached to bcache device can be found as below.
# ls -la /sys/block/<device>/bcache/cache
lrwxrwxrwx 1 root root 0 Jun 19 18:42 /sys/block/<device>/bcache/set -> ../../../../../../../../fs/bcache/<UUID>Detach
To detach a caching device, needs to send 1 or cache-set-uuid to bcache device or backing device
Safely remove the caching device from bcache device
echo cache-set-uuid > /sys/block/bcache0/bcache/detach
# or
echo cache-set-uuid > /sys/block/sdb/sdb1/bcache/detachDetach the caching device from bcache device
echo 1 > /sys/block/bcache0/bcache/detach
# or
echo 1 > /sys/block/sdb/sdb1/bcache/detachStop
bcache/backing device
Stop a bcache device, is the same as stop the backing device.
echo 1 > /sys/block/bcache0/bcache/stop
# or
echo 1 > /sys/block/sdb/sdb1/bcache/stopAfter stopped bcache/backing device,
- The /sys/block/sdb/sdb1/bcachefolder disappears
- The /sys/block/bcache0virtual device disappers
- But no impact to caching device, and still registered in /sys/fs/bcache/<uuid>.
caching device
Stop caching device, will impact all caching, bcache and backing devices
echo 1 > /sys/fs/bcache/cache-set-uuid/stopAfter stopped caching device, all bcache setup related to that caching device disapper
- The /sys/block/sdb/sdb1/bcachefolder disappers if/dev/sdb1is backing device attached
- The bcache devices /sys/block/bcache0disappers if/dev/bcache0is the bcache device attached
- The caching device /sys/fs/bcache/<uuid>disappers
To resume
The first way to resume whole setup, can be done by run partprobe.
The second way is using register to resume device one by one.
Register
In fact, registering is needed every bootup, but attaching only have to be done once.
Register is required if the caching or backing device missing during system start up or they are stopped manually.
Register the backing device as below
echo /dev/sdb1 > /sys/fs/bcache/register     # backing deviceAfter registered, the system will
- Creates /sys/block/sdb/sdb1/bcachefolder
- If didn't attach caching device before stopped or caching device had been registered, then creates /sys/block/bcache0virtual device
If /sys/block/bcache0 is not created due to missing caching device,
- The /sys/block/bcache0device will be created after register missing caching device
- Or use following command to force to create /sys/block/bcache0and start running
echo 1 > /sys/block/sdb/sdb1/bcache/runningWarning: If force start, all write cache in caching device will be lost, this can cause filesystem corruption
Register caching device
To register caching device, following command can be used
echo /dev/sdc1 > /sys/fs/bcache/register     # caching deviceIt will create directory /sys/fs/bcache/<uuid> folder.
If attached backing device had been registered, the /sys/block/bcache0 will be created and running.
Ordinary filesystem operation
All ordinary filesystem operations will be operated on bcache device (/dev/bcache0), for example
mkfs.btrfs /dev/bcache0
mount /dev/bcache0 /mnt
...Caching state
The caching state can be viewed using following command
cat /sys/block/bcache0/bcache/stateOutput:
- no cache: this means you have not attached a caching device to your backing bcache device
- clean: this means everything is ok. The cache is clean.
- dirty: this means everything is setup fine and that you have enabled writeback and that the cache is dirty.
- inconsistent: you are in trouble because the backing device is not in sync with the caching device
Caching mode
There are 4 caching modes, writethrough, writeback, writearound, and none.
echo writeback > /sys/block/bcache0/bcache/cache_modeShow caching device info
bcache-super-show /dev/sdXYWriteback Percent
echo 100 > /sys/block/bcache0/bcache/writeback_percentDirty data
How much data in cache has not written into backing device.
cat /sys/block/sda/sda3/bcache/dirty_dataFlush cache to backing device
This might be required if filesystem maintenance needed.
Run following command to disable writeback mode
echo writethrough > /sys/block/bcache0/bcache/cache_modeWait until state reports "clean"
watch cat /sys/block/bcache0/bcache/stateForce flush of cache to backing device
echo 0 > /sys/block/bcache0/bcache/writeback_percentErrors
The /sys/fs/bcache/ folder does not exist
The bcache module was not loaded.
sh: echo: write error: Invalid argument
If dmesg shows
bcache: bch_cached_dev_attach() Couldn't attach sdc: block size less than set's block sizeThen the --block 4k parameter was not set on either device and defaults can mismatch.
Otherwise, the device might already be attached.
sh: echo: write error: No such file or directory
The UUID is not a valid cache.
Other considerations
Boot from bcache device
Grub2 does not offer support for bcache, but it is fully supported by UEFI. Check the following link for details
https://wiki.archlinux.org/title/Bcache