Zff version 2 is in the testing stage. It has only been tested by me internally so far and requires further independent testing. For this purpose, the corresponding tools can also be used (see below in the corresponding table).
Zff (Z forensic file format) is a completley new designed file format to store and handle the contents and structure of a partial or entire disk image, physical memory or logical file/folder structures. The focus of zff is on speed, security and modularity in concert with forensic requirements. The modular design promises high maintainability and scalability. Zff is an alternative to the ewf and aff file formats and is not compatible with them.
Zff is open source and is dual licensed (Apache-2.0 and MIT). This should ensure reasonable suitability for use in both open source and commercial tools.
Above mentioned compression, encryption and signature methods are applied to each chunk separately. This makes it possible to access a corresponding part of the data in real time without the need to decompress or decrypt the complete image first. Authenticity verification can also be applied to individual chunks and does not have to be applied to the entire image.
The following benchmarks were all run on my notebook, which has the following specifications: - Lenovo Thinkbook 14S Yoga ITL - Intel(R) 11th Gen i5-1135G7 @ AVG: 2.40GHz (MAX: 4.2 GHz) - 16GB DDR4-3200 RAM - internal WDC PC SN530 512GB NVMe\ The installed operating system was Gentoo Linux.\ Input and output storage device was the internal NVMe.
The following benchmark was created for a \~20GB prebuilt image, which was generated using this script.
\
¹Using Guymager 0.8.12, with the default guymager.cfg, MD5 hash calculation, without "HashVerifyDest".\
²Using Guymager 0.8.12, with enabled Aff support and Aff compression level 1 in guymager.cfg, with MD5 hash calculation, without "HashVerifyDest".\
³using
zffacquire -i raw/example01.dd -o zff_lz4 -z lz4
\
⁴using zffacquire -i raw/example01.dd -o zff -S
\
⁵using zffacquire -i raw/example01.dd -o zff -p 123
\
⁶using zffacquire -i raw/example01.dd -o zff
\
⁷using ewfacquire example01.dd -t example01_ewf -f encase7-v2 -b 64 -c fast -S 7.9EiB -u
\
⁸using ewfacquire example01.dd -t example01_ewf -b 64 -c fast -S 7.9EiB -u
, using ewfacquire 20171104.\
As you can see, there are hardly any differences worth mentioning between the dump using Guymager and zffacquire. Using zffacquire with the default values gives no performance disadvantage. The situation is different, of course, with an additional signature operation (but the same would also apply to Guymager with "HashVerifyDest" and/or "HashVerifySrc" enabled).\
\
The two fastest images (The Guymager-e01-image at number 1, acquired in the benchmark process above and the zff-z01-image acquired with the default options of zffacquire, see above at number 6), the acquired Ex01-image (number 7) and the acquired Aff-image (by Guymager, see number 2), were used as the basis for the read speed benchmark.
For the benchmark, xmount and zffmount was used to FUSE mount the appropriate images. Next, dd was used to benchmark the read speed.
The dd commands were applied 10 times and then an average value was calculated over the determined values.
\
¹The following commands were used:
bash
zffmount -i zff.z01 -m /tmp/zffmount
dd if=/tmp/zffmount/zff_image.dd of=/dev/null bs=1M
²The following commands were used:
bash
affuse aff_image.aff /tmp/affmount
dd if=/tmp/affmount/aff_example01.aff.raw of=/dev/null bs=1M
³The following commands were used:
bash
xmount --in aff aff_image.aff /tmp/affmount
dd if=/tmp/affmount/aff_image.dd of=/dev/null bs=1M
⁴The following commands were used:
bash
xmount --in ewf ewfacquired.Ex01 /tmp/ewfmount
dd if=/tmp/ewfmount/ewfacquired.dd of=/dev/null bs=1M
⁵The following commands were used:
bash
xmount --in ewf guymager.e01 /tmp/ewfmount
dd if=/tmp/ewfmount/guymager.dd of=/dev/null b=1M
See the wiki pages for further information.
This repository contains several tools to work with zff images (or acquire them). All tools and libraries are written in pure Rust.
| Name | Type | Description | Crates.io | MRSV
|------|:----:|:------------|:---------:|:----:|
| zff | library | Library to handle the zff format | | 1.58.1 |
| zffacquire | binary | Tool to acquire disk images in zff format |
| 1.58.1 |
| zffanalyze | binary | Tool to get information about a zff container |
| 1.58.1 |
| zffmount | binary | Tool to mount a zff container with FUSE (similar to xmount) |
| 1.56.1 |