I am gonna modify reboot script, but still not Satisfying. if you can share your patch, that will be very cool. Thanks, Kongming Wu --------------------------------------------- wukongming ID: 12019 Tel:0571-86760239 Dept:2014 UIS2 OneStor -----邮件原件----- 发件人: Ilya Dryomov [mailto:idryomov@xxxxxxxxx] 发送时间: 2015年11月20日 17:30 收件人: wukongming 12019 (RD) 抄送: ceph-devel@xxxxxxxxxxxxxxx; Sage Weil 主题: Re: Reboot blocked when undoing unmap op. On Fri, Nov 20, 2015 at 3:19 AM, Wukongming <wu.kongming@xxxxxxx> wrote: > Hi Sage, > > I created a rbd image, and mapped to a local which means I can find > /dev/rbd0, at this time I reboot the system, in last step of shutting > down, it blocked with an error > > [235618.0202207] libceph: connect 172.16.57.252:6789 error -101. > > My Works’ Env: > > Ubuntu kernel 3.19.0 > Ceph 0.94.5 > A cluster of 2 Servers with iscsitgt and open-iscsi, both as server and client. Multipath process is on but not affect this issue. I’ve tried stopping multipath, but the issue still there. > I map a rbd image to a local, why show me a connect error? > > I saw your reply on http://permalink.gmane.org/gmane.comp.file-systems.ceph.devel/13077, but just apart. Is this issue resolved and how? Yeah, this has been a long standing problem with libceph/rbd. The issue is that you *have* to umount (and ideally also unmap, but unmap isn't strictly necessary) before you reboot. Otherwise (and I assume by mapped to a local you mean you've got MONs and OSDs on the same node as you do rbd map), when you issue a reboot, daemons get killed and the kernel client ends up waiting for the them to come back, because of outstanding writes issued by umount called by systemd (or whatever). There are other variations of this, but it all comes down to you having to cold reboot. The right fix is to have all init systems sequence the killing of ceph daemons after the umount/unmap. I also toyed with adding a reboot notifier for libceph to save a cold reboot, but the problem with that in the general case is data integrity. However, in cases like the one I described above, there is no going back so we might as well kill libceph through a notifier. I have an incomplete patch somewhere, but it really shouldn't be necessary... Thanks, Ilya ------------------------------------------------------------------------------------------------------------------------------------- 本邮件及其附件含有杭州华三通信技术有限公司的保密信息,仅限于发送给上面地址中列出 的个人或群组。禁止任何其他人以任何形式使用(包括但不限于全部或部分地泄露、复制、 或散发)本邮件中的信息。如果您错收了本邮件,请您立即电话或邮件通知发件人并删除本 邮件! This e-mail and its attachments contain confidential information from H3C, which is intended only for the person or entity whose address is listed above. Any use of the information contained herein in any way (including, but not limited to, total or partial disclosure, reproduction, or dissemination) by persons other than the intended recipient(s) is prohibited. If you receive this e-mail in error, please notify the sender by phone or email immediately and delete it! ��.n��������+%������w��{.n����z��u���ܨ}���Ơz�j:+v�����w����ޙ��&�)ߡ�a����z�ޗ���ݢj��w�f