(转)Java程序以后台方式在Linux上运行(nohup命令)

本文介绍如何使用Java创建一个后台循环应用程序,并通过nohup命令使其在Linux环境下脱离终端持续运行,同时将输出重定向至日志文件。

一、预备


命令

:nohup java cn.aofeng.LoopApplication >Loop.log &
说明
    1)将cn.aofeng.LoopApplication设置成后台运行,并且将标准输出的日志重定向至文件Loop.log。
    2)nohup 表示不挂断运行,&表示以后台方式运行。

源代码:

 

 

package cn.aofeng;

 

import java.text.Format;

import java.text.SimpleDateFormat;

import java.util.Date;

 

/**

 *

 * @author aofeng <a href="mailto:aofengblog@163.com">aofengblog@163.com</a>

 * @version 1.0.0

 * @since 1.0.0

 */

public class LoopApplication {

 

   public static void main(String[] args) {

      Format format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

 

      while(true) {

        String date = format.format(new Date());

        System.out.println("Current Time:" + date);

 

        try {

           Thread.sleep(1000);

        } catch (InterruptedException e) {

           e.printStackTrace(System.out);

        }

      }

   }

}



二、实践


1、telnet 登陆到Linux,执行命令
aofeng@suse9t90:~/aofeng/app> nohup java cn.aofeng.LoopApplication >Loop.log &
[1] 11860

系统返回作业号(1)和进程号(11860)。

2、退出telnet,再重新telnet登陆到Linux。

3、查看当前目录
aofeng@suse9t90:~/aofeng/app> ls
cn  Loop.log

结果显示已经在当前目录(app)下生成了日志文件Loop.log。

4、查看日志内容
aofeng@suse9t90:~/aofeng/app> tail -f Loop.log
Current Time:2008-11-14 10:59:03
Current Time:2008-11-14 10:59:04
Current Time:2008-11-14 10:59:05
Current Time:2008-11-14 10:59:06
Current Time:2008-11-14 10:59:07
Current Time:2008-11-14 10:59:08
Current Time:2008-11-14 10:59:09

日志显示程序正在运行,每秒向日志写入一行数据。

5、查看进程信息
aofeng@suse9t90:~/aofeng/app> ps -ef | grep java
1004     11860 11826  0 10:53 pts/4    00:00:00 java cn.aofeng.LoopApplication


三、附:nohup 命令


  用途:不挂断地运行命令。

  语法:nohup Command [ Arg ... ] [ & ]

   描述:nohup 命令运行由 Command 参数和任何相关的 Arg 参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使用 nohup 命令运行后台中的程序。要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部。

   无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。如果没有文件能创建或打开以用于追加,那么 Command 参数指定的命令不可调用。如果标准错误是一个终端,那么把指定的命令写给标准错误的所有输出作为标准输出重定向到相同的文件描述符。

  退出状态:该命令返回下列出口值:

  126 可以查找但不能调用 Command 参数指定的命令。

  127 nohup 命令发生错误或不能查找由 Command 参数指定的命令。

  否则,nohup 命令的退出状态是 Command 参数指定命令的退出状态。

  nohup命令及其输出文件

  nohup命令:如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用nohup命令。该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。nohup就是不挂起的意思( n ohang up)。

  该命令的一般形式为:nohup command &

  使用nohup命令提交作业

  如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:

  nohup command > myout.file 2>&1 &

  在上面的例子中,输出被重定向到myout.file文件中。

来源:http://www.cnblogs.com/Bob-FD/archive/2011/10/20/Bob.html

### Linux中使用nohup命令运行jar包的方法 在Linux系统中,`nohup` 命令可以用于将程序以后方式运行,并忽略挂起信号(SIGHUP),从而确保即使关闭终端或SSH连接,程序仍然能够继续执行[^2]。以下是具体的命令示例和用法说明: #### 基本命令格式 ```bash nohup java -jar demo.jar > nohup.log & ``` 上述命令中: - `nohup`:使程序忽略挂起信号。 - `java -jar demo.jar`:运行指定的JAR包程序。 - `> nohup.log`:将程序的标准输出重定向到 `nohup.log` 文件中。 - `&`:将命令放入后执行。 #### 输出日志的处理 如果需要将标准错误输出也重定向到同一文件中,可以使用以下命令: ```bash nohup java -jar demo.jar > log.log 2>&1 & ``` 此命令中,`2>&1` 表示将标准错误输出(文件描述符2)重定向到标准输出(文件描述符1),最终所有输出都会写入 `log.log` 文件[^3]。 #### 使用绝对路径 为了确保命令在任意工作目录下都能正确执行,建议使用绝对路径指定JAR包和日志文件的位置: ```bash nohup java -jar /export/server/jar/test.jar > /export/server/jar/testlog.log 2>&1 & ``` 通过这种方式,可以明确指定JAR包和日志文件的具体位置,避免因当前工作目录不同而导致的问题[^4]。 #### 查看程序运行状态 运行程序后,可以使用以下命令查看日志文件的内容: ```bash tail -f /export/server/jar/testlog.log ``` `tail -f` 命令会实时显示日志文件的新增内容,便于监控程序运行状态。 #### 停止后运行程序 若需要停止由 `nohup` 启动的程序,可以先找到其进程ID(PID),然后使用 `kill` 命令终止: 1. 查找进程ID: ```bash ps aux | grep demo.jar ``` 2. 终止进程: ```bash kill -9 <PID> ``` ### 注意事项 - 如果未指定输出文件,默认情况下,`nohup` 会将输出重定向到当前目录下的 `nohup.out` 文件中。 - 确保日志文件所在的目录具有写权限,否则可能会导致日志记录失败。 - 在Windows系统上运行JAR包时,可以直接双击文件启动,而在Linux系统中则推荐使用 `nohup` 或其他类似工具。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值