Isilon: Taak voor het opnieuw starten van langlopende laatste taken
Summary: Taken vertonen geen voortgang als gevolg van langlopende eindtaken.
Symptoms
Dit probleem doet zich voor bij alle taken, meestal bij het markeren van jobs(Collect, IntegrityScan) als restriping jobs(SmartPools, AB/ABL, FP/FPL).
Systeemtaken vertonen mogelijk geen voortgang tijdens het werken aan de laatste paar taken per fase.
Vaak verwijderen van taakresultaten worden weergegeven bij het controleren van isi_job_d.log wanneer de taken opnieuw worden gestart.
Dit kan ertoe leiden dat de taak niet wordt voltooid, omdat een of meer laatste taken niet kunnen worden voltooid voordat ze worden gedeactiveerd.
Dit gebeurt om verschillende redenen, zoals wanneer een taak met een hogere prioriteit in dezelfde uitsluitingsset wordt uitgevoerd.
Het kan ook zijn dat de limiet voor het uitvoeren van taken is bereikt en dat een nieuwere taak met een hogere prioriteit wordt uitgevoerd.
Andere mogelijke problemen kunnen de taak-engine zelf zijn of clusterproblemen zoals vergrendelingsconflicten, splitsingen van knooppunten, opnieuw opstarten/paniek van knooppunten, systeemprestaties en andere mogelijke oorzaken.
Cause
Controleer of de taak in de wacht staat of wordt uitgevoerd, waardoor de status van de taak wordt gewijzigd en taken opnieuw worden gestart.
Als u een groot aantal wijzigingen in de wachtende of actieve status ziet, kijkt u naar de taak om de prioriteit te bevestigen.
Als andere startende taken een hogere prioriteit hebben (1 is de hoogste prioriteit), kan dit ertoe leiden dat de taak in de wachtrij komt te staan.
Om live te controleren:
isi job events list --job-id=<JobID>
isi_for_array -sQ 'grep -hi "<JobName>.*Run\|<JobName>.*Wait" /var/log/messages' |sort -u |tail
Logboeken controleren:
zgrep -h '<JobName>.*Run\|<JobName>.*Wait' */varlog.tar/log/messages* |grep <JobID>|sort -u |tail
Soms wordt dezelfde taak-ID vaak opnieuw opgestart en kan deze niet met succes worden voltooid.
Mogelijk zijn er verschillende taak-ID's die regelmatig opnieuw worden opgestart.
Zorg er in beide gevallen voor dat de taak niet in een wachtende of onderbroken status wordt gezet, waardoor de verwijderde taken met eerdere stappen worden veroorzaakt.
Controleer op gedeactiveerde of genegeerde taken die te wijten kunnen zijn aan throttling van de taakmotor.
Om live te controleren:
isi_for_array -sQ 'grep -hi "deactivat\|discard" /var/log/isi_job_d.log' |grep <JobName> | sort -u | tail
Logboeken controleren:
grep -hi "deactivat\|discard" *-*/varlog.tar/log/isi_job_d.log* |grep <JobName> |sort -u|tail
In dit voorbeeld wordt dezelfde taak-ID genegeerd voor de FlexProtectLin Baan kijkt naar "tid=28-1" In de uitvoer:
[martid32@elvis 2024-10-29_20-31]$ zgrep -hi "deactivat\|discard" *-*/varlog.tar/log/isi_job_d.log* |grep 'FlexProtectLin jid=6894' |sort -u |tail
2024-10-10T06:01:53.217905-05:00 <3.6> CLUSTER-22(id22) isi_job_d[92144]: Worker 12 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=57916 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-11T11:50:02.236664-05:00 <3.6> CLUSTER-5(id5) isi_job_d[79762]: Worker 77 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=60525 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-11T16:24:26.930667-05:00 <3.6> CLUSTER-7(id7) isi_job_d[68876]: Worker 21 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=58508 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-11T19:14:46.876445-05:00 <3.6> CLUSTER-11(id11) isi_job_d[28510]: Worker 39 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=60665 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-11T20:30:49.232915-05:00 <3.6> CLUSTER-8(id8) isi_job_d[58489]: Worker 20 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=74387 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-12T00:09:39.969852-05:00 <3.6> CLUSTER-26(id26) isi_job_d[12284]: Worker 13 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=58255 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-12T00:39:46.999158-05:00 <3.6> CLUSTER-2(id2) isi_job_d[78458]: Worker 485 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=58365 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-12T01:18:53.867843-05:00 <3.6> CLUSTER-11(id11) isi_job_d[28510]: Worker 53 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=60666 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-12T02:21:01.143101-05:00 <3.6> CLUSTER-28(id28) isi_job_d[11777]: Worker 18 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=58221 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
2024-10-12T03:19:07.198836-05:00 <3.6> CLUSTER-1(id1) isi_job_d[87488]: Worker 561 Stopped: (task_state_clean, 614) FlexProtectLin[6894].0: Discarding unsent task result: { task_result={ jtid=FlexProtectLin jid=6894 phase=0 tid=28-1 rid=60128 ready=false errors=[] } data={ lins=0 files=0 dirs=0 blocks=0 lins_processed=0 sins=0 sins_processed=0 } start_linsid=0::INVALID end_linsid=0::INVALID }
De onderstaande opdrachten kunnen worden gebruikt om het huidige aantal taken te bevestigen en waar ze aan werken:
for i in $(isi job list|grep '^[0-9].*Running'|awk '{print $1}'); do isi job view $i; isi job statistics view -v --job-id=$i|grep -o 'Workers: [0-9]*'|sort |uniq -c; echo $(find /ifs/.ifsvar/modules/jobengine/cp/$i/tasks -type f | wc -l) tasks remaining; done;
Vervangen JOBID met de JobID Nummer voor de functie in kwestie:--
isi_for_array -XQ 'for n in $(sysctl efs.bam.busy_vnodes | grep "pid $(pgrep -f JOBID)" | egrep -o "[[:alnum:]]{1,4}:[[:alnum:]]{1,4}:[[:alnum:]]{1,4}"|sort|uniq); do isi get -L "$n" 2>&1; done' | grep -v 'job_d\|modules/jobengine' | sort | uniq -c
Resolution
Als wordt bevestigd dat de taak gaat wachten of vaak wordt uitgevoerd omdat er andere taken worden gestart, wijzigt u deze tijdelijk naar een hogere prioriteit.
Een prioriteit van 2 kan worden gebruikt om te voorkomen dat taken de betreffende taak onderbreken en kan worden teruggezet naar de standaardinstelling zodra de taak is voltooid.
Neem contact op met Support voor hulp en raadpleeg dit KB-artikel als de taak de werknemers lijkt te beperken, waardoor de taak meerdere keren wordt verwijderd.