public class oadd.org.apache.hadoop.util.NodeHealthScriptRunner extends oadd.org.apache.hadoop.service.AbstractService
{
private static final org.slf4j.Logger LOG;
private java.lang.String nodeHealthScript;
private long intervalTime;
private long scriptTimeout;
private java.util.Timer nodeHealthScriptScheduler;
oadd.org.apache.hadoop.util.Shell$ShellCommandExecutor shexec;
private static final java.lang.String ERROR_PATTERN;
public static final java.lang.String NODE_HEALTH_SCRIPT_TIMED_OUT_MSG;
private boolean isHealthy;
private java.lang.String healthReport;
private long lastReportedTime;
private java.util.TimerTask timer;
private boolean runBeforeStartup;
public void <init>(java.lang.String, long, long, java.lang.String[], boolean)
{
oadd.org.apache.hadoop.util.NodeHealthScriptRunner$NodeHealthMonitorExecutor v;
java.lang.String[] v;
long v, v, v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
java.lang.Class v;
java.lang.String v, v;
boolean v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v := @parameter: java.lang.String;
v := @parameter: long;
v := @parameter: long;
v := @parameter: java.lang.String[];
v := @parameter: boolean;
v = class "Loadd/org/apache/hadoop/util/NodeHealthScriptRunner;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
specialinvoke v.<oadd.org.apache.hadoop.service.AbstractService: void <init>(java.lang.String)>(v);
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: oadd.org.apache.hadoop.util.Shell$ShellCommandExecutor shexec> = null;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: long lastReportedTime> = v;
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: boolean isHealthy> = 1;
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.lang.String healthReport> = "";
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.lang.String nodeHealthScript> = v;
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: long intervalTime> = v;
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: long scriptTimeout> = v;
v = new oadd.org.apache.hadoop.util.NodeHealthScriptRunner$NodeHealthMonitorExecutor;
specialinvoke v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner$NodeHealthMonitorExecutor: void <init>(oadd.org.apache.hadoop.util.NodeHealthScriptRunner,java.lang.String[])>(v, v);
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.util.TimerTask timer> = v;
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: boolean runBeforeStartup> = v;
return;
}
protected void serviceInit(oadd.org.apache.hadoop.conf.Configuration) throws java.lang.Exception
{
oadd.org.apache.hadoop.conf.Configuration v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
specialinvoke v.<oadd.org.apache.hadoop.service.AbstractService: void serviceInit(oadd.org.apache.hadoop.conf.Configuration)>(v);
return;
}
protected void serviceStart() throws java.lang.Exception
{
java.util.Timer v, v;
long v, v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
java.util.TimerTask v, v;
boolean v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v = new java.util.Timer;
specialinvoke v.<java.util.Timer: void <init>(java.lang.String,boolean)>("NodeHealthMonitor-Timer", 1);
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.util.Timer nodeHealthScriptScheduler> = v;
v = 0L;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: boolean runBeforeStartup>;
if v == 0 goto label;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.util.TimerTask timer>;
virtualinvoke v.<java.util.TimerTask: void run()>();
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: long intervalTime>;
label:
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.util.Timer nodeHealthScriptScheduler>;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.util.TimerTask timer>;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: long intervalTime>;
virtualinvoke v.<java.util.Timer: void scheduleAtFixedRate(java.util.TimerTask,long,long)>(v, v, v);
specialinvoke v.<oadd.org.apache.hadoop.service.AbstractService: void serviceStart()>();
return;
}
protected void serviceStop()
{
java.lang.Process v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
oadd.org.apache.hadoop.util.Shell$ShellCommandExecutor v, v;
java.util.Timer v, v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.util.Timer nodeHealthScriptScheduler>;
if v == null goto label;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.util.Timer nodeHealthScriptScheduler>;
virtualinvoke v.<java.util.Timer: void cancel()>();
label:
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: oadd.org.apache.hadoop.util.Shell$ShellCommandExecutor shexec>;
if v == null goto label;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: oadd.org.apache.hadoop.util.Shell$ShellCommandExecutor shexec>;
v = virtualinvoke v.<oadd.org.apache.hadoop.util.Shell$ShellCommandExecutor: java.lang.Process getProcess()>();
if v == null goto label;
virtualinvoke v.<java.lang.Process: void destroy()>();
label:
return;
}
public boolean isHealthy()
{
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
boolean v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: boolean isHealthy>;
return v;
}
private synchronized void setHealthy(boolean)
{
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
boolean v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v := @parameter: boolean;
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: boolean isHealthy> = v;
return;
}
public java.lang.String getHealthReport()
{
java.lang.String v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.lang.String healthReport>;
return v;
}
private synchronized void setHealthReport(java.lang.String)
{
java.lang.String v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v := @parameter: java.lang.String;
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.lang.String healthReport> = v;
return;
}
public long getLastReportedTime()
{
long v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: long lastReportedTime>;
return v;
}
private synchronized void setLastReportedTime(long)
{
long v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v := @parameter: long;
v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: long lastReportedTime> = v;
return;
}
public static boolean shouldRun(java.lang.String)
{
java.lang.String v, v;
java.io.File v;
boolean v, v, v, v;
v := @parameter: java.lang.String;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
label:
return 0;
label:
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = staticinvoke <oadd.org.apache.hadoop.fs.FileUtil: boolean canExecute(java.io.File)>(v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private synchronized void setHealthStatus(boolean, java.lang.String)
{
org.slf4j.Logger v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
java.lang.String v, v;
boolean v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v := @parameter: boolean;
v := @parameter: java.lang.String;
v = <oadd.org.apache.hadoop.util.NodeHealthScriptRunner: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("health status being set as \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
specialinvoke v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: void setHealthy(boolean)>(v);
specialinvoke v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: void setHealthReport(java.lang.String)>(v);
return;
}
private synchronized void setHealthStatus(boolean, java.lang.String, long)
{
org.slf4j.Logger v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
long v;
java.lang.String v, v;
boolean v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v := @parameter: boolean;
v := @parameter: java.lang.String;
v := @parameter: long;
v = <oadd.org.apache.hadoop.util.NodeHealthScriptRunner: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("health status being set as \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
specialinvoke v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: void setHealthStatus(boolean,java.lang.String)>(v, v);
specialinvoke v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: void setLastReportedTime(long)>(v);
return;
}
public java.util.TimerTask getTimerTask()
{
java.util.TimerTask v;
oadd.org.apache.hadoop.util.NodeHealthScriptRunner v;
v := @this: oadd.org.apache.hadoop.util.NodeHealthScriptRunner;
v = v.<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: java.util.TimerTask timer>;
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/hadoop/util/NodeHealthScriptRunner;");
<oadd.org.apache.hadoop.util.NodeHealthScriptRunner: org.slf4j.Logger LOG> = v;
return;
}
}