全网最全Linux 运行jar包的几种方式

一、Linux 运行jar包的几种方式

  • 方式一: java -jar xxx.jar

最常用的启动jar包命令,特点:当前ssh窗口被锁定,可按CTRL + C打断程序运行,或直接关闭窗口,程序退出

  • 方式二: java -jar xxx.jar &

&代表在后台运行 ,ctrl+c 后程序也会继续运行

  • 方式三: nohup java -jar xxx.jar &

nohup 即 no hang up 不挂断 ,关闭SSH客户端连接,程序不会中止运行

缺省情况下该作业的所有输出被重定向到nohup.out的文件中,如何让输出的内容重定向到指定的文件呢?

  • 方式四:nohup java -jar xxx.jar >aaa.log &

command >out.file 是将commandd 输出重定向到out.flie文件,即输出内容不打印到屏幕上,而是输出到out.file文件中

  • 方式五:nohup java -jar spring-boot-demo.jar > springboot.log 2>&1 &

363c896c36dec3783bb93a3ebe312a58.png

  • 方式六:nohup java -jar spring-boot-demo.jar > /dev/null 2>&1 &

​ 不输出日志

二、nohup 和 &

使用&后台运行程序:
  • 结果会输出到终端
  • 使用Ctrl + C,程序免疫
  • 关闭session,程序关闭
使用nohup运行程序:
  • 结果默认会输出到nohup.out
  • 使用Ctrl + C,程序关闭
  • 关闭session,程序免疫

平日线上经常使用nohup&配合来启动程序

三、> /dev/null 2>&1

  • > 标准重定向符,允许我们创建一个 0KB 的空文件。它通常用于重定向一个命令的输出到一个新文件中。在没有命令的情况下使用重定向符号时,它会创建一个文件。

  • /dev/null 可以看作黑洞,等价于一个只写文件。所有写入它的内容都会永远丢失,尝试从它那儿读取内容则什么也读不到。也就是将所有产生的日志将被丢弃

  • 2>&1 符号>&是一个整体代表将标准错误2重定向到标准输出1,如果是2>1的话,代表将标准错误输出到文件1,而不是重定向到标准输出流

​ 先了解下1和2在Linux中代表什么

​ 当Linux执行一个程序时,会自动打开三个流

0:标准输入流(默认是键盘)
1:标准输出流(默认是屏幕)
2:标准错误流(默认是屏幕)

名称代码操作符java中表示Linux中文件描述符
标准输入(stdin)0< 或 <<System.in/dev/stdin -> /proc/self/fd/0 -> /dev/pts/0
标准输出(stdout)1>, >>, 1> 或 1>>System.out/dev/stdout -> /proc/self/fd/1 -> /dev/pts/0
标准错误输出(stderr)22> 或 2>>System.err/dev/stderr -> /proc/self/fd/2 -> /dev/pts/0

​ 从上表看出,平常使用的 echo 'hello' > a.log 可以写成 echo 'hello' 1> a.log

​ 为什么2>&1要放在后面 ? 如下一条shell命令 nohup java -jar app.jar >log 2>&1 & 我们不妨把1和2都理解是一个指针,然后来看上面的语句就是这样的:

​ 本来1----->屏幕 (1指向屏幕)
​ 执行>log后, 1----->log (1指向log)
​ 执行2>&1后, 2----->1 (2指向1,而1指向log,因此2也指向了log)

​ 再来分析下nohup java -jar app.jar 2>&1 >log &
​ 本来1----->屏幕 (1指向屏幕)
​ 执行2>&1后, 2----->1 (2指向1,而1指向屏幕,因此2也指向了屏幕)
​ 执行>log后, 1----->log (1指向log,2还是指向屏幕)
​ 所以这就不是我们想要的结果。

​ 每次都写">log 2>&1"太麻烦,能简写吗?可以简写成 &>log>&log

nohup java -jar app.jar 2>&1 >log & 简写成:nohup java -jar app.jar &>log &

### 如何在 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 的方法概览。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值