Linux运行jar包命令

本文详细介绍了在Linux环境下运行jar包的三种方式,重点解析了使用nohup命令实现程序在后台不挂断运行的方法,以及如何通过ps和kill命令关闭nohup启动的进程。同时,讨论了标准输入、输出和错误流的概念,并举例说明了如何重定向输出到文件。文章还对比了nohup与&的区别,并提到了/dev/null的特殊作用。

一. linux下运行jar包的命令
1、java -jar xxxxx.jar // 当前xshell窗口被锁定,可按CTRL + C打断程序运行,或直接关闭窗口,程序退出

2、java -jar xxxxx.jar & //当前shell窗口不被锁定,但是当窗口关闭时,程序中止运行。

3、nohup Java -jar xxxxxx.jar & //意思是不挂断运行命令,当账户退出或终端关闭时,程序仍然运行

二. 下面详细介绍第三种运行方式

/*下面介绍如何关闭第三种运行的jar包程序/
//查看进程,找到对应java程序的进程号(PID值)
#ps -ef
//关闭进程
#kill -9 PID
//centos7.3系统 直接使用入下命令也可以
#kill PID

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

nohup 是 no hang up 的缩写,就是不挂断的意思。

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

在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中。
nohup和&的区别
& : 指在后台运行

nohup : 不挂断的运行,注意并没有后台运行的功能,就是指,用nohup运行命令可以使命令永久的执行下去,和用户终端没有关系,例如我们断开SSH连接都不会影响它的运行;

三. linux下nohup命令的使用
现对上面的命令进行下解释

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

操作系统中有三个常用的流:
  0:标准输入流 stdin
  1:标准输出流 stdout
  2:标准错误流 stderr
  一般当我们用 > console.txt,实际是 1>console.txt的省略用法;< console.txt ,实际是 0 < console.txt的省略用法。

下面步入正题:

nohup ./start-dishi.sh >output 2>&1 &
解释:

带&的命令行,即使terminal(终端)关闭,或者电脑死机程序依然运行(前提是你把程序递交到服务器上);
2>&1的意思
  这个意思是把标准错误(2)重定向到标准输出中(1),而标准输出又导入文件output里面,所以结果是标准错误和标准输出都导入文件output里面了。 至于为什么需要将标准错误重定向到标准输出的原因,那就归结为标准错误没有缓冲区,而stdout有。这就会导致 >output 2>output 文件output被两次打开,而stdout和stderr将会竞争覆盖,这肯定不是我门想要的.
  这就是为什么有人会写成: nohup ./command.sh >output 2>output出错的原因了

最后谈一下/dev/null文件的作用,这是一个无底洞,任何东西都可以定向到这里,但是却无法打开。 所以一般很大的stdou和stderr当你不关心的时候可以利用stdout和stderr定向到这里>./command.sh >/dev/null 2>&1

### 如何在 Linux 系统中使用命令执行 JAR 文件 #### 使用 `java` 命令执行 JAR 文件 为了在 Linux 上通过命令运行 JAR 文件,可以采用 Java 的 `-jar` 参数来指定要执行JAR 文件路径。基本语法如下所示: ```bash java -jar /path/to/your-application.jar ``` 如果 JAR 文件位于当前目录,则可以直接输入文件名而不需要完整的路径[^2]。 #### 解决可能遇到的问题 当尝试在 Linux命令运行 JAR 文件出现问题时,可能是由于缺少依赖库或者环境配置不正确引起的。例如,在某些情况下,可能会因为 MANIFEST.MF 中定义的 Class-Path 路径不符合 Unix 格式的缘故而导致错误发生。此时应确保所有外部资源的位置都按照正确的斜杠分隔符(/)书写,并且这些资源确实存在于所指明的地方[^3]。 #### 将 Hadoop Jar 应用部署到集群并执行 对于特定的应用场景比如 Hadoop MapReduce 作业来说,除了常规的 java -jar 方式外还可以借助 hadoop 自带的 jar 执行器来进行操作。这涉及到几个步骤:首先是创建含主类和其他所需组件在内的可执行 JAR;其次是把该 JAR 及其关联的数据集传送到分布式文件系统 (DFS); 接着就是调用相应的命令启动任务;最后可以从 DFS 获取处理后的成果带回本地磁盘保存[^1]。 #### 利用 curl 工具获取远程 JAR 文件再执行 假如目标 JAR 存在于互联网上的某个位置而不是本地存储设备里的话,那么就可以先运用像 curl 这样的 HTTP 客户端抓取下来之后再去加载它。具体做法是给出源地址作为参数给定于 curl 后面再加上输出重定向符号大于号(>)指向期望存放的目标地点形成一条完整的指令链[^4]。 ```bash curl http://example.com/path-to-your-jarfile.jar --output local-filename.jar && java -jar local-filename.jar ``` 以上就是在 Linux 平台上经由终端界面驱动各种类型的 JAR 的方法概览。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值