Re: Mounted compress-force=zlib, compresses when files copied in, but not when written directly by application

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Dec 04, 2012 at 07:44:16PM +0000, Thorn Roby wrote:
> I am trying to use a btrfs filesystem (Oracle Linux 6.3 X86_64, UEK kernel)  
> with data RAID0 and metadata RAID1, mounted as follows:
> 
> /dev/sda3 on /data type btrfs (rw,noatime,compress-force=zlib,noacl)
> 
> dmesg shows 
> 
> btrfs: force zlib compression
> btrfs: disk space caching is enabled
> 
> My application is MongoDB, which creates a series of 2GB datafiles, possibly 
> using sparse allocation (at least I know it does on XFS), which reports the 
> following for each datafile:
> 
> Tue Dec  4 12:05:26.538 [FileAllocator] allocating new datafile 
> /data/db/lfs/lfs.19, filling with zeroes...
> Tue Dec  4 12:05:26.544 [FileAllocator] done allocating datafile 
> /data/db/lfs/lfs.19, size: 2047MB,  took 0.006 secs
> 
> If I create a new filesystem and mount it with compress-force=zlib, then rsync a 
> number of these 2GB files containing MongoDB data from another system, I get 
> roughly 4:1 compression. I also notices that CPU usage remains at 100% and the 
> rsync speed is roughly 70% of network speed. If I do the same thing using LZO, I 
> see low CPU usage, transmission speed is 100% of network speed and compression 
> is about 2:1. These results are what I expect.
> 
> However, if I run the mongodb process directly on the machine, using compress-
> force=zlib (haven't tried LZO yet) with the same mount options, and load data 
> into the database from another system via database inserts, there is no evidence 
> of compression. This is consistently verified by the output of df, btrfs fi df 
> and an internal report from the database which shows row count and average row 
> size (560 bytes). I also see low CPU usage (however this is not conclusive since 
> the file write rate from the database process is roughly 10 times slower than a 
> direct write using rsync). 
> 
> [root@eng-mongodb-t1 lfs]# btrfs fi df /data
> Data, RAID0: total=37.95GB, used=33.84GB
> Data: total=8.00MB, used=0.00
> System, RAID1: total=8.00MB, used=4.00KB
> System: total=4.00MB, used=0.00
> Metadata, RAID1: total=1.00GB, used=45.35MB
> Metadata: total=8.00MB, used=0.00
> 
> [root@eng-mongodb-t1 lfs]# df -h
> /dev/sda3              40G   34G  4.2G  90% /data
> 
> I tried chattr -c on the database directory but it doesn't appear to be 
> supported in Oracle Linux (nor was it necessary in the case where I rsyncd the 
> files and saw the expected compression).
> Filesystem type is: 9123683e
> File size of lfs.18 is 2146435072 (524032 blocks, blocksize 4096)
>  ext logical physical expected length flags
>    0       0  9182208               2 
>    1       2  9706240  9182209      1 
>    2       3  9182211  9706240  14348 
>    3   14351  9706241  9196558      1 
>    4   14352  9196560  9706241  28126 
>    5   42478  9224686          481554 eof
> lfs.18: 5 extents found
> 
> 
> Is there something about the (possible) initial sparse allocation followed by 
> zero-filling that might be disabling compression as the datafile is later 
> overwritten by the database process, despite the compress-force flag?

Well, it shouldn't be that since we have compress-force, as the name shows,
with compress-force it'll always try to compress the data via zlib/lzo.

So the previous rsync one is just 'write numbers of 2G files', while the
current application one is 'write numbers of 2G files' plus 'overwritten
by others later', is it right?

And is the above 'btrfs fi df' output captured after 'overwritten', or not?

thanks,
--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Filesystem Development]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux