All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ml.shifu.guagua.master.MasterComputableTimer Maven / Gradle / Ivy

The newest version!
/*
 * Copyright [2013-2014] PayPal Software Foundation
 *  
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *  
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package ml.shifu.guagua.master;

import java.util.concurrent.TimeUnit;

import ml.shifu.guagua.io.Bytable;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * {@link MasterComputableTimer} is used to print execution time for master computation. Waiting time is not included in
 * this timer.
 * 
 * 

* {@link MasterComputableTimer} should be set as user intercepter, not system intercepter. * * @param * master result for computation in each iteration. * @param * worker result for computation in each iteration. */ public class MasterComputableTimer extends BasicMasterInterceptor { private static final Logger LOG = LoggerFactory.getLogger(MasterComputableTimer.class); /** * Application starting time. */ private long appStartTime; /** * Iteration starting time. */ private long iterStartTime; @Override public void preApplication(MasterContext context) { this.appStartTime = System.nanoTime(); LOG.info("Application {} container {} computation starts internal master computation.", context.getAppId(), context.getContainerId()); } @Override public void preIteration(MasterContext context) { this.iterStartTime = System.nanoTime(); LOG.info("Application {} container {} iteration {} computation starts internal master computatio.", context.getAppId(), context.getContainerId(), context.getCurrentIteration()); } @Override public void postIteration(MasterContext context) { LOG.info("Application {} container {} iteration {} computation ends with {}ms execution time.", context.getAppId(), context.getContainerId(), context.getCurrentIteration(), TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - this.iterStartTime)); } @Override public void postApplication(MasterContext context) { LOG.info("Application {} container {} computation ends with {}ms execution time.", context.getAppId(), context.getContainerId(), TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - this.appStartTime)); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy