On Thu, May 24, 2012 at 07:45:05AM +0200, Juerg Haefliger wrote: > > Hit this on a filesystem with a regular sized log over the weekend. If you see > > this again in production could you gather up task states? > > > > echo t > /proc/sysrq-trigger > > Here is the log from a production hang: > > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.111805] INFO: > task xfssyncd/dm-4:971 blocked for more than 120 seconds. > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.111864] "echo 0 > > /proc/sys/kernel/hung_task_timeout_secs" disables this message. > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.111951] > xfssyncd/dm-4 D 000000000000000f 0 971 2 0x00000000 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.111957] > ffff880325e09d00 0000000000000046 ffff880325e09fd8 ffff880325e08000 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.111962] > 0000000000013d00 ffff880326774858 ffff880325e09fd8 0000000000013d00 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.111966] > ffff8803241badc0 ffff8803267744a0 0000000000000282 ffff8806265d7e00 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.111971] Call Trace: > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112016] > [<ffffffffa00f42d8>] xlog_grant_log_space+0x4a8/0x500 [xfs] > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112023] > [<ffffffff8105f6f0>] ? default_wake_function+0x0/0x20 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112046] > [<ffffffffa00f61ff>] xfs_log_reserve+0xff/0x140 [xfs] > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112070] > [<ffffffffa01021fc>] xfs_trans_reserve+0x9c/0x200 [xfs] > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112092] > [<ffffffffa00e6383>] xfs_fs_log_dummy+0x43/0x90 [xfs] > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112117] > [<ffffffffa01193c1>] xfs_sync_worker+0x81/0x90 [xfs] > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112141] > [<ffffffffa01180f3>] xfssyncd+0x183/0x230 [xfs] > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112164] > [<ffffffffa0117f70>] ? xfssyncd+0x0/0x230 [xfs] > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112170] > [<ffffffff810871f6>] kthread+0x96/0xa0 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112176] > [<ffffffff8100cde4>] kernel_thread_helper+0x4/0x10 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112180] > [<ffffffff81087160>] ? kthread+0x0/0xa0 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112183] > [<ffffffff8100cde0>] ? kernel_thread_helper+0x0/0x10 > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112241] INFO: > task ruby1.8:2734 blocked for more than 120 seconds. > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112295] "echo 0 > > /proc/sys/kernel/hung_task_timeout_secs" disables this message. > May 23 11:44:33 sw-aw2az1-object062 kernel: [6272393.112378] ruby1.8 Great, that's the same one we saw last saturday. The xfs_sync_worker is blocked getting log reservation, so it doesn't push the target on the ail... which would possibly release enough space for the log reservation it's blocked on. I was thinking of experimenting with something like this: Index: xfs/fs/xfs/xfs_sync.c =================================================================== --- xfs.orig/fs/xfs/xfs_sync.c +++ xfs/fs/xfs/xfs_sync.c @@ -392,15 +392,15 @@ xfs_sync_worker( if (down_read_trylock(&mp->m_super->s_umount)) { if (!(mp->m_flags & XFS_MOUNT_RDONLY)) { /* dgc: errors ignored here */ - if (mp->m_super->s_frozen == SB_UNFROZEN && - xfs_log_need_covered(mp)) - error = xfs_fs_log_dummy(mp); - else - xfs_log_force(mp, 0); + xfs_log_force(mp, 0); /* start pushing all the metadata that is currently * dirty */ xfs_ail_push_all(mp->m_ail); + + if (mp->m_super->s_frozen == SB_UNFROZEN && + xfs_log_need_covered(mp)) + error = xfs_fs_log_dummy(mp); } up_read(&mp->m_super->s_umount); } By forcing the log and pushing all of the ail before trying to cover the log we don't deadlock that way... but it doesn't fix the greater problem with the ail hang. (It looks like that is being worked in a separate thread.) And there may be some other considerations with respect to covering the log later, after pushing the ail. Something for discussion. -Ben _______________________________________________ xfs mailing list xfs@xxxxxxxxxxx http://oss.sgi.com/mailman/listinfo/xfs