<div dir="ltr">Hi Darius.<div>Did you get needed files?</div><div><br></div><div>Anatoly.<br><br><div class="gmail_quote">---------- Forwarded message ----------<br>From: <b class="gmail_sendername">Anatoly G</b> <span dir="ltr">&lt;<a href="mailto:anatolyrishon@gmail.com">anatolyrishon@gmail.com</a>&gt;</span><br>
Date: Thu, Jan 12, 2012 at 11:26 AM<br>Subject: Re: [mpich-discuss] Fault tolerance - not stable.<br>To: <a href="mailto:mpich-discuss@mcs.anl.gov">mpich-discuss@mcs.anl.gov</a><br><br><br>Ok.<br>
I&quot;ll send it again.<br>
In file mpi_rcv_waitany_1__r18.log I get same print<br>
==========================================<br>
W_MpiSendSync error :<br>
------------------------------------------<br>
ErrorCode:    0x18C1AE0F<br>
==========================================<br>
63286 times. Original file size ~ 18 MB.<br>
<br>
So I deleted a lot of these prints to bring file to suitable size.<br>
<span class="HOEnZb"><font color="#888888"><br>
Anatoly.<br>
</font></span><div class="HOEnZb"><div class="h5"><br>
On Wed, Jan 11, 2012 at 7:58 PM, Darius Buntinas &lt;<a href="mailto:buntinas@mcs.anl.gov">buntinas@mcs.anl.gov</a>&gt; wrote:<br>
&gt;<br>
&gt; Anatoly,<br>
&gt;<br>
&gt; I didn&#39;t get the attachments.  Can you try again?<br>
&gt;<br>
&gt; -d<br>
&gt;<br>
&gt; On Jan 11, 2012, at 5:03 AM, Anatoly G wrote:<br>
&gt;<br>
&gt; &gt; Hi Darius.<br>
&gt; &gt; Thank you for your&#39;s response.<br>
&gt; &gt; I changed code according to your&#39;s proposition.<br>
&gt; &gt; Results:<br>
&gt; &gt; Sometimes I get fail process as expected, and one more process fails unexpectedly.<br>
&gt; &gt; I attach code &amp; logs.<br>
&gt; &gt; Execution command:<br>
&gt; &gt; mpiexec.hydra -genvall -disable-auto-cleanup -f machines_student.txt -n 24 -launcher=rsh mpi_rcv_waitany 100000 1000000 3 5 1 logs/mpi_rcv_waitany_1_<br>
&gt; &gt;<br>
&gt; &gt;       • I run 24 processes on 3 computers.<br>
&gt; &gt;       • 100000 iterations<br>
&gt; &gt;       • Expected fail of process 3 on iteration 5.<br>
&gt; &gt;       • In addition I got fail of process 18. It&#39;s logs with it&#39;s errors is mpi_rcv_waitany_1__r18.log<br>
&gt; &gt; Can you please review again my code, and give me some tips to fix application.<br>
&gt; &gt;<br>
&gt; &gt; Anatoly.<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; On Tue, Jan 10, 2012 at 9:32 PM, Anatoly G &lt;<a href="mailto:anatolyrishon@gmail.com">anatolyrishon@gmail.com</a>&gt; wrote:<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; ---------- Forwarded message ----------<br>
&gt; &gt; From: Darius Buntinas &lt;<a href="mailto:buntinas@mcs.anl.gov">buntinas@mcs.anl.gov</a>&gt;<br>
&gt; &gt; Date: Tue, Jan 10, 2012 at 8:11 PM<br>
&gt; &gt; Subject: Re: [mpich-discuss] Fault tolerance - not stable.<br>
&gt; &gt; To: <a href="mailto:mpich-discuss@mcs.anl.gov">mpich-discuss@mcs.anl.gov</a><br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; I took a look at mpi_rcv_waitany.cpp, and I found a couple of issues.  I&#39;m not sure if this is the problem, but we should fix these first.<br>
&gt; &gt;<br>
&gt; &gt; In Rcv_WaitAny(), in the while(true) loop, you do a waitany, but then you iterate over the requests and do a test.  I don&#39;t think this is what you want to do.  When waitany returns, mRcvRequests[slaveIdx] will be set to MPI_REQUEST_NULL, so the subsequent test will return MPI_SUCCESS, and you may not register a failure.<br>

&gt; &gt;<br>
&gt; &gt; Also, if all requests have previously completed, and you call waitany, then it will return and set slaveIdx to MPI_UNDEFINED, so we need to consider that case.<br>
&gt; &gt;<br>
&gt; &gt; Another issue is that you post a receive for the slave after it completes, but never wait on that request.  This is not allowed in MPI (but you can probably get away with this most of the time).<br>
&gt; &gt;<br>
&gt; &gt; I _think_ what you want to do is this:<br>
&gt; &gt;<br>
&gt; &gt;  while(mSlavesFinished &lt; mSlaves) {<br>
&gt; &gt;        retErr = MPI_Waitany(mRcvRequests.size(), &amp;*mRcvRequests.begin(), &amp;slaveIdx, &amp;status);<br>
&gt; &gt;        slaveRank = slaveIdx + 1;<br>
&gt; &gt;<br>
&gt; &gt;        if  (retErr != MPI_SUCCESS) {<br>
&gt; &gt;            char Msg[256];<br>
&gt; &gt;            sprintf(Msg, &quot;From rank %d, fail - request deallocated&quot;, slaveRank);<br>
&gt; &gt;            handleMPIerror(mFpLog, Msg, retErr, &amp;status);<br>
&gt; &gt;            mRcvRequests[slaveIdx] = MPI_REQUEST_NULL;<br>
&gt; &gt;            mIsSlaveLives[slaveIdx] = 0;<br>
&gt; &gt;            ++mSlavesFinished;<br>
&gt; &gt;            continue;<br>
&gt; &gt;        }<br>
&gt; &gt;<br>
&gt; &gt;        /* if all requests have been completed, we should have exited the loop already */<br>
&gt; &gt;        assert(slaveIdx != MPI_UNDEFINED);<br>
&gt; &gt;        /* if the slave is dead, we should not be able to receive a message from it */<br>
&gt; &gt;        assert(mIsSlaveLives[slaveIdx});<br>
&gt; &gt;<br>
&gt; &gt;        ++mSlavesRcvIters[slaveIdx];<br>
&gt; &gt;        if(mSlavesRcvIters[slaveIdx] == nIters) {<br>
&gt; &gt;            ++mSlavesFinished;<br>
&gt; &gt;            fprintf(mFpLog, &quot;\n\nFrom rank %d, Got number = %d\n &quot;, slaveRank, mRcvNumsBuf[slaveIdx]);<br>
&gt; &gt;            fprintf(mFpLog, &quot;Slave %d finished\n\n&quot;, slaveIdx+1);<br>
&gt; &gt;        } else {<br>
&gt; &gt;            MPI_Irecv(&amp;(mRcvNumsBuf[slaveIdx]), 1, MPI::INT, slaveRank, MPI::ANY_TAG, MPI_COMM_WORLD, &amp;(mRcvRequests[slaveIdx]));<br>
&gt; &gt;        }<br>
&gt; &gt;    }<br>
&gt; &gt;<br>
&gt; &gt; Give this a try and see how it works.<br>
&gt; &gt;<br>
&gt; &gt; -d<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; On Jan 10, 2012, at 12:50 AM, Anatoly G wrote:<br>
&gt; &gt;<br>
&gt; &gt; &gt; Dear mpich-discuss,<br>
&gt; &gt; &gt; I have a problem while using fault tolerance feature, in MPICH2 hydra process manager.<br>
&gt; &gt; &gt; The results are not consistent, sometimes tests pass, sometimes stall.<br>
&gt; &gt; &gt; If you executes command line written below in loop, after number of iterations, test stall.<br>
&gt; &gt; &gt; Can you please help me with this problem?<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; There are 3 tests. All 3 tests have same model master with number of slaves. Communication operations are point to point.<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; Slave algorithm is same for all 3 tests.<br>
&gt; &gt; &gt; for N times:<br>
&gt; &gt; &gt;     MPI_Send integer to master.<br>
&gt; &gt; &gt;     if IterI (parameter) &amp;&amp; rank= fail_rank<br>
&gt; &gt; &gt;         cause divide by zero exception. (A = 5.0; B = 0.0;  C = A / B;)<br>
&gt; &gt; &gt; MPI_Recv(master)<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; Master algorithm Test1 (mpi_send_rcv_waitany.cpp) :<br>
&gt; &gt; &gt;       • For each slave call MPI_Irecv<br>
&gt; &gt; &gt;       • while not got N messages from each slave continue<br>
&gt; &gt; &gt;       •       MPI_Waitany(slaveIdx)<br>
&gt; &gt; &gt;       •       if slaveIdx alive<br>
&gt; &gt; &gt;       •          MPI_Irecv(slaveIdx)<br>
&gt; &gt; &gt;       •       else<br>
&gt; &gt; &gt;       •          Mark it as finished.<br>
&gt; &gt; &gt;       • MPI_Send to all slaves .<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; Master algorithm Test2 (mpi_send_sync.cpp) :<br>
&gt; &gt; &gt;       • slave = first slave<br>
&gt; &gt; &gt;       • while not got N messages from each slave continue<br>
&gt; &gt; &gt;       •       MPI_Recv(slave)<br>
&gt; &gt; &gt;       •       if slaveIdx alive<br>
&gt; &gt; &gt;       •          pass to next live slave<br>
&gt; &gt; &gt;       •       else<br>
&gt; &gt; &gt;       •          Mark it as finished.<br>
&gt; &gt; &gt;       • MPI_Send to all slaves .<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; Master algorithm Test3 (mpi_send_async.cpp) :<br>
&gt; &gt; &gt; Same as test2, but instead of MPI_Recv, I use MPI_Irecv + MPI_Wait<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; When test stall, I connect debugger to master process.<br>
&gt; &gt; &gt; Process stall in MPI_recv, or MPI_Irecv.<br>
&gt; &gt; &gt; I think, stall caused by following sequence:<br>
&gt; &gt; &gt;       • Master receives integer from slave.<br>
&gt; &gt; &gt;       • Tests slave - it&#39;s Ok.<br>
&gt; &gt; &gt;       • Slave failes<br>
&gt; &gt; &gt;       • master try to perform MPI_Irecv or MPI_Recv on failed slave.<br>
&gt; &gt; &gt; Problem happens on cluster (student_machines.txt) &amp; on single machine (machine_student1.txt)<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; Execution lines:<br>
&gt; &gt; &gt;       • /space/local/hydra/bin/mpiexec.hydra  -genvall  -disable-auto-cleanup  -f machine_student1.txt  -n 8  -launcher=rsh mpi_rcv_waitany 100000 1000000 3 10 1 logs/mpi_rcv_waitany_it_9/res_<br>
&gt; &gt; &gt;       • /space/local/hydra/bin/mpiexec.hydra  -genvall  -disable-auto-cleanup  -f student_machines.txt  -n 12  -launcher=rsh mpi_rcv_waitany 100000 1000000 3 10 1 logs/mpi_rcv_waitany_it_9/res_<br>
&gt; &gt; &gt; Test performs 100000 iterations master with each slave.<br>
&gt; &gt; &gt; 1000000 scale number to distinguish between sequences if integers with master &amp; each slave.<br>
&gt; &gt; &gt; 3 - rank of process to cause fail (fail_rank)<br>
&gt; &gt; &gt; 10 - fail iteration. On iteration 10 process with rank 3 will cause divide by zero exception.<br>
&gt; &gt; &gt; 1 logs/mpi_rcv_waitany_it_9/res_     defines log file.<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; &lt;machine_student1.txt&gt;&lt;machines_student.txt&gt;&lt;mpi_rcv_waitany.cpp&gt;&lt;mpi_send_async.cpp&gt;&lt;mpi_send_sync.cpp&gt;&lt;mpi_test_incl.h&gt;_______________________________________________<br>

&gt; &gt; &gt; mpich-discuss mailing list     <a href="mailto:mpich-discuss@mcs.anl.gov">mpich-discuss@mcs.anl.gov</a><br>
&gt; &gt; &gt; To manage subscription options or unsubscribe:<br>
&gt; &gt; &gt; <a href="https://lists.mcs.anl.gov/mailman/listinfo/mpich-discuss" target="_blank">https://lists.mcs.anl.gov/mailman/listinfo/mpich-discuss</a><br>
&gt; &gt;<br>
&gt; &gt; _______________________________________________<br>
&gt; &gt; mpich-discuss mailing list     <a href="mailto:mpich-discuss@mcs.anl.gov">mpich-discuss@mcs.anl.gov</a><br>
&gt; &gt; To manage subscription options or unsubscribe:<br>
&gt; &gt; <a href="https://lists.mcs.anl.gov/mailman/listinfo/mpich-discuss" target="_blank">https://lists.mcs.anl.gov/mailman/listinfo/mpich-discuss</a><br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; _______________________________________________<br>
&gt; &gt; mpich-discuss mailing list     <a href="mailto:mpich-discuss@mcs.anl.gov">mpich-discuss@mcs.anl.gov</a><br>
&gt; &gt; To manage subscription options or unsubscribe:<br>
&gt; &gt; <a href="https://lists.mcs.anl.gov/mailman/listinfo/mpich-discuss" target="_blank">https://lists.mcs.anl.gov/mailman/listinfo/mpich-discuss</a><br>
&gt;<br>
&gt; _______________________________________________<br>
&gt; mpich-discuss mailing list     <a href="mailto:mpich-discuss@mcs.anl.gov">mpich-discuss@mcs.anl.gov</a><br>
&gt; To manage subscription options or unsubscribe:<br>
&gt; <a href="https://lists.mcs.anl.gov/mailman/listinfo/mpich-discuss" target="_blank">https://lists.mcs.anl.gov/mailman/listinfo/mpich-discuss</a><br>
</div></div></div><br></div></div>