码迷,mamicode.com
首页 > 编程语言 > 详细

用jetty-runner.jar 运行程序的脚本

时间:2016-11-08 19:52:17      阅读:209      评论:0      收藏:0      [点我收藏+]

标签:简单   linux 命令   文件描述符   读取数据   控制   命令   系统   jvm   linux   

今天又补充了点脚本,感觉蛮有用的, 开心~ 

 

先阐述清楚 linux/unix下特性:

一般情况下,每个 Unix/Linux 命令运行时都会打开三个文件:
标准输入文件(stdin):stdin的文件描述符为0,Unix程序默认从stdin读取数据。
标准输出文件(stdout):stdout 的文件描述符为1,Unix程序默认向stdout输出数据。
标准错误文件(stderr):stderr的文件描述符为2,Unix程序会向stderr流中写入错误信息。

有时候,程序刚启动会刷日志到std out(console),很烦的~ 今天根据上面的说明, 优化了一下脚本。

 

 

启动脚本

#!/bin/bash
java -Xmx512m -Xms64m -XX:PermSize=256M -XX:MaxPermSize=512M -jar jetty-runner.jar --port 12345 server-0.0.1-SNAPSHOT.war  >/web/program/gw/logs/stdout.log 2>&1 &


echo $! > ./program.pid

 

启动脚本说明:

1. java - jar 和一些jvm参数  
2. jetty-runner.jar 参数
3. 把标准输出、标准错误(1/2) 从定向到/web/program/gw/logs/stdout.log
4. & 后台启动
5. 把程序的pid输出到program.pid

 

关闭脚本

#!/bin/bash
pkill -F ./program.pid
rm ./program.pid

 

关闭脚本简单, 就是一个pkill -F 然后删除文件。

 

小小心得

java -Xmx512m -Xms64m -XX:PermSize=256M -XX:MaxPermSize=512M -jar jetty-runner.jar --port 12345 server-0.0.1-SNAPSHOT.war  >/web/program/gw/logs/stdout.log 2>&1 &

之前是没有上面红色的部分的。问题就是系统启动后,控制台在刷日志, 神烦。 把上面红色的加上, 意思是把标准输出和标准错误都输出到这个文件中。

 

用jetty-runner.jar 运行程序的脚本

标签:简单   linux 命令   文件描述符   读取数据   控制   命令   系统   jvm   linux   

原文地址:http://www.cnblogs.com/ELMND/p/6044154.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!