package hudson.plugins.ec2;
import hudson.model.Descriptor;
import hudson.slaves.RetentionStrategy;
import hudson.util.TimeUnit2;
import org.kohsuke.stapler.DataBoundConstructor;
import java.util.logging.Logger;
/**
* {@link RetentionStrategy} for EC2.
*
* @author Kohsuke Kawaguchi
*/
public class EC2RetentionStrategy extends RetentionStrategy<EC2Computer> {
@DataBoundConstructor
public EC2RetentionStrategy() {
}
public synchronized long check(EC2Computer c) {
if (c.isIdle() && !disabled) {
// TODO: really think about the right strategy here
final long idleMilliseconds = System.currentTimeMillis() - c.getIdleStartMilliseconds();
if (idleMilliseconds > TimeUnit2.MINUTES.toMillis(30)) {
LOGGER.info("Disconnecting "+c.getName());
c.getNode().terminate();
}
}
return 1;
}
/**
* Try to connect to it ASAP.
*/
@Override
public void start(EC2Computer c) {
c.connect(false);
}
// no registration since this retention strategy is used only for EC2 nodes that we provision automatically.
// @Extension
public static class DescriptorImpl extends Descriptor<RetentionStrategy<?>> {
public String getDisplayName() {
return "EC2";
}
}
private static final Logger LOGGER = Logger.getLogger(EC2RetentionStrategy.class.getName());
public static boolean disabled = Boolean.getBoolean(EC2RetentionStrategy.class.getName()+".disabled");
}