WinRun4J - сервис не останавливается
Я использую это для установки моего приложения в качестве службы Windows. Все работает отлично, кроме службы не останавливается;
@Override
public int serviceMain(String[] strings) throws ServiceException {
try {
System.out.println("BootService: init");
System.out.println("BootService: service loop start");
while (ws.isServiceRunning()) {
System.out.println("BootService: loop");
ws.serviceHandler();
}
System.out.println("BootService: stopped");
return 0;
} catch (Exception ex) {
throw new ServiceException(ex);
}
}
@Override
public int serviceRequest(int control) throws ServiceException {
try {
switch (control) {
case SERVICE_CONTROL_SHUTDOWN:
case SERVICE_CONTROL_STOP:
if (ws!=null) {
ws.stopService();
}
break;
}
return 0;
} catch (WindowsServiceException ex) {
throw new ServiceException(ex);
}
}
Мой служебный код службы останавливается вызовом serviceRequest(), что, в свою очередь, приводит к завершению цикла в serviceMain(). Я вижу сообщение "BootService: остановлено" в моих журналах, но апплет служб панели управления Windows просто говорит "Остановка службы...", но этого не происходит.
Что помешает остановке службы, даже если я уверен, что она вышла из serviceMain() без ошибок?
1 ответ
Я не знаю, можете ли вы решить эту проблему, но у меня была схожая проблема, и я исправил ее, добавив таймер с именем System.exit(0).
public int serviceMain(String[] args) throws ServiceException {
while (!shutdown) {
try {
if (!myservice.isRunning()) {
(new Thread(new LaucherRunnable(args))).start();
}
Thread.sleep(6000);
} catch (InterruptedException e) {
}
}
periodicRunner.stop();
Timer t = new Timer(1000, new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
System.exit(0);
}
});
t.setRepeats(false);
t.start();
return 0;
}