Recurring problem: processes block accessing UFS file system
Don Lewis
truckman at FreeBSD.org
Thu Jan 5 10:46:06 PST 2006
On 5 Jan, Denis Shaposhnikov wrote:
> Hi!
>
>>>>>> "Greg" == Greg Rivers <gcr+freebsd-stable at tharned.org> writes:
>
> Greg> It's taken more than a month, but the problem has recurred
> Greg> without snapshots ever having been run. I've got a good trace
>
> I think that I have the same problem on a fresh CURRENT. For some
> processes I see MWCHAN = ufs and "D" in the STAT. And I can't kill
> such processes even with -9. And system can't kill them too on
> shutdown. So, system can't do shutdown and wait forever after "All
> buffers synced" message. At this moment I've entered to KDB do "show
> lockedvnods":
>
> Locked vnodes
>
> 0xc687cb58: tag ufs, type VDIR
> usecount 1, writecount 0, refcount 2 mountedhere 0
> flags ()
> v_object 0xcb5b1934 ref 0 pages 0
> lock type ufs: EXCL (count 1) by thread 0xc795d600 (pid 74686) with 1 pending
> ino 2072602, on dev ad4s1g
>
> 0xc687ca50: tag ufs, type VDIR
> usecount 31, writecount 0, refcount 32 mountedhere 0
> flags ()
> v_object 0xc85d2744 ref 0 pages 1
> lock type ufs: EXCL (count 1) by thread 0xc7683d80 (pid 74178) with 6 pending
> ino 2072603, on dev ad4s1g
>
> 0xc687c948: tag ufs, type VDIR
> usecount 2, writecount 0, refcount 3 mountedhere 0
> flags ()
> v_object 0xc875d000 ref 0 pages 1
> lock type ufs: EXCL (count 1) by thread 0xc91f3300 (pid 65610) with 1 pending
> ino 2072615, on dev ad4s1g
>
> 0xc691f420: tag ufs, type VDIR
> usecount 2, writecount 0, refcount 3 mountedhere 0
> flags ()
> v_object 0xc8a773e0 ref 0 pages 1
> lock type ufs: EXCL (count 1) by thread 0xc68e5780 (pid 519) with 1 pending
> ino 2072680, on dev ad4s1g
>
> 0xc691f318: tag ufs, type VDIR
> usecount 3, writecount 0, refcount 4 mountedhere 0
> flags ()
> v_object 0xc8a7b2e8 ref 0 pages 1
> lock type ufs: EXCL (count 1) by thread 0xc7019780 (pid 74103) with 2 pending
> ino 2072795, on dev ad4s1g
>
> 0xc69bb528: tag ufs, type VDIR
> usecount 2, writecount 0, refcount 3 mountedhere 0
> flags ()
> v_object 0xc7890744 ref 0 pages 1
> lock type ufs: EXCL (count 1) by thread 0xc91f4600 (pid 74129) with 1 pending
> ino 2072767, on dev ad4s1g
> Locked vnodes
>
> 0xc687cb58: tag ufs, type VDIR
> usecount 1, writecount 0, refcount 2 mountedhere 0
> flags ()
> v_object 0xcb5b1934 ref 0 pages 0
> lock type ufs: EXCL (count 1) by thread 0xc795d600 (pid 74686) with 1 pending
> ino 2072602, on dev ad4s1g
>
> 0xc687ca50: tag ufs, type VDIR
> usecount 31, writecount 0, refcount 32 mountedhere 0
> flags ()
> v_object 0xc85d2744 ref 0 pages 1
> lock type ufs: EXCL (count 1) by thread 0xc7683d80 (pid 74178) with 6 pending
> ino 2072603, on dev ad4s1g
>
> 0xc687c948: tag ufs, type VDIR
> usecount 2, writecount 0, refcount 3 mountedhere 0
> flags ()
> v_object 0xc875d000 ref 0 pages 1
> lock type ufs: EXCL (count 1) by thread 0xc91f3300 (pid 65610) with 1 pending
> ino 2072615, on dev ad4s1g
>
> 0xc691f420: tag ufs, type VDIR
> usecount 2, writecount 0, refcount 3 mountedhere 0
> flags ()
> v_object 0xc8a773e0 ref 0 pages 1
> lock type ufs: EXCL (count 1) by thread 0xc68e5780 (pid 519) with 1 pending
> ino 2072680, on dev ad4s1g
>
> 0xc691f318: tag ufs, type VDIR
> usecount 3, writecount 0, refcount 4 mountedhere 0
> flags ()
> v_object 0xc8a7b2e8 ref 0 pages 1
> lock type ufs: EXCL (count 1) by t(kgdb)
>
> After that I've done "call doadump" and got vmcore.
>
> ps show me:
>
> (kgdb) ps
> During symbol reading, Incomplete CFI data; unspecified registers at 0xc04d97eb.
> pid proc uid ppid pgrp flag stat comm wchan
> 74686 c9464000 0 1 1 000000 1 sh ufs c687caa8
> 74195 c970d000 0 3074 74195 4000100 1 sshd ufs c687caa8
> 74178 c7682adc 0 3074 74178 004000 1 sshd ufs c687c9a0
> 74129 c9b82adc 1008 1 5504 004000 1 parser3.cgi ufs c691f370
> 74103 c70b5458 1008 1 5504 000000 1 httpd ufs c69bb580
> 65610 c92c0458 1005 1 65610 004000 1 sftp-server ufs c691f478
> 5518 c6247458 1008 1 5516 004002 1 perl5.8.7 ufs c687caa8
> 3081 c7523d08 0 1 3081 000000 1 cron ufs c687caa8
> 3074 c7682d08 0 1 3074 000100 1 sshd ufs c687caa8
> 3016 c7523adc 0 1 3016 000000 1 syslogd ufs c687caa8
> 519 c68e4d08 80 1 518 000100 1 nginx ufs c691f370
> 34 c6260000 0 0 0 000204 1 schedcpu - e88b3cf0
> 33 c62438b0 0 0 0 000204 1 syncer ktsusp c6243938
> 32 c6243adc 0 0 0 000204 1 vnlru ktsusp c6243b64
> 31 c6243d08 0 0 0 000204 1 bufdaemon ktsusp c6243d90
> 30 c6244000 0 0 0 00020c 1 pagezero pgzero c06c21a0
> 29 c624422c 0 0 0 000204 1 vmdaemon psleep c06c1d08
> 28 c6244458 0 0 0 000204 1 pagedaemon psleep c06c1cc8
> 27 c602e684 0 0 0 000204 1 irq1: atkbd0
> 26 c602e8b0 0 0 0 000204 1 swi0: sio
> 25 c602eadc 0 0 0 000204 1 irq18: atapci1
> 24 c602ed08 0 0 0 000204 1 irq15: ata1
> 23 c6074000 0 0 0 000204 1 irq14: ata0
> 22 c607422c 0 0 0 000204 1 irq27: em1
> 21 c6074458 0 0 0 000204 1 irq26: em0
> 20 c6074684 0 0 0 000204 1 irq9: acpi0
> 19 c60748b0 0 0 0 000204 1 swi2: cambio
> 18 c6074adc 0 0 0 000204 1 swi6: task queue
> 9 c5fd822c 0 0 0 000204 1 acpi_task2 - c6061e40
> 8 c5fd8458 0 0 0 000204 1 acpi_task1 - c6061e40
> 7 c5fd8684 0 0 0 000204 1 acpi_task0 - c6061e40
> 17 c5fd88b0 0 0 0 000204 1 swi6: Giant taskq
> 6 c5fd8adc 0 0 0 000204 1 thread taskq - c6062040
> 16 c5fd8d08 0 0 0 000204 1 swi5: Fast taskq
> 5 c602e000 0 0 0 000204 1 kqueue taskq - c6062100
> 15 c602e22c 0 0 0 000204 1 yarrow - c06b1720
> 4 c602e458 0 0 0 000204 1 g_down - c06b1fc0
> 3 c5fd3000 0 0 0 000204 1 g_up - c06b1fbc
> 2 c5fd322c 0 0 0 000204 1 g_event - c06b1fb4
> 14 c5fd3458 0 0 0 000204 1 swi3: vm
> 13 c5fd3684 0 0 0 00020c 1 swi4: clock sio
> 12 c5fd38b0 0 0 0 000204 1 swi1: net
> 11 c5fd3adc 0 0 0 00020c 1 idle: cpu0
> 10 c5fd3d08 0 0 0 00020c 1 idle: cpu1
> 1 c5fd8000 0 0 1 004200 1 init ufs c687cbb0
> 0 c06b20c0 0 0 0 000200 1 swapper
> There is no member named p_pptr.
This is different because only vnode locks appear to be involved. One
thread holding a vnode lock is getting stuck, and then all the other
threads pile up behind it.
I traced the list of locked vnodes and get stuck here:
> 0xc691f318: tag ufs, type VDIR
> usecount 3, writecount 0, refcount 4 mountedhere 0
> flags ()
> v_object 0xc8a7b2e8 ref 0 pages 1
> lock type ufs: EXCL (count 1) by t(kgdb)
pid 519 wants to lock this vnode but some other thread is holding the
vnode lock. Unfortunately we don't know who the lock holder is because
the message is truncated.
This might just be a vnode lock leak. Build a debug kernel with the
DEBUG_VFS_LOCKS and DEBUG_LOCKS options and see if anything shows up.
More information about the freebsd-stable
mailing list