Added “round [number]” to every status “eecho”; changed all “echo('...')” to “echo '...'”
This commit is contained in:
parent
ececc8e8c8
commit
6a750a2f3c
1 changed files with 33 additions and 31 deletions
|
@ -164,10 +164,10 @@ for ($i=1; $i<$argc; $i++) {
|
||||||
$opts['minmsgimplev']=array_search(ucfirst(strtolower($argv[$i])),$msglevs);
|
$opts['minmsgimplev']=array_search(ucfirst(strtolower($argv[$i])),$msglevs);
|
||||||
} elseif ($argv[$i]=='-G' || $argv[$i]=='--graceline') {
|
} elseif ($argv[$i]=='-G' || $argv[$i]=='--graceline') {
|
||||||
$graceline=time()-$opts['gracetime'];
|
$graceline=time()-$opts['gracetime'];
|
||||||
echo('Graceline: '.$graceline.' ('.date('Y-m-d H:i:s',$graceline).').'.N);
|
echo 'Graceline: '.$graceline.' ('.date('Y-m-d H:i:s',$graceline).').'.N;
|
||||||
exit(0);
|
exit(0);
|
||||||
} elseif ($argv[$i]=='-h' || $argv[$i]=='--help') {
|
} elseif ($argv[$i]=='-h' || $argv[$i]=='--help') {
|
||||||
echo($help);
|
echo $help;
|
||||||
exit(0);
|
exit(0);
|
||||||
} else {
|
} else {
|
||||||
mexit(3,'don’t know how to interpret «'.$argv[$i].'» (use «-h» to read the help text).'.N,1,false);
|
mexit(3,'don’t know how to interpret «'.$argv[$i].'» (use «-h» to read the help text).'.N,1,false);
|
||||||
|
@ -241,6 +241,7 @@ exit(0);
|
||||||
|
|
||||||
function crawl(&$list,$id) {
|
function crawl(&$list,$id) {
|
||||||
global $insts, $ckinsts, $deadinsts, $tini, $opts, $maxround, $totnewc, $link;
|
global $insts, $ckinsts, $deadinsts, $tini, $opts, $maxround, $totnewc, $link;
|
||||||
|
// wouldn't make sense to filter $list here: filtering already happens before adding an instance to next round list
|
||||||
$newc=0;
|
$newc=0;
|
||||||
lecho(1,'###### START OF ROUND '.$id.' ######'.N);
|
lecho(1,'###### START OF ROUND '.$id.' ######'.N);
|
||||||
$clist=count($list);
|
$clist=count($list);
|
||||||
|
@ -252,27 +253,27 @@ function crawl(&$list,$id) {
|
||||||
$responded=false;
|
$responded=false;
|
||||||
$i++;
|
$i++;
|
||||||
lecho(1,'round '.$id.': working on instance «'.$inst.'» ('.$i.'/'.$clist.').'.N);
|
lecho(1,'round '.$id.': working on instance «'.$inst.'» ('.$i.'/'.$clist.').'.N);
|
||||||
updexarr();
|
updexarr($id);
|
||||||
waituntilonline();
|
waituntilonline($id);
|
||||||
lecho(1,'trying to load instance «'.$inst.'»’s peers...'.N);
|
lecho(1,'round '.$id.': trying to load instance «'.$inst.'»’s peers...'.N);
|
||||||
$peers=gurl('https://'.$inst.'/api/v1/instance/peers',$opts['conntimeout'],$opts['functimeout']);
|
$peers=gurl('https://'.$inst.'/api/v1/instance/peers',$opts['conntimeout'],$opts['functimeout']);
|
||||||
if ($peers['cont']===false) {
|
if ($peers['cont']===false) {
|
||||||
lecho(2,'could not load instance «'.$inst.'»’s peers: '.$peers['emsg'].'.'.N);
|
lecho(2,'round '.$id.': could not load instance «'.$inst.'»’s peers: '.$peers['emsg'].'.'.N);
|
||||||
} else {
|
} else {
|
||||||
$peers=@json_decode($peers['cont'],true);
|
$peers=@json_decode($peers['cont'],true);
|
||||||
if (!is_array($peers)) {
|
if (!is_array($peers)) {
|
||||||
lecho(2,'expecting instance «'.$inst.'»’s peers, got bad JSON instead.'.N);
|
lecho(2,'round '.$id.': expecting instance «'.$inst.'»’s peers, got bad JSON instead.'.N);
|
||||||
} else {
|
} else {
|
||||||
$responded=true;
|
$responded=true;
|
||||||
$cpeers=count($peers);
|
$cpeers=count($peers);
|
||||||
lecho(1,'successfully loaded instance «'.$inst.'»’s peers ('.$cpeers.') :-)'.N);
|
lecho(1,'round '.$id.': successfully loaded instance «'.$inst.'»’s peers ('.$cpeers.') :-)'.N);
|
||||||
$pi=1;
|
$pi=1;
|
||||||
foreach ($peers as $key=>$peer) {
|
foreach ($peers as $key=>$peer) {
|
||||||
if ($key!=$pi-1) {
|
if ($key!=$pi-1) {
|
||||||
lecho(2,'instance «'.$inst.'»’s peers: entity '.$pi.'/'.$cpeers.'’s key is not sequential: not checking further.'.N);
|
lecho(2,'round '.$id.': instance «'.$inst.'»’s peers: entity '.$pi.'/'.$cpeers.'’s key is not sequential: not checking further.'.N);
|
||||||
break;
|
break;
|
||||||
} elseif (!is_string($peer)) {
|
} elseif (!is_string($peer)) {
|
||||||
lecho(2,'instance «'.$inst.'»’s peers: entity '.$pi.'/'.$cpeers.' is not a string: not checking further.'.N);
|
lecho(2,'round '.$id.': instance «'.$inst.'»’s peers: entity '.$pi.'/'.$cpeers.' is not a string: not checking further.'.N);
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
$whynot=[];
|
$whynot=[];
|
||||||
|
@ -283,9 +284,9 @@ function crawl(&$list,$id) {
|
||||||
if (in_array($peer,$nlist)) $whynot[]='it is already present in next round list';
|
if (in_array($peer,$nlist)) $whynot[]='it is already present in next round list';
|
||||||
if ($opts['excludedead'] && in_array($peer,$deadinsts)) $whynot[]='it’s dead';
|
if ($opts['excludedead'] && in_array($peer,$deadinsts)) $whynot[]='it’s dead';
|
||||||
if (count($whynot)>0) {
|
if (count($whynot)>0) {
|
||||||
lecho(0,'instance «'.$inst.'»: not adding peer «'.$peer.'» ('.$pi.'/'.$cpeers.') to next round list: '.implode(', ',$whynot).'.'.N);
|
lecho(0,'round '.$id.': instance «'.$inst.'»: not adding peer «'.$peer.'» ('.$pi.'/'.$cpeers.') to next round list: '.implode(', ',$whynot).'.'.N);
|
||||||
} else {
|
} else {
|
||||||
lecho(1,'instance «'.$inst.'»: adding peer «'.$peer.'» ('.$pi.'/'.$cpeers.') to next round list :-)'.N);
|
lecho(1,'round '.$id.': instance «'.$inst.'»: adding peer «'.$peer.'» ('.$pi.'/'.$cpeers.') to next round list :-)'.N);
|
||||||
$nlist[]=$peer;
|
$nlist[]=$peer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -294,52 +295,53 @@ function crawl(&$list,$id) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!$responded) {
|
if (!$responded) {
|
||||||
lecho(1,'instance «'.$inst.'» didn’t respond at its “peers” endpoint; trying to load its info from “instance” endpoint...'.N);
|
lecho(1,'round '.$id.': instance «'.$inst.'» didn’t respond at its “peers” endpoint; trying to load its info from “instance” endpoint...'.N);
|
||||||
$instinfo=gurl('https://'.$inst.'/api/v1/instance',$opts['conntimeout'],$opts['functimeout']);
|
$instinfo=gurl('https://'.$inst.'/api/v1/instance',$opts['conntimeout'],$opts['functimeout']);
|
||||||
if ($instinfo['cont']===false) {
|
if ($instinfo['cont']===false) {
|
||||||
lecho(2,'could not load instance «'.$inst.'»’s info: '.$instinfo['emsg'].'.'.N);
|
lecho(2,'round '.$id.': could not load instance «'.$inst.'»’s info: '.$instinfo['emsg'].'.'.N);
|
||||||
} else {
|
} else {
|
||||||
$instinfo=@json_decode($instinfo['cont'],true);
|
$instinfo=@json_decode($instinfo['cont'],true);
|
||||||
if (is_array($instinfo))
|
if (is_array($instinfo))
|
||||||
$responded=true;
|
$responded=true;
|
||||||
else
|
else
|
||||||
lecho(2,'expecting instance «'.$inst.'»’s info, got bad JSON instead.'.N);
|
lecho(2,'round '.$id.': expecting instance «'.$inst.'»’s info, got bad JSON instead.'.N);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$now=time();
|
$now=time();
|
||||||
if ($responded) {
|
if ($responded) {
|
||||||
lecho(1,'instance «'.$inst.'» responded :-)'.N);
|
lecho(1,'round '.$id.': instance «'.$inst.'» responded :-)'.N);
|
||||||
$insts[]=$inst;
|
$insts[]=$inst;
|
||||||
$res=myq($link,'SELECT ID FROM Instances WHERE URI=\''.myesc($link,$inst).'\'');
|
$res=myq($link,'SELECT ID FROM Instances WHERE URI=\''.myesc($link,$inst).'\'');
|
||||||
$cres=mysqli_num_rows($res);
|
$cres=mysqli_num_rows($res);
|
||||||
if ($cres<1) {
|
if ($cres<1) {
|
||||||
lecho(1,'instance «'.$inst.'» is new to “Instances” table, adding it :-)'.N);
|
lecho(1,'round '.$id.': instance «'.$inst.'» is new to “Instances” table, adding it :-)'.N);
|
||||||
myq($link,'INSERT INTO Instances SET URI=\''.myesc($link,$inst).'\', InsertTS='.$now);
|
myq($link,'INSERT INTO Instances SET URI=\''.myesc($link,$inst).'\', InsertTS='.$now);
|
||||||
$totnewc++;
|
$totnewc++;
|
||||||
$newc++;
|
$newc++;
|
||||||
} elseif ($cres>1) {
|
} elseif ($cres>1) {
|
||||||
lecho(2,'instance «'.$inst.'» has '.$cres.' records in “Instances” table! :-('.N);
|
lecho(2,'round '.$id.': instance «'.$inst.'» has '.$cres.' records in “Instances” table! :-('.N);
|
||||||
} else {
|
} else {
|
||||||
lecho(1,'instance «'.$inst.'» is already present in “Instances” table.'.N);
|
lecho(1,'round '.$id.': instance «'.$inst.'» is already present in “Instances” table.'.N);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lecho(1,'instance «'.$inst.'» didn’t respond :-('.N);
|
lecho(1,'round '.$id.': instance «'.$inst.'» didn’t respond :-('.N);
|
||||||
}
|
}
|
||||||
$res=myq($link,'SELECT * FROM Peers WHERE Hostname=\''.myesc($link,$inst).'\'');
|
$res=myq($link,'SELECT * FROM Peers WHERE Hostname=\''.myesc($link,$inst).'\'');
|
||||||
$cres=mysqli_num_rows($res);
|
$cres=mysqli_num_rows($res);
|
||||||
if ($cres<1) {
|
if ($cres<1) {
|
||||||
lecho(1,'instance «'.$inst.'» is new to “Peers” table, adding it :-)'.N);
|
lecho(1,'round '.$id.': instance «'.$inst.'» is new to “Peers” table, adding it :-)'.N);
|
||||||
$query='INSERT INTO Peers SET Hostname=\''.myesc($link,$inst).'\', FirstCheckTS='.$now;
|
$query='INSERT INTO Peers SET Hostname=\''.myesc($link,$inst).'\', FirstCheckTS='.$now;
|
||||||
if ($responded) $query.=', LastOkCheckTS='.$now;
|
if ($responded) $query.=', LastOkCheckTS='.$now;
|
||||||
myq($link,$query);
|
myq($link,$query);
|
||||||
} elseif ($cres>0) {
|
} elseif ($cres>0) {
|
||||||
if ($cres>1) lecho(2,'«'.$inst.'» has '.$cres.' records in “Peers” table! :-('.N);
|
if ($cres>1) lecho(2,'round '.$id.': instance «'.$inst.'» has '.$cres.' records in “Peers” table! :-('.N);
|
||||||
if ($responded) {
|
if ($responded) {
|
||||||
lecho(1,'instance «'.$inst.'» is already present in “Peers” table, but it responded: updating its record’s “LastOkCheckTS” value...'.N);
|
lecho(1,'round '.$id.': instance «'.$inst.'» is already present in “Peers” table, but it responded: updating its record’s “LastOkCheckTS” value...'.N);
|
||||||
$row=mysqli_fetch_assoc($res);
|
$row=mysqli_fetch_assoc($res);
|
||||||
myq($link,'UPDATE Peers SET LastOkCheckTS='.$now.' WHERE ID='.$row['ID']);
|
myq($link,'UPDATE Peers SET LastOkCheckTS='.$now.' WHERE ID='.$row['ID']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
$ckinsts[]=$inst;
|
||||||
$now=time();
|
$now=time();
|
||||||
$rtela=$now-$rtini;
|
$rtela=$now-$rtini;
|
||||||
lecho(1,'round '.$id.': finished working on instance «'.$inst.'» ('.$i.'/'.$clist.'); RoundElapsedTime: '.ght($rtela,null,0).'; RoundEstimatedTimeRemaining: '.ght($rtela/$i*$clist-$rtela,null,0).'; RoundNewInsts: '.$newc.'; NextRoundInsts: '.count($nlist).'; TotElapsedTime: '.ght($now-$tini,null,0).'; TotConsideredInsts: '.count($ckinsts).'; TotRespondingInsts: '.count($insts).'; TotNewInsts: '.$totnewc.'; using '.ghs(memory_get_usage(true)).' mem. (peak: '.ghs(memory_get_peak_usage(true)).').'.N);
|
lecho(1,'round '.$id.': finished working on instance «'.$inst.'» ('.$i.'/'.$clist.'); RoundElapsedTime: '.ght($rtela,null,0).'; RoundEstimatedTimeRemaining: '.ght($rtela/$i*$clist-$rtela,null,0).'; RoundNewInsts: '.$newc.'; NextRoundInsts: '.count($nlist).'; TotElapsedTime: '.ght($now-$tini,null,0).'; TotConsideredInsts: '.count($ckinsts).'; TotRespondingInsts: '.count($insts).'; TotNewInsts: '.$totnewc.'; using '.ghs(memory_get_usage(true)).' mem. (peak: '.ghs(memory_get_peak_usage(true)).').'.N);
|
||||||
|
@ -372,7 +374,7 @@ function lecho($lev,$msg) {
|
||||||
$msg=$time.' '.$msglevs[$lev].': '.$msg;
|
$msg=$time.' '.$msglevs[$lev].': '.$msg;
|
||||||
if ($lev>=$opts['minmsgimplev']) {
|
if ($lev>=$opts['minmsgimplev']) {
|
||||||
if ($lev<2)
|
if ($lev<2)
|
||||||
echo($msg);
|
echo $msg;
|
||||||
else
|
else
|
||||||
fwrite(STDERR,$msg);
|
fwrite(STDERR,$msg);
|
||||||
}
|
}
|
||||||
|
@ -410,7 +412,7 @@ function sortcheckandsave(&$arr,$arrdesc,&$fp) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function sighandler($signal) {
|
function sighandler($signal) {
|
||||||
echo(N);
|
echo N;
|
||||||
mexit(1,'interrupted (signal: '.$signal.').'.N,0,true);
|
mexit(1,'interrupted (signal: '.$signal.').'.N,0,true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -421,19 +423,19 @@ function isempty($val) {
|
||||||
return(false);
|
return(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
function waituntilonline() {
|
function waituntilonline($roundid) {
|
||||||
$url='www.google.com';
|
$url='www.google.com';
|
||||||
$gotoff=false;
|
$gotoff=false;
|
||||||
while (false===($f=@fsockopen($url,80,$errno,$errstr,1))) {
|
while (false===($f=@fsockopen($url,80,$errno,$errstr,1))) {
|
||||||
$gotoff=true;
|
$gotoff=true;
|
||||||
lecho(2,'it seems we are offline, waiting for 10 seconds before retrying...'.N);
|
lecho(2,'round '.$roundid.': it seems we are offline, waiting 10 seconds before retrying...'.N);
|
||||||
sleep(10);
|
sleep(10);
|
||||||
}
|
}
|
||||||
fclose($f);
|
fclose($f);
|
||||||
if ($gotoff) lecho(1,'it seems we are back online! :-)'.N);
|
if ($gotoff) lecho(1,'round '.$roundid.': it seems we are back online! :-)'.N);
|
||||||
}
|
}
|
||||||
|
|
||||||
function updexarr() {
|
function updexarr($roundid) {
|
||||||
global $exarr, $opts;
|
global $exarr, $opts;
|
||||||
if (!is_null($opts['excludefp'])) {
|
if (!is_null($opts['excludefp'])) {
|
||||||
$f=@fopen($opts['excludefp'],'r');
|
$f=@fopen($opts['excludefp'],'r');
|
||||||
|
@ -447,11 +449,11 @@ function updexarr() {
|
||||||
if (@preg_match($line,'foo')!==false)
|
if (@preg_match($line,'foo')!==false)
|
||||||
$exarr[]=$line;
|
$exarr[]=$line;
|
||||||
else
|
else
|
||||||
lecho(2,'exclude file «'.$opts['excludefp'].'» contains an invalid regular expression on line '.$i.': «'.$line.'».'.N);
|
lecho(2,'round '.$roundid.': exclude file «'.$opts['excludefp'].'» contains an invalid regular expression on line '.$i.': «'.$line.'».'.N);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lecho(2,'could not open exclude file «'.$opts['excludefp'].'» for reading.'.N);
|
lecho(2,'round '.$roundid.': could not open exclude file «'.$opts['excludefp'].'» for reading.'.N);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue