gobblin-cluster/src/main/java/org/apache/gobblin/cluster/GobblinHelixJobLauncherListener.java [42:78]:
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    this.jobLauncherMetrics = jobLauncherMetrics;
  }

  @Override
  public void onJobPrepare(JobContext jobContext)
      throws Exception {
    super.onJobPrepare(jobContext);
    jobContext.getJobState().setProp(JOB_START_TIME, Long.toString(System.nanoTime()));
    jobLauncherMetrics.numJobsLaunched.mark();
  }

  /**
   * From {@link org.apache.gobblin.runtime.AbstractJobLauncher#launchJob(JobListener)}, the final
   * job state should only be FAILED or COMMITTED. This means the completed jobs metrics covers
   * both failed jobs and committed jobs.
   */
  @Override
  public void onJobCompletion(JobContext jobContext)
      throws Exception {
    super.onJobCompletion(jobContext);
    long startTime = jobContext.getJobState().getPropAsLong(JOB_START_TIME);
    jobLauncherMetrics.numJobsCompleted.mark();
    Instrumented.updateTimer(Optional.of(jobLauncherMetrics.timeForCompletedJobs), System.nanoTime() - startTime, TimeUnit.NANOSECONDS);
    if (jobContext.getJobState().getState() == JobState.RunningState.FAILED) {
      jobLauncherMetrics.numJobsFailed.mark();
      Instrumented.updateTimer(Optional.of(jobLauncherMetrics.timeForFailedJobs), System.nanoTime() - startTime, TimeUnit.NANOSECONDS);
    } else {
      jobLauncherMetrics.numJobsCommitted.mark();
      Instrumented.updateTimer(Optional.of(jobLauncherMetrics.timeForCommittedJobs), System.nanoTime() - startTime, TimeUnit.NANOSECONDS);
    }
  }

  @Override
  public void onJobCancellation(JobContext jobContext)
      throws Exception {
    super.onJobCancellation(jobContext);
    jobLauncherMetrics.numJobsCancelled.mark();
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -



gobblin-temporal/src/main/java/org/apache/gobblin/temporal/joblauncher/GobblinTemporalJobLauncherListener.java [42:78]:
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    this.jobLauncherMetrics = jobLauncherMetrics;
  }

  @Override
  public void onJobPrepare(JobContext jobContext)
      throws Exception {
    super.onJobPrepare(jobContext);
    jobContext.getJobState().setProp(JOB_START_TIME, Long.toString(System.nanoTime()));
    jobLauncherMetrics.numJobsLaunched.mark();
  }

  /**
   * From {@link org.apache.gobblin.runtime.AbstractJobLauncher#launchJob(JobListener)}, the final
   * job state should only be FAILED or COMMITTED. This means the completed jobs metrics covers
   * both failed jobs and committed jobs.
   */
  @Override
  public void onJobCompletion(JobContext jobContext)
      throws Exception {
    super.onJobCompletion(jobContext);
    long startTime = jobContext.getJobState().getPropAsLong(JOB_START_TIME);
    jobLauncherMetrics.numJobsCompleted.mark();
    Instrumented.updateTimer(Optional.of(jobLauncherMetrics.timeForCompletedJobs), System.nanoTime() - startTime, TimeUnit.NANOSECONDS);
    if (jobContext.getJobState().getState() == JobState.RunningState.FAILED) {
      jobLauncherMetrics.numJobsFailed.mark();
      Instrumented.updateTimer(Optional.of(jobLauncherMetrics.timeForFailedJobs), System.nanoTime() - startTime, TimeUnit.NANOSECONDS);
    } else {
      jobLauncherMetrics.numJobsCommitted.mark();
      Instrumented.updateTimer(Optional.of(jobLauncherMetrics.timeForCommittedJobs), System.nanoTime() - startTime, TimeUnit.NANOSECONDS);
    }
  }

  @Override
  public void onJobCancellation(JobContext jobContext)
      throws Exception {
    super.onJobCancellation(jobContext);
    jobLauncherMetrics.numJobsCancelled.mark();
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -



