linux修改脚本权限linux修改脚本

如题所述

Java在linux上调用shell脚本?

近期正好结合工作实践,分享了一篇关于Java如何调用Shell的文章,希望能够帮到您。内容如下。

《Java配Shell等于美酒加咖啡》

化学中我们得知「氢气加氧气在点燃的情况下会生成水」。

生活中我们得知「良辰加美景的情况下会得到千金春宵一刻」。

技术上又何尝不是如此呢?先假设一个场景:BOSS让你实现一个服务监控的指挥室,能看到每个服务器的磁盘剩余空间,能看到。。。能看到。。。

其实讲真,实现思路有很多,但是不管黑猫白猫能抓住老鼠都是好猫,今天我们尝试用Java与Shell搭配一下,看看是否会产生惊奇的反应。

1.首先通过JDK源码,品一品Runtime这杯美酒。

上图是摘取JDK中Runtime的部分源码,主要分成4大代码段来粗略认识她。

第一块代码段,可以看出Runtime构造私有化,提供了静态属性,并提前创建对象实例,并提供获取实例的静态方法,这不就是单例设计模式的使用么,当有面试官再问设计模式,拿去狂喷。

第二块代码段,主要是addShutdownHook()方法,添加关闭的钩子,说的直白点,其实允许研发人员插入一段在JVM关闭时执行的代码。例如在搭建服务框架时,面对需要完成优雅停服,打扫战场,释放资源等等,诸如此类的场景下都很有用。其中在Tomcat、Jetty等容器中都可以看到shutdownHook的身影。

Runtimeruntime=Runtime.getRuntime();

runtime.addShutdownHook(newThread(){

@Override

publicvoidrun(){

System.out.println("打扫战场,释放资源,完成优雅停服");

}

});

System.out.println("服务启动完成");

代码运行效果如下。

服务启动完成

打扫战场,释放资源,完成优雅停服

第三块代码段,主要展现JDK针对Runtime提供的系列exec重载方法,这个是本次分享的重点,重头戏最后再说。

第四块代码段,主要是Runtime提供的一些获取系统信息的API,直接抛代码,拿去用就行了。

Runtimeruntime=Runtime.getRuntime();

System.out.println(String.format("JVM可用本机CPU内核数%d",runtime.availableProcessors()));

//默认为系统的1/4

System.out.println(String.format("最大可用内存空间%dM",runtime.maxMemory()/1024/1024));

//默认为系统的1/64

System.out.println(String.format("可用内存空间%dM",runtime.totalMemory()/1024/1024));

System.out.println(String.format("空闲内存空间%dM",runtime.freeMemory()/1024/1024));

代码运行输出如下,其实真实环境中不妨用模板引擎FreeMarker渲染,然后通过邮件告警,实现的逼格高一些。

2.在详细说Runtime.exec()这个重头戏之前,再品一品df这款咖啡。

Linuxdf命令,用于显示目前在系统上的磁盘使用情况统计,主要用于查看磁盘的分区,磁盘已使用的空间,剩余的空间。

命令如下:

df......

常用选项如下:

3.Runtime美酒加Shell咖啡会发生什么呢?

重头戏开始,回到Runtime的源码,我们看到exec()系列方法会帮我们启动一个Process进程,那不妨把df-h命令传入进去一探究竟。

publicclassFoo{

publicstaticvoidmain(Stringargs)throwsException{

//df命令用于查看磁盘的分区,磁盘已使用的空间,剩余的空间

//df-h以合适的单位来显示信息

System.out.println(exec("df-h"));

}

privatestaticStringexec(Stringcommand)throwsException{

Stringcmd={"/bin/sh","-c",command};

StringBuilderout=newStringBuilder();

BufferedReaderreader=null;

InputStreamin=null;

try{

Processprocess=Runtime.getRuntime().exec(cmd);

in=process.getInputStream();

reader=newBufferedReader(newInputStreamReader(in));

Stringline;

while((line=reader.readLine())!=null){

out.append(line+"n");

}

process.waitFor();

}finally{

if(reader!=null){

reader.close();

}

}

returnout.toString();

}

}

代码中会发现调用了process的waitFor()方法,此方法作用会导致当前线程等待,一直要等到由该Process对象表示的进程终止,其实也就是等待把exec里面启动的Process中的所有事都干完(生产上出问题的大多出在这儿),代码运行效果如下。

效果确实可以,那么这么一来,想监控统计什么功能,不妨直接把命令交给Java程序去执行即可。

4.

如果关注一猿小讲的伙伴应该清楚,在《如何让Java应用成为杀不死的小强?(中篇)》《如何让Java应用成为杀不死的小强?(下篇)》两篇中都用到了ProcessBuilder来执行命令启动进程,那Runtime与ProcessBuilder的主要区别是啥呢?

其实Runtime.exec()方法设计,可接受一个单独的字符串,这个字符串是通过空格来分隔可执行命令程序和参数的;当然也可以接受字符串数组参数。

如上图所示,ProcessBuilder的方法入参是一个ListString>或者多个字符串。

相同点是ProcessBuilder.start()和Runtime.exec()方法都被用来创建一个操作系统进程(执行命令行操作)。

5.好了,几分钟的简单分享,主要让你接触并真正认识一下Runtime,希望能帮助你在工作中锦上添花。

最后依然用阿里新六脉神剑中的三脉送给大家:今天最好的表现是明天最低的要求;此时此刻非我莫属;认真生活快乐工作!

linux脚本怎么定义字符串?

可以使用eval命令。eval命令,如同熟悉的其他脚本语言,会将它的参数做为命令执行。eval命令将会首先扫描命令行进行所有的替换,然后再执行命令。该命令使用于那些一次扫描无法实现其功能的变量。该命令对变量进行两次扫描。这些需要进行两次扫描的变量有时候被称为复杂变量。命令格式:eval补充说明:eval可读取一连串的参数,然后再依参数本身的特性来执行。参数不限数目,彼此之间用分号分开。用法示例:将字符串变量s的值作为命令执行s=lseval$s

linux运行脚本不需要什么权限?

运行脚本需要权限,需要可执行权限。

温馨提示:答案为网友推荐,仅供参考
相似回答