因为shell程序是解释执行的,所以不需要编译装配成目标程序,按照shell编程的惯例,以bash为例,程序的第一行一般为“# !/bin/bash”,其中#表示该行是注释,叹号“!”告诉shell运行叹号之后的命令并用文件的其余部分作为输入,也就是运行/bin/bash并让/bin/bash去执行shell程序的内容。执行shell程序的方法有三种:1、sh shell程序文件名 这种方法的命令格式为:bash shell程序文件名这实际上是调用一个新的bash命令解释程序,而把shell程序文件名作为参数传递给它。新启动的shell将去读指定的文件,执行文件中列出的命令,当所有的命令都执行完结束。该方法的优点是可以利用shell调试功能。2、sh<shell程序文件名 格式为:bash<shell 程序文件名这种方式就是利用输入重定向,使shell命令解释程序的输入取自指定的程序文件。3、用chmod命令使shell程序成为可执行的 一个文件能否运行取决于该文件的内容本身可执行且该文件具有执行权。对于shell程序,当用编辑器生成一个文件时,系统赋予的许可权限都是644(rw-r-r--),因此,当用户需要运行这个文件时,只需要直接键入文件名即可。在这三种运行shell程序的方法中,最好按下面的方式选择:当刚建立一个shell程序,对它的正确性还没有把握时,应当使用第一种方式进行调试。当一个shell程序已经调试好时,应使用第三种方式把它固定下来,以后只要键入相应的文件名即可,并可被另一个程序所调用。
1、首先电脑中需要安装的是git的应用程序,安装完成之后,可以在开始菜单进行查看。
2、并需要配置好git的bin,配置环境变量,把bin的绝对路径复制到环境变量中path。
3、配置git的环境变量之后,在任意文件进行创建一个为mkdirsh,文件名可以是随意的结尾需要为sh。
4、然后在sh的文件中进行输入#!/bin/shtouch atxtsleep 10echo "testtesttesttest">>atxt
创建一个为txt文件后testtesttesttest写入到txt文件中。
5、然后进行双击sh的文件,会d出git的命令窗口,根据代码的执行的时间窗口显示多久。
6、然后就会自动生成一个atxt的文件。
7、并会在atxt文件中写入为“testtesttesttest”的一段文字,即代表运行linux shell脚本成功。
如果shell脚本和java程序运行在不同的服务器上,可以使用远程执行Linux命令执行包,使用ssh2协议连接远程服务器,并发送执行命令就行了,ganymedssh2相关mave配置如下,你可以自己百度搜索相关资料。
如果shell脚本和java程序在同一台服务器上,
这里不得不提到java的process类了。
process这个类是一个抽象类,封装了一个进程(你在调用linux的命令或者shell脚本就是为了执行一个在linux下执行的程序,所以应该使用process类)。
process类提供了执行从进程输入,执行输出到进程,等待进程完成,检查进程的推出状态,以及shut down掉进程。
<dependency><groupId>comganymedssh2</groupId>
<artifactId>ganymed-ssh2-build</artifactId>
<version>210</version>
</dependency>
本地执行命令代码如下:
String shpath="/test/testsh"; //程序路径Process process =null;
String command1 = “chmod 777 ” + shpath;
process = RuntimegetRuntime()exec(command1);
processwaitFor();
首先脚本需要有执行权限
chmod u+x filesh
执行脚本有三种方法:
1 /filesh
特点:开启bash子进程来执行,也就是开启额外的进程来进行,不影响原进程的变量、配置等
2 bash filesh
特点:和/filesh相同
3 source filesh 或者 filesh
特点:在原bash进程中执行脚本。
第三种方法主要用于在脚本中切换用户su、切换目录cd等命令。
source 和 命令是相同的。
你可以搜索 source
补充,如何查看脚本运行是否开启了bash子进程
vim filesh
写入
#!/bin/bash
#echo $$命令会输出bash进程ID
echo $$
保存并赋予可执行权限chmod u+x filesh
在你的shell中输入,echo $$ 屏幕输出4176
/filesh 屏幕输出3600
bash filesh 屏幕输出3984
source filesh 屏幕输出4176 和 你直接在shell中输出的一样,说明是在同一个bash进程
C语言中调用shell指令,根据调用指令目的,可以区分如下两种情况:
一、需要shell指令执行某一功能,如创建文件夹,或者删除文件夹等,程序中不关注shell指令的输出,那么可以使用system函数。
system函数声明于stdlibh, 功能为调用系统命令,形式为
int system(const char cmd);
其中cmd为要执行的命令字符串,返回值为执行是否成功的标记。
比如在Linux下要删除当前文件夹下的所有扩展名为a的文件,即a, 可以写作
system("rm a -f");二、不仅要执行shell命令,还需要得知运行的打印结果,并在程序中使用。
对于此,有两种方案:
1、用system命令,将输出重定向到一个txt文件中,执行后,再读取txt文件,使用后删除。
比如Linux下获取剩余内存的指令可以写作:
system("free>resulttxt");//结果重定向到resulttxt中。FILE fp = fopen("resulttxt", "r");//打开文件。
int r;
while(fgetc(fp) != '\n'); //忽略第一行。
fscanf(fp, "%s%d%d%d",&r);//读取第四个域的值,即剩余内存值。
printf("剩余内存为%d KB\n",r);//打印结果。
fclose(fp);//关闭文件。
unlink("resulttxt");//删除临时文件。
2、使用重定向,需要经过磁盘读写,还要删除文件,相对低效。同时还有可能出现临时文件和已有文件重名,导致误删数据的情况。 所以一般使用更方便快捷的方式,即调用popen。
FILE popen(const char cmd, const char mode);
使用popen的功能和system类似,属于方法1中执行命令和打开文件的一个组合。不过这里用到的文件是隐式的,并不会在系统中真正存在。返回的指针即结果文件指针。 当使用pclose关闭后,文件自动销毁。
方法1中的例子,用popen实现如下:
FILE fp = popen("free", "r");//执行命令,同时创建管道文件。int r;
while(fgetc(fp) != '\n'); //忽略第一行。
fscanf(fp, "%s%d%d%d",&r);//读取第四个域的值,即剩余内存值。
printf("剩余内存为%d KB\n",r);//打印结果。
pclose(fp);//关闭并销毁管道文件。
三、注意事项:
虽然调用shell命令有时可以大大减少代码量,甚至有千行代码不如一句shell的说法,不过调用shell命令还是有局限性的:
1、使用shell命令会调用系统资源,效率偏低;
2、不同平台的shell指令不同,导致可移植性下降;
3、调用shell命令时会复制当前进程(fork),如果当前进程的资源占有比较大,会导致瞬间资源占用极大,甚至可能出现失败。
所以,在编码时,除非是测试性的代码,否则在正式代码中不建议使用shell。
以上就是关于如何运行shell命令第一行为什么是# !/bin/sh全部的内容,包括:如何运行shell命令第一行为什么是# !/bin/sh、如何在Windows下运行linux shell脚本、java怎么执行shell脚本等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)