java 执行linux命令或shell脚本方法
2015-11-20 00:17
926 查看
一.容易出错的地方之一,执行ps等命令要注意到jvm调用的linux命令也是一个进程
背景:第1,2,3,4行代码都可以完成java 执行shell脚本的任务,第2,3,4行代码的数组中第三个参数可以是脚本名,也可以是cd / ls / chown 这种命令。
问题:本例中调用其他shell脚本和linux命令都正常,而在第四行代码中调用ps时候,会遇到不能执行的问题
java代码中,第一行和第二行等价,都是调用stop.sh脚本,第三行第四行等价,都是直接执行linux命令
在此处第一句第二句总能拿到两个pid,并且当前stop.sh脚本进程也被kill调。而java的第3行和第4行能正确执行,只拿到1个pid,而且kill掉jmeter进程后,stop.sh进程
仍然正常存在。
stop.sh如下:
pid=`ps -ef | grep jmeter | grep -v 'grep' |awk '{print $2}'`
echo ${pid}>>result.txt
ps -ef | grep jmeter | grep -v 'grep'| awk '{print $2}' | xargs kill -9
原因:java代码调用shell脚本和直接执行shell脚本里的code,在此处不等效。stop.sh的第1句执行,时而拿到1个pid,时而拿到2个的原因是,在java中直接调用stop.sh,jvm进程,stop.sh进程,ps -ef 和被判断的jmeter进程,共存在这四个进程。在java中直接调用ps -ef命令,则只存在jvm和ps -ef 和jmeter这三个进程,这时,ps -ef 不止能判断出jmeter进程,还能把stop.sh jmeter这个进程的pid拿出来并且kill掉,以上问题解决。
二.容易出错的地方之二,路径问题
这个linux命令被jvm或者tomcat启动,那么这个命令的进程所在路径是他的父进程的路径(classpath),此时linux命令中和路径有关的命令,要注意。
三.容易出错的地方之三,父进程执行完就结束,子进程还没执行完就被迫结束
如果java中执行‘nohup run.sh 30min &’ 这种命令,命令本身需要30分钟能执行完,但是java 执行nohup这句一瞬间执行完,所代表的父进程结束,则nohup子进程也结束。如果不想被结束,就不要用这种很特殊的nohup命令,而直接在java中调用' run.sh 30min '命令即可。
四.打印执行命令的结果
完成任务.
背景:第1,2,3,4行代码都可以完成java 执行shell脚本的任务,第2,3,4行代码的数组中第三个参数可以是脚本名,也可以是cd / ls / chown 这种命令。
问题:本例中调用其他shell脚本和linux命令都正常,而在第四行代码中调用ps时候,会遇到不能执行的问题
import java.io.IOException; public class test { public static void main(String[] args) throws IOException,InterruptedException { //Runtime.getRuntime().exec("/Users/lijialiang/codetest/stop.sh jmeter"); //Runtime.getRuntime().exec(new String[]{"/bin/sh","-c","/codetest/stop.sh jmeter"}); //Runtime.getRuntime().exec(new String[]{"/bin/sh","-c","ps -ef | grep jmeter | grep -v 'grep' |awk '{print $2}'>>result.txt"}); Runtime.getRuntime().exec(new String[]{"/bin/sh","-c","ps -ef | grep <span style="font-family: Arial, Helvetica, sans-serif;">jmeter</span><span style="font-family: Arial, Helvetica, sans-serif;"> | awk '{print $2}' | xargs kill -9"});</span> //Thread.sleep(100000); } }
java代码中,第一行和第二行等价,都是调用stop.sh脚本,第三行第四行等价,都是直接执行linux命令
在此处第一句第二句总能拿到两个pid,并且当前stop.sh脚本进程也被kill调。而java的第3行和第4行能正确执行,只拿到1个pid,而且kill掉jmeter进程后,stop.sh进程
仍然正常存在。
stop.sh如下:
pid=`ps -ef | grep jmeter | grep -v 'grep' |awk '{print $2}'`
echo ${pid}>>result.txt
ps -ef | grep jmeter | grep -v 'grep'| awk '{print $2}' | xargs kill -9
原因:java代码调用shell脚本和直接执行shell脚本里的code,在此处不等效。stop.sh的第1句执行,时而拿到1个pid,时而拿到2个的原因是,在java中直接调用stop.sh,jvm进程,stop.sh进程,ps -ef 和被判断的jmeter进程,共存在这四个进程。在java中直接调用ps -ef命令,则只存在jvm和ps -ef 和jmeter这三个进程,这时,ps -ef 不止能判断出jmeter进程,还能把stop.sh jmeter这个进程的pid拿出来并且kill掉,以上问题解决。
二.容易出错的地方之二,路径问题
这个linux命令被jvm或者tomcat启动,那么这个命令的进程所在路径是他的父进程的路径(classpath),此时linux命令中和路径有关的命令,要注意。
三.容易出错的地方之三,父进程执行完就结束,子进程还没执行完就被迫结束
如果java中执行‘nohup run.sh 30min &’ 这种命令,命令本身需要30分钟能执行完,但是java 执行nohup这句一瞬间执行完,所代表的父进程结束,则nohup子进程也结束。如果不想被结束,就不要用这种很特殊的nohup命令,而直接在java中调用' run.sh 30min '命令即可。
四.打印执行命令的结果
public static void main(String[] args) throws IOException { String line = ""; Process ps = Runtime.getRuntime().exec("ls"); BufferedReader br = new BufferedReader(new InputStreamReader(ps.getInputStream())); while((line = br.readLine())!=null ){ System.out.println(line); } }
完成任务.
相关文章推荐
- SSH Secure Shell Client中文乱码的解决办法
- xshell链接虚拟机Ubuntu
- xshell远程连接设置
- shell入门-awk-2
- hdfs-shell操作
- linux shell 编程 3(if then else fi 字符串空的判断)
- linux重定向总结:如何将shell命令的输出信息自动输出到文件中保存
- MAC下切换到zsh,打造有git提示的美化shell
- Shell脚本
- linux shell中find的使用
- 反弹shell的十种姿势
- shell脚本
- shell入门学习
- 《linux shell》笔记之date
- shell脚本:ip/mask 转换为 ip1-ip2
- 修改git bash 默认路径
- shell之md5sum(对文件内手机号生成MD5)
- Shell命令的内容
- shell之ssh远程管理(这个脚本就是上一个jump.sh调用的脚本)
- shell之菜单+跳板机(跳板机管理及连接脚本与下一个for循环的脚本配合使用)