<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
p.msonormal0, li.msonormal0, div.msonormal0
        {mso-style-name:msonormal;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">Okay, here’s the latest.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I ran the TrimTester tool on two separate servers in DRBD standalone mode, and both wrote 24TB to disk without any file corruption errors. I then connected and sync’d the nodes and ran the test again with replication enabled. TrimTester
detected file corruption after a few hours.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">The supposedly “corrupted” file is 4.9GB in size (as expected, over 4GB). The file name is ’50.’ It contains a repeating sequence of characters that looks like this:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"># od -b 50 | more<o:p></o:p></p>
<p class="MsoNormal">0000000 001 002 003 004 005 006 007 010 011 012 013 014 015 016 017 020<o:p></o:p></p>
<p class="MsoNormal">0000020 021 022 023 024 025 026 027 030 031 032 033 034 035 036 037 040<o:p></o:p></p>
<p class="MsoNormal">0000040 041 042 043 044 045 046 047 050 051 052 053 054 055 056 057 060<o:p></o:p></p>
<p class="MsoNormal">0000060 061 062 063 064 065 066 067 070 071 072 073 074 075 076 077 100<o:p></o:p></p>
<p class="MsoNormal">0000100 101 102 103 104 105 106 107 110 111 112 113 114 115 116 117 120<o:p></o:p></p>
<p class="MsoNormal">0000120 121 122 123 124 125 126 127 130 131 132 133 134 135 136 137 140<o:p></o:p></p>
<p class="MsoNormal">0000140 141 142 143 144 145 146 147 150 151 152 153 154 155 156 157 160<o:p></o:p></p>
<p class="MsoNormal">0000160 161 162 163 164 165 166 167 170 171 172 173 174 175 176 177 200<o:p></o:p></p>
<p class="MsoNormal">0000200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220<o:p></o:p></p>
<p class="MsoNormal">0000220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240<o:p></o:p></p>
<p class="MsoNormal">0000240 241 242 243 244 245 246 247 250 251 252 253 254 255 256 257 260<o:p></o:p></p>
<p class="MsoNormal">0000260 261 262 263 264 265 266 267 270 271 272 273 274 275 276 277 300<o:p></o:p></p>
<p class="MsoNormal">0000300 301 302 303 304 305 306 307 310 311 312 313 314 315 316 317 320<o:p></o:p></p>
<p class="MsoNormal">0000320 321 322 323 324 325 326 327 330 331 332 333 334 335 336 337 340<o:p></o:p></p>
<p class="MsoNormal">0000340 341 342 343 344 345 346 347 350 351 352 353 354 355 356 357 360<o:p></o:p></p>
<p class="MsoNormal">0000360 361 362 363 364 365 366 367 370 371 372 373 374 375 376 377 000<o:p></o:p></p>
<p class="MsoNormal"><snip><o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">The same sequence repeats to the end of the file. As you can see, each iteration of the character sequence ends with a zero/null. However, there are no zeroes anywhere else in the file except at the end of every sequence.
<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I guess it is safe to conclude that your theory is right. The file does not appear to really be corrupted. The TrimTester tool is reporting a false positive.
<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">--Eric <o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b>From:</b> drbd-user-bounces@lists.linbit.com [mailto:drbd-user-bounces@lists.linbit.com]
<b>On Behalf Of </b>Lars Ellenberg<br>
<b>Sent:</b> Tuesday, October 17, 2017 9:24 AM<br>
<b>To:</b> drbd-user@lists.linbit.com<br>
<b>Subject:</b> Re: [DRBD-user] Warning: Data Corruption Issue Discovered in DRBD 8.4 and 9.0<o:p></o:p></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div>
<div>
<div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt">> Most importantly: once the trimtester (or *any* "corruption detecting"<br>
> tool) claims that a certain corruption is found, you look at what supposedly is<br>
> corrupt, and double check if it in fact is.<br>
><br>
> Before doing anything else.<br>
><o:p></o:p></p>
</div>
<p class="MsoNormal">I did that, but I don't know what a "good" file is supposed to look like, so I can't tell whether it is really corrupted.<o:p></o:p></p>
</blockquote>
</div>
</div>
</div>
<div>
<div>
<div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<p class="MsoNormal">The last time TrimTester reported a corrupt file, I checked it manually and it looked fine to me, but I don't know what I'm looking for.<o:p></o:p></p>
</blockquote>
</div>
</div>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<div>
<p class="MsoNormal"><span style="font-family:"Arial",sans-serif">For it to be reported as corrupted by trimester, it would need to contain at least one aligned 512 byte sector full of zeroes. Did it? Did it contain even two zero bytes next to each other?<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-family:"Arial",sans-serif"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-family:"Arial",sans-serif">Or simply the same 256 byte cyclic pattern that is written by this tool?<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-family:"Arial",sans-serif"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-family:"Arial",sans-serif">If so, then obviously the tool in error claimed to find a corruption that clearly was not there.<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-family:"Arial",sans-serif"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-family:"Arial",sans-serif">Feel free to keep using that tool, but fix it first, change the unsigned i and j to size_t or uint64_t. And maybe have it really check all files, before removing them.<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="font-family:"Arial",sans-serif"><o:p> </o:p></span></p>
</div>
</div>
</div>
</div>
</div>
</body>
</html>