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

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

There is a newer version: 0.7.10
Show newest version
/**
 * Copyright [2013-2014] eBay 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 MasterTimer} is used to log execution time of preXXXX of interceptors, master computation and postXXXX of
 * interceptors. {@link MasterTimer} includes waiting time and should be set as system interceptor.
 * 
 * 

* {@link MasterTimer} is set as one master interceptor by default. * * @param * master computation result in each iteration. * @param * worker computation result in each iteration. */ public class MasterTimer implements MasterInterceptor { private static final Logger LOG = LoggerFactory.getLogger(MasterTimer.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 {} starts master computation.", context.getAppId(), context.getContainerId()); } @Override public void preIteration(MasterContext context) { this.iterStartTime = System.nanoTime(); LOG.info("Application {} container {} iteration {} starts master computation.", context.getAppId(), context.getContainerId(), context.getCurrentIteration()); } @Override public void postIteration(MasterContext context) { LOG.info("Application {} container {} iteration {} 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 {} ends with {}ms execution time.", context.getAppId(), context.getContainerId(), TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - this.appStartTime)); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy