<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class="">I don’t see it.  I was waiting for today when my crontab triggered the update and no users or nodes were disconnected and it updated just fine like should.  My Perl is weak to non existent but the if(!$pid) block looks like an exception handler to me.<div class=""><br class=""></div><div class="">It works perfect on 1.57 Build 344.</div><div class=""><br class=""></div><div class="">Those with more Perl knowledge can correct me, but it looks like it is doing as expected.</div><div class=""><br class=""></div><div class="">Joe N9JR<br class=""><div class=""><br class=""></div><div class=""><br class=""><div><br class=""><blockquote type="cite" class=""><div class="">On Apr 8, 2021, at 8:42 AM, David Spoelstra via Dxspider-support <<a href="mailto:dxspider-support@tobit.co.uk" class="">dxspider-support@tobit.co.uk</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class=""><span style="font-family:Verdana;font-size:12px" class="">Saki-</span><div class="">You are correct! Good catch! I dug into the "spawn" code in DXCron.pm (below) and I see that "spawn" does a "DXChannel::closeall();". I don't know why, but Dirk must have decided it was needed.</div><div class="">-David, N9KT</div><div class=""><br class=""></div><div class=""># spawn any old job off<br class="">sub spawn<br class="">{<br class="">        my $line = shift;<br class="">        <br class="">        my $pid = fork();<br class="">        if (defined $pid) {<br class="">                if (!$pid) {<br class="">                        # in child, unset warnings, disable debugging and general clean up from us<br class="">                        $^W = 0;<br class="">                        eval "{ package DB; sub DB {} }";<br class="">                        DXChannel::closeall();<br class="">                        for (@main::listeners) {<br class="">                                $_->close_server;<br class="">                        }<br class="">                        unless ($main::is_win) {<br class="">                                $SIG{HUP} = 'IGNORE';<br class="">                                $SIG{CHLD} = $SIG{TERM} = $SIG{INT} = $SIG{__WARN__} = 'DEFAULT';<br class="">                                alarm(0);<br class="">                        }<br class="">                        exec "$line" or dbg("exec '$line' failed $!") if isdbg('cron');<br class="">                }<br class="">                dbg("spawn of $line started") if isdbg('cron');<br class="">        } else {<br class="">                dbg("can't fork for $line $!") if isdbg('cron');<br class="">        }<br class=""><br class="">        # coordinate<br class="">        sleep(1);<br class="">}<br class=""></div></div><br class=""><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Apr 8, 2021 at 3:32 AM dd5xx--- via Dxspider-support <<a href="mailto:dxspider-support@tobit.co.uk" class="">dxspider-support@tobit.co.uk</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class=""><div style="font-family:Verdana;font-size:12px" class=""><div class="">
<div class="">Hi David et all,</div>
<div class=""> </div>
<div class="">thanks for sharing your local crontab script. I have implemented my updates via my own bash script, independent of DXspider. I actually do the exact same thing, however the DXspider process doesn't get anything out of it except at the end when I run the load/prefix.</div>
<div class=""> </div>
<div class="">I like to think outside the box and have also tried it via Spiders' local crontab as you suggested. However, while following along using 'watchdbg' and 'set/debug cron', I noticed that *EVERY* 'spawn' command in the crontab causes all connected users and nodes to be disconnected! In the watchdbg output window it looks like this:</div>
<div class=""> </div>
<div class="">06:59:01 DXCommand<br class="">
06:59:01 DL1ABC disconnected<br class="">
06:59:01 DXCommand<br class="">
06:59:01 DL2ABC-5 disconnected<br class="">
06:59:01 DXCommand<br class="">
06:59:01 DL3ABC disconnected<br class="">
06:59:01 DXCommand<br class="">
06:59:35 DXCommand<br class="">
06:59:35 DL1ABC connected from 111.222.33.44</div>
<div class=""> </div>
<div class="">The documentation for DXspider crontab <<a href="http://www.dxcluster.org/main/cron.html" target="_blank" class="">http://www.dxcluster.org/main/cron.html</a>> unfortunately does not give a more detailed information.</div>
<div class=""><br class="">
[...]<br class="">
spawn(<command>) - start a <command> as a new process. This is used to do various batch jobs that you may wish to happen at certain times of the day or week that operate on your machine but don't require access to the real-time internals of the cluster daemon. You can execute just about any command you like, but be warned stdin and stdout are still connected to the same terminal (if any) as the cluster daemon. Any unix command and arguments can be used, see exec in the perl documentation.</div>
<div class="">[...]</div>
<div class=""> </div>
<div class="">For my needs the spawn event and the resulted disconnects for users/nodes is a no-go as I don't want my connected users+nodes to be disconnected. So I will continue to use my own external bash script for the cty.dat and wpxloc.raw updates as usual.</div>
<div class=""> </div>
<div class="">==> Nevertheless, I'm curious if this is also the case for you, that the currently connected users+nodes are disconnected at the spawn command ? Looking forward to hear some comments.</div>
<div class=""> </div>
<div class="">I want to add that I do not use Mojo but still (consciously) running version 1.55</div>
<div class=""> </div>
<div class="">73</div>
<div class="">Saki, DD5XX</div>
</div>
<div class=""> 
<div class=""> 
<div name="quote" style="margin:10px 5px 5px 10px;padding:10px 0px 10px 10px;border-left:2px solid rgb(195,217,229)" class="">
<div style="margin:0px 0px 10px" class=""><b class="">Gesendet:</b> Donnerstag, 04. März 2021 um 04:14 Uhr<br class="">
<b class="">Von:</b> "David Spoelstra via Dxspider-support" <<a href="mailto:dxspider-support@tobit.co.uk" target="_blank" class="">dxspider-support@tobit.co.uk</a>><br class="">
<b class="">An:</b> "The DXSpider Support list" <<a href="mailto:dxspider-support@tobit.co.uk" target="_blank" class="">dxspider-support@tobit.co.uk</a>><br class="">
<b class="">Cc:</b> "David Spoelstra" <<a href="mailto:davids@mediamachine.com" target="_blank" class="">davids@mediamachine.com</a>><br class="">
<b class="">Betreff:</b> Re: [Dxspider-support] CTY-3105 Country Files - 03 March 2021</div>
<div name="quoted-content" class="">
<div class="">OK, found the problem. I was using http vs https when I fetched the file - that made all the difference.
<div class=""> </div>
<div class="">If anyone wants to use my DXSpider cron, you are most welcome. Just to make sure everyone understands, you can put a crontab in /spider/local_cmd/ and it will run. I put all my DXSpider stuff in there to keep everything dealing with DXSpider in one place.</div>
<div class=""> </div>
<div class="">My DXSpider crontab in /spider/local_cmd/:</div>
<div class=""> </div>
<div class=""># /spider/local_cmd/crontab<br class="">
# MAKE SURE /spider/cmd_import EXISTS!<br class="">
# min, hour, day-of-month, month, day-of-week (0=Sun)<br class="">
# TIME IS UTC!<br class="">
<br class="">
# Connect to other nodes<br class="">
* * * * * start_connect('w9pa') unless connected('w9pa')<br class="">
* * * * * start_connect('wb3ffv') unless connected('wb3ffv')<br class="">
* * * * * start_connect('ky4xx') unless connected('ky4xx')<br class="">
<br class="">
# Monday 1am local - Get latest FCC data (W1NR updates Sundays)<br class="">
0 5 * * 1 spawn("cd /tmp && wget -Nq <a href="ftp://ftp.w1nr.net/usdbraw.gz" target="_blank" class="">ftp://ftp.w1nr.net/usdbraw.gz</a> && /spider/perl/<a href="http://create_usdb.pl/" target="_blank" class="">create_usdb.pl</a> usdbraw.gz")<br class="">
2 5 * * 1 run_cmd("load/usdb")<br class="">
4 5 * * 1 spawn("rm /tmp/usdbraw.gz")<br class="">
<br class="">
# Friday 1am local - Get latest Keps to be ready for any contest<br class="">
0 5 * * 5 spawn("cd /tmp && wget -Nq <a href="https://www.amsat.org/amsat/ftp/keps/current/nasabare.txt" target="_blank" class="">https://www.amsat.org/amsat/ftp/keps/current/nasabare.txt</a> && /spider/perl/<a href="http://convkeps.pl/" target="_blank" class="">convkeps.pl</a> -p nasabare.txt")<br class="">
2 5 * * 5 run_cmd("load/keps")<br class="">
4 5 * * 5 spawn("rm /tmp/nasabare.txt")<br class="">
<br class="">
# Friday 1am local - Get latest cty.dat to be ready for any contest<br class="">
6  5 * * 5 spawn("cd /spider/data && wget -Nq <a href="https://www.country-files.com/cty/cty.dat" target="_blank" class="">https://www.country-files.com/cty/cty.dat</a>")<br class="">
8  5 * * 5 spawn("cd /spider/data && wget -Nq <a href="https://www.country-files.com/cty/wpxloc.raw" target="_blank" class="">https://www.country-files.com/cty/wpxloc.raw</a>")<br class="">
10 5 * * 5 spawn("cd /spider/data && /spider/perl/<a href="http://create_prefix.pl/" target="_blank" class="">create_prefix.pl</a>")<br class="">
12 5 * * 5 run_cmd("load/prefixes")<br class="">
<br class="">
# Friday 1am local - Update DXSpider to be ready for any contest<br class="">
14 5 * * 5 spawn("cd /spider && git reset --hard && git pull")</div>
<div class=""> </div>
<div class="">-David, N9KT</div>
</div>
</div>
</div>
</div>
</div></div></div>
_______________________________________________<br class="">
Dxspider-support mailing list<br class="">
<a href="mailto:Dxspider-support@tobit.co.uk" target="_blank" class="">Dxspider-support@tobit.co.uk</a><br class="">
<a href="https://mailman.tobit.co.uk/mailman/listinfo/dxspider-support" rel="noreferrer" target="_blank" class="">https://mailman.tobit.co.uk/mailman/listinfo/dxspider-support</a><br class="">
</blockquote></div>
_______________________________________________<br class="">Dxspider-support mailing list<br class=""><a href="mailto:Dxspider-support@tobit.co.uk" class="">Dxspider-support@tobit.co.uk</a><br class="">https://mailman.tobit.co.uk/mailman/listinfo/dxspider-support<br class=""></div></blockquote></div><br class=""></div></div></body></html>