Re: Effects of varying page size on OSD writes

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

 



On Mon, May 4, 2015 at 1:29 PM, Sage Weil <sage@xxxxxxxxxxxx> wrote:
> Sorry, I missed this earlier.
>
> On Mon, 4 May 2015, Gregory Farnum wrote:
>> On Fri, May 1, 2015 at 7:54 AM, Steve Capper <steve.capper@xxxxxxxxxx> wrote:
>> > Hello,
>> > Whilst testing Ceph 0.94.1 on 64-bit ARM hardware, I noticed that
>> > switching the kernel PAGE_SIZE from 4KB to 64KB caused an increase by
>> > a factor of ~6 in the total amount of data written to disk (according
>> > to blktrace) by the OSD when running the RBD bench-write test (with
>> > --io-pattern rand, --io-size=4096, --num-threads=16, --io-total=$((50
>> > << 20))).
>> >
>> > Delving into the source, it is apparent that the FileJournal code uses
>> > the current page size for the block size. I was wondering why
>> > something like the block device sector size wasn't used instead? Is
>> > there a mmap somewhere that I missed, or are fewer larger blocks
>> > better for most use cases? (The use case above may be overly
>> > contrived?).

I believe this (64k) is also the case on most common PPC64 systems. I
only bring this up because I saw this recent commit:
https://github.com/ceph/ceph/commit/da7f6835b15370ce0120a64f7ac3359f3ba4729b

>>
>> This isn't an area of the kernel I know much about, but doesn't the
>> page cache work in memory page size, regardless of what the disk is
>> doing? FileJournal/FileStore are definitely trying to be friendly to
>> what the page cache is up to.
>
> Yeah, although the actual O_DIRECT requirement is that we align to the
> block size, not necessarily page size.  I'm just so used to them both
> being 4k and didn't realize anyone used other pages sizes in practice.
>
> We could definitely change this, but it's milding involved.  The buffer.h
> helpers like is_n_page_aligned() and so forth should be changed to take an
> alignment argument, and we should pull that from the journal device
> instead of assuming it's the page size...
>
> FWIW, one other 4k assumption currently baked in is that when you do an
> encode a data type to a bufferlist we allocate a page-sized buffer to
> append to.  4k is reasonablish (e.g., smallish and minimally stressful to
> the allocator) but 64k may be less so...
>
> sage
> --
> To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html



-- 
Milosz Tanski
CTO
16 East 34th Street, 15th floor
New York, NY 10016

p: 646-253-9055
e: milosz@xxxxxxxxx
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [CEPH Users]     [Ceph Large]     [Information on CEPH]     [Linux BTRFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux