<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Jul 3, 2020 at 4:27 PM Fernando Benavides <<a href="mailto:elbrujohalcon@gmail.com">elbrujohalcon@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div style="font-family:"trebuchet ms",sans-serif">Hi Lukas,</div><div style="font-family:"trebuchet ms",sans-serif"><br></div><div style="font-family:"trebuchet ms",sans-serif">Thanks for the tip! We actually use those extended stats from time to time to profile our systems but I don't have them turned on in the machines I'm using now. In any case, hey might tell me which specific parts of the emulator the scheduler is spending less time on, but… they won't tell me what extra auxiliary tasks it is handling, right?</div></div></blockquote><div><br></div><div>Parts of what is normally the aux state will be moved to other new states when you enable the extra states.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div style="font-family:"trebuchet ms",sans-serif"><br></div><div style="font-family:"trebuchet ms",sans-serif">I'll run a test with extended microaccounting, probably next week, but do you know a way to figure out what the extra auxiliary jobs that my scheduler is running are?</div></div></blockquote><div><br></div><div>If you don't feel like coding some C you might want to try perf and see what it can tell you.</div><div><br></div><div>If you feel like coding some C you can add the extra states to msacc for each of the aux jobs that are done and then check which one it is.</div><div><br></div><div>You add new states here: <a href="https://github.com/erlang/otp/blob/master/erts/emulator/beam/erl_msacc.h#L59">https://github.com/erlang/otp/blob/master/erts/emulator/beam/erl_msacc.h#L59</a></div><div>The different aux actions can be found here: <a href="https://github.com/erlang/otp/blob/master/erts/emulator/beam/erl_process.h#L299-L319">https://github.com/erlang/otp/blob/master/erts/emulator/beam/erl_process.h#L299-L319</a></div><div>And the calls to them can be found here: <a href="https://github.com/erlang/otp/blob/master/erts/emulator/beam/erl_process.c#L2588-L2663">https://github.com/erlang/otp/blob/master/erts/emulator/beam/erl_process.c#L2588-L2663</a></div><div><br></div><div>It should be enough to add a ERTS_MSACC_SET_STATE_M call before each of the clauses.</div><div><br></div><div>Lukas</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div style="font-family:"trebuchet ms",sans-serif"><span style="font-family:Arial,Helvetica,sans-serif"> </span><br></div></div></blockquote><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div style="font-family:"trebuchet ms",sans-serif"></div><div style="font-family:"trebuchet ms",sans-serif">Cheers!</div><div style="font-family:"trebuchet ms",sans-serif"><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Jul 3, 2020 at 4:22 PM Lukas Larsson <<a href="mailto:lukas@erlang.org" target="_blank">lukas@erlang.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div>Hello,</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Jul 3, 2020 at 4:14 PM Fernando Benavides <<a href="mailto:elbrujohalcon@gmail.com" target="_blank">elbrujohalcon@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div style="font-family:"trebuchet ms",sans-serif">Hi Erlangers,</div><div style="font-family:"trebuchet ms",sans-serif"><br></div><div style="font-family:"trebuchet ms",sans-serif">It's me again… still trying to understand why my system behaves worse in OTP22 than OTP21.</div><div style="font-family:"trebuchet ms",sans-serif">The last thing I tried was running <a href="http://erlang.org/doc/man/msacc.html" target="_blank">MicroStateAccounting</a> on it and the results showed something <i>odd</i>…</div><div style="font-family:"trebuchet ms",sans-serif"><br></div><div style="font-family:"trebuchet ms",sans-serif">These are two of my summaries for OTP21:</div><div><font size="1" face="monospace">Stats per type:<br>  Â  Â  Â  Thread Â  Â  Â <b>aux</b> check_io <b>emulator</b> Â  Â  Â  gc Â  Â other Â  Â  port Â  Â sleep<br>  Â  Â  Â  Â async Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â 100.00%<br>  Â  Â  Â  Â  Â aux Â  Â 0.23% Â  Â 0.06% Â  Â 0.00% Â  Â 0.00% Â  Â 0.09% Â  Â 0.00% Â  99.62%<br>dirty_cpu_sche Â  Â 0.00% Â  Â 0.00% Â  Â 0.01% Â  Â 0.20% Â  Â 0.00% Â  Â 0.00% Â  99.79%<br>dirty_io_sched Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â 100.00%<br>  Â  Â  Â  Â  poll Â  Â 0.00% Â  Â 0.58% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  99.42%<br>  Â  Â scheduler Â  Â <b>2.05%</b> Â  Â 0.56% Â  <b>71.29%</b> Â  13.25% Â  Â 3.00% Â  Â 1.89% Â  Â 7.96%<br>ok<br><br>Stats per type:<br>  Â  Â  Â  Â async Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â 100.00%<br>  Â  Â  Â  Â  Â aux Â  Â 0.23% Â  Â 0.07% Â  Â 0.00% Â  Â 0.00% Â  Â 0.08% Â  Â 0.00% Â  99.62%<br>dirty_cpu_sche Â  Â 0.00% Â  Â 0.00% Â  Â 0.01% Â  Â 0.29% Â  Â 0.00% Â  Â 0.00% Â  99.70%<br>dirty_io_sched Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â 100.00%<br>  Â  Â  Â  Â  poll Â  Â 0.00% Â  Â 0.61% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  99.39%<br>  Â  Â <b>scheduler</b> Â  Â <b>2.26%</b> Â  Â 0.56% Â  <b>68.70%</b> Â  12.69% Â  Â 3.42% Â  Â 1.89% Â  10.48%<br>ok</font><br></div><div style="font-family:"trebuchet ms",sans-serif"><br></div><div><div style="font-family:"trebuchet ms",sans-serif">These are the corresponding two summaries for OTP22 (same period of time, same code, running the same things):</div><div><font size="1" face="monospace">Stats per type:<br>  Â  Â  Â  Thread Â  Â  Â <b>aux</b> check_io <b>emulator</b> Â  Â  Â  gc Â  Â other Â  Â  port Â  Â sleep<br>  Â  Â  Â  Â async Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â 100.00%<br>  Â  Â  Â  Â  Â aux Â  Â 0.49% Â  Â 0.06% Â  Â 0.00% Â  Â 0.00% Â  Â 0.28% Â  Â 0.00% Â  99.16%<br>dirty_cpu_sche Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.19% Â  Â 0.00% Â  Â 0.00% Â  99.80%<br>dirty_io_sched Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  99.99%<br>  Â  Â  Â  Â  poll Â  Â 0.00% Â  Â 0.53% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  99.47%<br>  Â  Â <b>scheduler</b> Â  Â <b>6.26%</b> Â  Â 0.52% Â  <b>63.83%</b> Â  14.41% Â  Â 3.05% Â  Â 1.72% Â  10.20%<br>ok</font></div><div><font size="1" face="monospace"><br>Stats per type:<br>  Â  Â  Â  Â async Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â 100.00%<br>  Â  Â  Â  Â  Â aux Â  Â 0.39% Â  Â 0.07% Â  Â 0.00% Â  Â 0.00% Â  Â 0.18% Â  Â 0.00% Â  99.36%<br>dirty_cpu_sche Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.22% Â  Â 0.00% Â  Â 0.00% Â  99.78%<br>dirty_io_sched Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  99.99%<br>  Â  Â  Â  Â  poll Â  Â 0.00% Â  Â 0.51% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  Â 0.00% Â  99.49%<br>  Â  Â <b>scheduler</b> Â  Â <b>6.97%</b> Â  Â 0.54% Â  <b>63.88%</b> Â  13.73% Â  Â 3.19% Â  Â 1.74% Â  Â 9.96%<br>ok</font><br></div></div><div><br></div><div><div style="font-family:"trebuchet ms",sans-serif">I highlighted the strange/different parts there, but in a nutshell:</div><div style="font-family:"trebuchet ms",sans-serif">The scheduler is spending more time <i>handling </i><b><i>auxiliary jobs</i> </b>and less time <i>executing Erlang processes </i>(<a href="http://erlang.org/doc/man/erlang.html#statistics_microstate_accounting" target="_blank">for context</a>).</div><div style="font-family:"trebuchet ms",sans-serif">Can anybody give me a clue as to what to check next? How can I determine what are those <i><b>auxiliary jobs</b></i> that the scheduler is working on now?</div><div style="font-family:"trebuchet ms",sans-serif"><br></div></div></div></blockquote><div><br></div><div>You can enable more msacc stats by turning on extra states. This is a compile-time flag that you pass to configure: ./configure --with-microstate-accounting=extra</div><div><br></div><div>My guess would be that the extra time ends up in the alloc state, which means that it for some reason extra memory allocation is happening which is slowing down the system.</div><div><br></div><div>Lukas</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div><div style="font-family:"trebuchet ms",sans-serif"></div><div style="font-family:"trebuchet ms",sans-serif">Thanks in advance :)</div><br></div><div><br></div>-- <br><div dir="ltr"><table border="0" cellpadding="0" cellspacing="0">
    <tbody>
        <tr>
            <td align="left" valign="bottom" width="107" style="line-height:0;vertical-align:bottom;padding-right:10px;padding-top:20px;padding-bottom:20px">
                <a href="https://about.me/elbrujohalcon?promo=email_sig&utm_source=product&utm_medium=email_sig&utm_campaign=gmail_api&utm_content=thumb" style="text-decoration:none" target="_blank">
                    <img alt="" width="105" height="70" style="margin: 0px; padding: 0px; display: block; border: 1px solid rgb(238, 238, 238);">
                </a>
            </td>
            <td align="left" valign="bottom" style="line-height:1.1;vertical-align:bottom;padding-top:20px;padding-bottom:20px">
                <img width="1" height="1" style="border: 0px; margin: 0px; padding: 0px; overflow: hidden;">
                <div style="font-size:18px;font-weight:bold;color:rgb(51,51,51);font-family:"Proxima Nova",Helvetica,Arial,sans-serif">Brujo Benavides</div>
                <a href="https://about.me/elbrujohalcon?promo=email_sig&utm_source=product&utm_medium=email_sig&utm_campaign=gmail_api&utm_content=thumb" style="text-decoration:none;font-size:12px;color:rgb(43,130,173);font-family:"Proxima Nova",Helvetica,Arial,sans-serif" target="_blank">about.me/elbrujohalcon
                </a>
            </td>
        </tr>
    </tbody>
</table>
</div></div>
</blockquote></div></div>
</blockquote></div><br clear="all"><div><br></div>-- <br><div dir="ltr"><table border="0" cellpadding="0" cellspacing="0">
    <tbody>
        <tr>
            <td align="left" valign="bottom" width="107" style="line-height:0;vertical-align:bottom;padding-right:10px;padding-top:20px;padding-bottom:20px">
                <a href="https://about.me/elbrujohalcon?promo=email_sig&utm_source=product&utm_medium=email_sig&utm_campaign=gmail_api&utm_content=thumb" style="text-decoration:none" target="_blank">
                    <img alt="" width="105" height="70" style="margin: 0px; padding: 0px; display: block; border: 1px solid rgb(238, 238, 238);">
                </a>
            </td>
            <td align="left" valign="bottom" style="line-height:1.1;vertical-align:bottom;padding-top:20px;padding-bottom:20px">
                <img width="1" height="1" style="border: 0px; margin: 0px; padding: 0px; overflow: hidden;">
                <div style="font-size:18px;font-weight:bold;color:rgb(51,51,51);font-family:"Proxima Nova",Helvetica,Arial,sans-serif">Brujo Benavides</div>
                <a href="https://about.me/elbrujohalcon?promo=email_sig&utm_source=product&utm_medium=email_sig&utm_campaign=gmail_api&utm_content=thumb" style="text-decoration:none;font-size:12px;color:rgb(43,130,173);font-family:"Proxima Nova",Helvetica,Arial,sans-serif" target="_blank">about.me/elbrujohalcon
                </a>
            </td>
        </tr>
    </tbody>
</table>
</div>
</blockquote></div></div>