Я пытаюсь убедиться, что мое приложение Java принимает разумные меры для обеспечения надежности, и частично это связано с корректным завершением работы. Я читаю о хуках завершения работы и не понимаю, как их использовать на практике.
Есть ли там практический пример?
Допустим, у меня было действительно простое приложение, подобное приведенному ниже, которое записывает числа в файл, от 10 до строки, партиями по 100 штук, и я хочу убедиться, что данная партия завершится, если программа будет прервана. Я понимаю, как зарегистрировать ловушку выключения, но понятия не имею, как интегрировать ее в свое приложение. Какие-либо предложения?
package com.example.test.concurrency;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.PrintWriter;
public class GracefulShutdownTest1 {
final private int N;
final private File f;
public GracefulShutdownTest1(File f, int N) { this.f=f; this.N = N; }
public void run()
{
PrintWriter pw = null;
try {
FileOutputStream fos = new FileOutputStream(this.f);
pw = new PrintWriter(fos);
for (int i = 0; i < N; ++i)
writeBatch(pw, i);
}
catch (FileNotFoundException e) {
e.printStackTrace();
}
finally
{
pw.close();
}
}
private void writeBatch(PrintWriter pw, int i) {
for (int j = 0; j < 100; ++j)
{
int k = i*100+j;
pw.write(Integer.toString(k));
if ((j+1)%10 == 0)
pw.write('\n');
else
pw.write(' ');
}
}
static public void main(String[] args)
{
if (args.length < 2)
{
System.out.println("args = [file] [N] "
+"where file = output filename, N=batch count");
}
else
{
new GracefulShutdownTest1(
new File(args[0]),
Integer.parseInt(args[1])
).run();
}
}
}
java
shutdown-hook
Джейсон С
источник
источник
Ответы:
Вы могли сделать следующее:
.interrupt
рабочие потоки, если они ждут данных в каком-то блокирующем вызове)writeBatch
в вашем случае), вызвавThread.join()
метод в рабочих потоках.Какой-то схематичный код:
static volatile boolean keepRunning = true;
В run () вы меняете на
В main () вы добавляете:
Примерно так я изящно «отклоняю всех клиентов при нажатии Control-C» в терминале.
Из документов :
То есть ловушка выключения поддерживает работу JVM до тех пор, пока ловушка не будет завершена (возвращена из метода run () .
источник
mainThread
это поток демона, тоjoin
мы гарантируем, что мы дождемся его завершения, прежде чем позволить JVM завершиться.Обработчики выключения - это незапущенные потоки, которые зарегистрированы с помощью Runtime.addShutdownHook (). JVM не дает никаких гарантий относительно порядка, в котором запускаются обработчики выключения. Для получения дополнительной информации см. Http://techno-terminal.blogspot.in/2015/08 /shutdown-hooks.html
источник