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"); }