<html><head><style type='text/css'>p { margin: 0; }</style></head><body><div style='font-family: arial,helvetica,sans-serif; font-size: 12pt; color: #000000'>Hi, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br><br>I'm testing setting up a Xen DomU with a DRBD storage for easy failover. Most of the time, immediately after booting the DomU, I get an IO error:<br><br><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.153370] EXT3-fs (xvda2): using internal journal</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.277115] ip_tables: (C) 2000-2006 Netfilter Core Team</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.336014] nf_conntrack version 0.5.0 (3899 buckets, 15596 max)</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.515604] init: failsafe main process (397) killed by TERM signal</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.801589] blkfront: barrier: write xvda2 op failed</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.801597] blkfront: xvda2: barrier or flush: disabled</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.801611] end_request: I/O error, dev xvda2, sector 52171168</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.801630] end_request: I/O error, dev xvda2, sector 52171168</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.801642] Buffer I/O error on device xvda2, logical block 6521396</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.801652] lost page write due to I/O error on xvda2</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.801755] Aborting journal on device xvda2.</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.804415] EXT3-fs (xvda2): error: ext3_journal_start_sb: Detected aborted journal</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.804434] EXT3-fs (xvda2): error: remounting filesystem read-only</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;3.814754] journal commit I/O error</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;6.973831] init: udev-fallback-graphics main process (538) terminated with status 1</span><br style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: arial,helvetica,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; &nbsp;6.992267] init: plymouth-splash main process (546) terminated with status 1</span><br><br>The manpage of drbdsetup says that LVM (which I use) doesn't support barriers (better known as "tagged command queuing" or "native command queuing"), so I configured the DRBD device not to use barriers. This can be seen in /proc/drbd (by "wo:f, meaning flush, the next method drbd chooses after barrier):<br><br><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;3: cs:Connected ro:Primary/Secondary ds:UpToDate/UpToDate C r----</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;ns:2160152 nr:520204 dw:2680344 dr:2678107 al:3549 bm:9183 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:0</span><br><br>And on the other host:<br><br><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;3: cs:Connected ro:Secondary/Primary ds:UpToDate/UpToDate C r----</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;ns:0 nr:2160152 dw:2160152 dr:0 al:0 bm:8052 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:0</span><br><br>I also enabled the option disable_sendpage, as per the DRBD docs:<br><br><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">cat /sys/module/drbd/parameters/disable_sendpage</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">Y</span><br><br>I also tried adding barriers=0 to fstab as mount option. Still it says:<br><br><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; 58.603896] blkfront: barrier: write xvda2 op failed</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">[ &nbsp; 58.603903] blkfront: xvda2: barrier or flush: disabled</span><br><br>I don't even know if ext3 has a nobarrier option, but it does seem to work. But, because only one of my storage systems is battery backed, it would not be smart.<br><br>Why does it still compain about barriers when I disabled that?<br><br>Both hosts are:<br><br>Debian: 6.0.4<br>uname -a: Linux 2.6.32-5-xen-amd64<br>drbd: 8.3.7<br>Xen: 4.0.1<br><br>Guest:<br><br>Ubuntu 12.04 LTS<br>uname -a: Linux 3.2.0-24-generic pvops<br><br>drbd resource:<br><br><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">resource drbdvm</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">{</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;meta-disk internal;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;device /dev/drbd3;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;startup</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;{</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# The timeout value when the last known state of the other side was available. 0 means infinite.</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;wfc-timeout 0;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# Timeout value when the last known state was disconnected. 0 means infinite.</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;degr-wfc-timeout 180;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;}</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;syncer</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;{</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# This is recommended only for low-bandwidth lines, to only send those</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# blocks which really have changed.</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;#csums-alg md5;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# Set to about half your net speed</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;rate 60M;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# It seems that this option moved to the 'net' section in drbd 8.4. (later release than Debian has currently)</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;verify-alg md5;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;}</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;net</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;{</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# The manpage says this is recommended only in pre-production (because of its performance), to determine</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# if your LAN card has a TCP checksum offloading bug.</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;#data-integrity-alg md5;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;}</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;disk</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;{</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# Detach causes the device to work over-the-network-only after the</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# underlying disk fails. Detach is not default for historical reasons, but is</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# recommended by the docs.</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# However, the Debian defaults in drbd.conf suggest the machine will reboot in that event...</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;on-io-error detach;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# LVM doesn't support barriers, so disabling it. It will revert to flush. Check wo: in /proc/drbd. If you don't disable it, you get IO errors.</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;no-disk-barrier;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;}</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;on host1</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;{</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# universe is a VG</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;disk /dev/universe/drbdvm-disk;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;address 10.0.0.1:7792;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;}</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;on host2</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;{</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;# universe is a VG</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;disk /dev/universe/drbdvm-disk;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp; &nbsp;address 10.0.0.2:7792;</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">&nbsp;&nbsp;}</span><br style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);"><span style="font-family: courier new,courier,monaco,monospace,sans-serif; color: rgb(0, 0, 153);">}</span><br><br><p>In my test setup: the primary host's storage is 9650SE SATA-II RAID PCIe with battery. The secondary is software RAID1.</p>

<p><br></p><p>Isn't DRBD+Xen widely used? With these problems, it's not going to work.</p><p><br></p><p>Any help welcome.<br></p><br></div></body></html>