Re: segfault in bluestore during random writes

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

 



Thus forces previous ops on the object to complete before processing the new write request. Hence it eliminates concurrency for object access. At the cost of performance decrease... Probably the bug has some relation to concurrent writes processing.


On 06.07.2016 14:55, Ma, Jianpeng wrote:
With this patch:
@@ -6122,7 +6127,7 @@ int BlueStore::_do_write(
    if (length == 0) {
      return 0;
    }
-
+  o->flush();
    uint64_t end = offset + length;
WriteContext wctx;

This bug can't reproduce. But I don't know why?


-----Original Message-----
From: Varada Kari [mailto:Varada.Kari@xxxxxxxxxxx]
Sent: Wednesday, July 6, 2016 4:47 PM
To: Ma, Jianpeng <jianpeng.ma@xxxxxxxxx>; Mark Nelson <mnelson@xxxxxxxxxx>; ceph-devel <ceph-devel@xxxxxxxxxxxxxxx>
Subject: Re: segfault in bluestore during random writes

Okay. I haven't tried sequential write, will try now. Thanks for the help.

Varada

On Wednesday 06 July 2016 02:10 PM, Ma, Jianpeng wrote:
I use fio(engine=rbd) for seqwrite on 30G rbd image, this bug 100% occur.

-----Original Message-----
From: ceph-devel-owner@xxxxxxxxxxxxxxx
[mailto:ceph-devel-owner@xxxxxxxxxxxxxxx] On Behalf Of Varada Kari
Sent: Wednesday, July 6, 2016 2:45 PM
To: Mark Nelson <mnelson@xxxxxxxxxx>; ceph-devel
<ceph-devel@xxxxxxxxxxxxxxx>
Subject: Re: segfault in bluestore during random writes

Hi mark,

I have tried reproducing the issue with latest master, so far no luck with 128k and 512k block sizes on a 1000GB rbd image.
I couldn't find #5e07e5a3446ee39189c5b959be624411561175f5 in master, are you using any private changes?

I will try some more time today to reproduce the issue. Seems blob map got corrupted in your case.

Varada

On Tuesday 05 July 2016 09:06 PM, Mark Nelson wrote:
Hi Guys,

This is primarily for Varada but if anyone else wants to take a look
feel free.  We are hitting segfaults in tc_state_proc during random
writes.  I was able to reproduce with logging enabled and got a core
dump.  I've only briefly looked at the code/logs, but I haven't
really looked through it in earnest yet.  Unfortunately the logs are
about 4GB and the core dump is 2GB, so I'll only attach the last 10k lines.
Hopefully it should be fairly reproducible.  I'll try to see if I can
narrow down commits that have touched the write path over the last 4
weeks and see if anything looks relevant.

Varada: let me know if you can reproduce.  Thanks!

gdb bt:

(gdb) bt
#0  0x00007f9c59708fcb in raise (sig=11) at
../nptl/sysdeps/unix/sysv/linux/pt-raise.c:37
#1  0x0000000000bd7505 in reraise_fatal (signum=11) at
/home/ubuntu/src/markhpc/ceph/src/global/signal_handler.cc:69
#2  handle_fatal_signal (signum=11) at
/home/ubuntu/src/markhpc/ceph/src/global/signal_handler.cc:133
#3  <signal handler called>
#4  next_node (node=<synthetic pointer>) at
/usr/include/boost/intrusive/detail/tree_algorithms.hpp:446
#5  next_node (p=<synthetic pointer>) at
/usr/include/boost/intrusive/rbtree_algorithms.hpp:352
#6  operator++ (this=<synthetic pointer>) at
/usr/include/boost/intrusive/detail/tree_node.hpp:128
#7  BlueStore::_txc_state_proc (this=this@entry=0xaff6000,
txc=txc@entry=0x192c8c80) at
/home/ubuntu/src/markhpc/ceph/src/os/bluestore/BlueStore.cc:4568
#8  0x0000000000aeddb7 in BlueStore::_txc_finish_io
(this=this@entry=0xaff6000, txc=txc@entry=0x192c8c80) at
/home/ubuntu/src/markhpc/ceph/src/os/bluestore/BlueStore.cc:4669
#9  0x0000000000aed23f in BlueStore::_txc_state_proc
(this=0xaff6000,
txc=0x192c8c80) at
/home/ubuntu/src/markhpc/ceph/src/os/bluestore/BlueStore.cc:4559
#10 0x0000000000bc134a in KernelDevice::_aio_thread (this=0xaf20960)
at
/home/ubuntu/src/markhpc/ceph/src/os/bluestore/KernelDevice.cc:270
#11 0x0000000000bc588d in KernelDevice::AioCompletionThread::entry
(this=<optimized out>) at
/home/ubuntu/src/markhpc/ceph/src/os/bluestore/KernelDevice.h:49
#12 0x00007f9c59701dc5 in start_thread (arg=0x7f9c4da2e700) at
pthread_create.c:308
#13 0x00007f9c575fc28d in clone () at
../sysdeps/unix/sysv/linux/x86_64/clone.S:113
(gdb) frame 7
#7  BlueStore::_txc_state_proc (this=this@entry=0xaff6000,
txc=txc@entry=0x192c8c80) at
/home/ubuntu/src/markhpc/ceph/src/os/bluestore/BlueStore.cc:4568
4568for (auto& p : o->blob_map.blob_map) {
Mark
PLEASE NOTE: The information contained in this electronic mail message is intended only for the use of the designated recipient(s) named above. If the reader of this message is not the intended recipient, you are hereby notified that you have received this message in error and that any review, dissemination, distribution, or copying of this message is strictly prohibited. If you have received this communication in error, please notify the sender by telephone or e-mail (as shown above) immediately and destroy any and all copies of this message in your possession (whether hard copies or electronically stored copies).
--
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

--
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

--
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