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

io.vlingo.cluster.ShutdownHook Maven / Gradle / Ivy

Go to download

Cluster management for reactive, scalable resiliency of JVM tools and applications running on VLINGO XOOM Actors.

There is a newer version: 1.7.5
Show newest version
// Copyright © 2012-2018 Vaughn Vernon. All rights reserved.
//
// This Source Code Form is subject to the terms of the
// Mozilla Public License, v. 2.0. If a copy of the MPL
// was not distributed with this file, You can obtain
// one at https://mozilla.org/MPL/2.0/.

package io.vlingo.cluster;

import io.vlingo.actors.Logger;
import io.vlingo.cluster.model.ClusterSnapshotControl;
import io.vlingo.common.Tuple2;

final class ShutdownHook {
  private final Tuple2 control;
  private final String nodeName;

  protected ShutdownHook(final String nodeName, final Tuple2 control) {
    this.nodeName = nodeName;
    this.control = control;
  }

  protected void register() throws Exception {
    Runtime.getRuntime().addShutdownHook(new Thread() {
      @Override
      public void run() {
        control._2.info("\n==========");
        control._2.info("Stopping node: '" + nodeName + "' ...");
        control._1.shutDown();
        pause();
        control._2.info("Stopped node: '" + nodeName + "'");
      }
    });
  }
  
  private void pause() {
    try {
      Thread.sleep(1000L);
    } catch (Exception e) {
      // ignore
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy