Hello,
I have an interesting issue where dm-multipath marks one path (out of
many) as down and multipath-tools' tur checker brings it back up, repeat.
May 27 22:21:45 box kernel: sd_init_command: disk=sdah, block=12411960, count=8
May 27 22:21:45 box kernel: Finishing 8 sectors
May 27 22:21:45 box kernel: Retry with 0xffff8103138da080
May 27 22:21:45 box kernel: device-mapper: multipath: Failing path 66:16.
May 27 22:21:57 box kernel: sd_ioctl: disk=sdah, cmd=0x2285
May 27 22:21:57 box multipathd: sdah: tur checker reports path is up
May 27 22:21:57 box kernel: sd_ioctl: disk=sdah, cmd=0x2285
[... repeat sd_ioctl ...]
May 27 22:22:20 box kernel: sd_init_command: disk=sdah, block=12412744, count=72
May 27 22:22:20 box kernel: Finishing 72 sectors
May 27 22:22:20 box kernel: Retry with 0xffff8104983ece40
May 27 22:22:20 box kernel: device-mapper: multipath: Failing path 66:16.
May 27 22:22:27 box kernel: sd_ioctl: disk=sdah, cmd=0x2285
May 27 22:22:27 box multipathd: sdah: tur checker reports path is up
May 27 22:22:27 box kernel: sd_ioctl: disk=sdah, cmd=0x2285
[... repeat sd_ioctl ...]
[... REPEAT sequence ...]
(This logging is via `echo 0xffffffff >/proc/sys/dev/scsi/logging_level`.)
While this particular sdah path is down, others are up and working well:
mpathc (360050768019081c13700000000000112) dm-2 IBM,2145
[size=10G][features=1 queue_if_no_path][hwhandler=0]
\_ round-robin 0 [prio=100][active]
\_ 1:0:1:7 sdah 66:16 [failed][ready] <=-- bad path
\_ 0:0:0:7 sdg 8:96 [active][ready]
\_ round-robin 0 [prio=20][enabled]
\_ 0:0:1:7 sdv 65:80 [active][ready]
\_ 1:0:0:7 sdw 65:96 [active][ready]
The bad path toggles between active/ready and failed states depending on
the time it's sampled. When failed, its counterpart handles I/O requests:
May 27 22:22:20 box kernel: sd_init_command: disk=sdg, block=12412744, count=72
May 27 22:22:20 box kernel: sdg : block=12412744
May 27 22:22:20 box kernel: sdg : writing 72/72 512 byte blocks.
May 27 22:22:20 box kernel: scsi_add_timer: scmd: ffff8103138dab00, time: 15000, (ffffffff880062a5)
May 27 22:22:20 box kernel: sd 0:0:0:7: send 0xffff8103138dab00 sd 0:0:0:7:
May 27 22:22:20 box kernel: command: Write(10): 2a 00 00 bd 67 48 00 00 48 00
May 27 22:22:20 box kernel: buffer = 0xffff8103611f4e00, bufflen = 36864, done = 0xffffffff8802e6a6, queuecommand 0xffffffff88053250
May 27 22:22:20 box kernel: leaving scsi_dispatch_cmnd()
May 27 22:22:20 box kernel: scsi_delete_timer: scmd: ffff8103138dab00, rtn: 1
May 27 22:22:20 box kernel: sd 0:0:0:7: done 0xffff8103138dab00 SUCCESS 0 sd 0:0:0:7:
I've tracked this down in the kernel code -- it seems things get here, at
which point of the conditions in the if() below cause the logged error:
if (!sdp || !scsi_device_online(sdp) ||
block + blk_rq_sectors(rq) > get_capacity(disk)) {
SCSI_LOG_HLQUEUE(2, scmd_printk(KERN_INFO, SCpnt,
"Finishing %u sectors\n",
blk_rq_sectors(rq)));
SCSI_LOG_HLQUEUE(2, scmd_printk(KERN_INFO, SCpnt,
"Retry with 0x%p\n", SCpnt));
goto out;
}
Then tur comes around, checks the device and marks the PATH_UP, repeat.
This has happened on more than one server, in more than one datacenter.
Backend storage in all cases is an IBM SAN Volume Controller (IBM SVC
2145) with a Brocade FC fabric. Unfortunately, this isn't a reproducible
problem; however, I do have a server that's currently exhibiting this
issue. Either re-zoning the LUNs or disconnecting and reconnecting the
fibre corrects the issue, and I suspect this is because it forces the
initator to re-PLOGI to the SCSI target, although this is not certain.
Why the difference between tur's check and scsi_device_online(), assuming
this is the condition that triggers the if() above? Also, is there any
additional debugging info I can capture to further isolate this issue?
It seems to me the path should be up or down, but not flapping.
Thanks in advance,
--
William R. Lorenz
--
dm-devel mailing list
dm-devel@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/dm-devel