io.vlingo.lattice.grid.GridShutdownHook Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vlingo-lattice Show documentation
Show all versions of vlingo-lattice Show documentation
Tooling for reactive Domain-Driven Design projects that are highly concurrent. Includes compute grid, actor caching, spaces, cross-node cluster messaging, CQRS, and Event Sourcing support.
// Copyright © 2012-2020 VLINGO LABS. 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.lattice.grid;
import io.vlingo.actors.Logger;
import io.vlingo.cluster.model.ClusterSnapshotControl;
import io.vlingo.common.Tuple2;
final class GridShutdownHook {
private final Tuple2 control;
private final String nodeName;
protected GridShutdownHook(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