Исключение "Bad File Descriptor" из-за использования nohup
Мое приложение может быть запущено через терминал в ОС Linux в виде исполняемого файла оболочки. У меня нет проблем при его нормальном выполнении, однако, когда я выполняю его вместе с командой "nohup", он регистрирует исключение ниже в файле "nohup.out"
`Exception in thread "Spring Shell" java.lang.IllegalStateException: Shell line reading failure
at org.springframework.shell.core.JLineShell.promptLoop(JLineShell.java:541)
at org.springframework.shell.core.JLineShell.run(JLineShell.java:179)
at java.lang.Thread.run(Unknown Source)
Caused by: java.io.IOException: Ungültiger Dateideskriptor this is in english “Invalid File Descriptor”
at java.io.FileInputStream.read(Native Method)
at jline.internal.NonBlockingInputStream.read(NonBlockingInputStream.java:169)
at jline.internal.NonBlockingInputStream.read(NonBlockingInputStream.java:137)
at jline.internal.NonBlockingInputStream.read(NonBlockingInputStream.java:246)
at jline.internal.InputStreamReader.read(InputStreamReader.java:261)
at jline.internal.InputStreamReader.read(InputStreamReader.java:198)
at jline.console.ConsoleReader.readCharacter(ConsoleReader.java:2038)
at jline.console.ConsoleReader.readLine(ConsoleReader.java:2242)
at jline.console.ConsoleReader.readLine(ConsoleReader.java:2162)
at jline.console.ConsoleReader.readLine(ConsoleReader.java:2150)
at org.springframework.shell.core.JLineShell.promptLoop(JLineShell.java:522)
... 2 more
`
Теперь, согласно моему анализу, мое приложение основано на Spring Shell, и оно пытается открыть / получить доступ к терминалу / консоли изначально во время выполнения приложения. Но поскольку используется nohup, стандартный ввод перенаправляется из / dev / null, и, следовательно, мое приложение пытается открыть / access / dev / null в качестве терминала, и, следовательно, я получаю исключение выше.
Пожалуйста, кто-то может указать мне, иду ли я в правильном направлении или нет? а также есть ли альтернатива для команды nohup?
1 ответ
Вы можете попробовать что-то вроде этого:
nohup java -jar shell-app.jar 'spring shell command' > log.log 2>&1