linuxshell调用shell
❶ 在linux下shell调用其他shell的问题
我在linux下测试了(下面x.sh调用y.sh),应该不会啊!
x.sh
#!/bin/sh
y.sh
echo "===="$?
for i in 1 2 3
do
sleep 1
echo "i="$i
done
=====================
y.sh
#!/bin/sh
echo "exit!"
exit 0
你用的是那种shell?在那种环境下运行?
❷ 如何运行linux shell程序
如何运行shell程序,如何在shell程序以及后续脚本中使用同一个变量,这些在工作中经常用到, 我找到如下的文章,再加深复习一下。
1 source命令用法:
source FileName
作用:在当前bash环境下读取并执行FileName中的命令。该filename文件可以无"执行权限"
注:该命令通常用命令“.”来替代。
如:source .bash_profile
. .bash_profile两者等效。
source(或点)命令通常用于重新执行刚修改的初始化文档。
source命令(从 C Shell 而来)是bash shell的内置命令。
点命令,就是个点符号,(从Bourne Shell而来)。
source的程序主体是bash,脚本中的$0变量的值是bash,而且由于作用于当前bash环境,脚本中set的变量将直接起效
2 sh, bash的命令用法:
sh/bash FileName
作用:打开一个子shell来读取并执行FileName中命令。该filename文件可以无"执行权限"
注:运行一个shell脚本时会启动另一个命令解释器.
每个shell脚本有效地运行在父shell(parent shell)的一个子进程里.
这个父shell是指在一个控制终端或在一个xterm窗口中给你命令指示符的进程.
shell脚本也可以启动他自已的子进程.
这些子shell(即子进程)使脚本并行地,有效率地地同时运行脚本内的多个子任务.
在ubuntu中sh只是bash的一个链接。
由于是在子shell中执行,脚本设置的变量不会影响当前shell。
3 ./的命令用法:
./FileName
作用:打开一个子shell来读取并执行FileName中命令。该filename文件需要"执行权限"
注:运行一个shell脚本时会启动另一个命令解释器.
每个shell脚本有效地运行在父shell(parent shell)的一个子进程里.
这个父shell是指在一个控制终端或在一个xterm窗口中给你命令指示符的进程.
shell脚本也可以启动他自已的子进程.
这些子shell(即子进程)使脚本并行地,有效率地地同时运行脚本内的多个子任务.
由于是在子shell中执行,脚本设置的变量不会影响当前shell。
4 export:
一个变量创建时,它不会自动地为在它之后创建的shell进程所知。而命令export可以向后面的shell传递变量的值。当一个shell脚本调用并执行时,它不会自动得到原为脚本(调用者)里定义的变量的访问权,除非这些变量已经被显式地设置为可用。export命令可以用于传递一个或多个变量的值到任何后继脚本
5. 举例
比如您在一个脚本里export $KKK=111 ,假如您用./a.sh执行该脚本,执行完毕后,您运行 echo $KKK ,发现没有值,假如您用source来执行 ,然后再echo ,就会发现KKK=111。因为调用./a.sh来执行shell是在一个子shell里运行的,所以执行后,结构并没有反应到父shell里,但是 source不同他就是在本shell中执行的,所以能够看到结果.
小测试
1 建立test.sh
#!/bin/bash
export s=/home/jboss/
2 执行命令: source test.sh
echo $s
结果输出: /home/jboss/
3 新开个shell
执行命令: ./test.sh
echo $s
结果: 没有输出s值
结论:
1、执行脚本时是在一个子shell环境运行的,脚本执行完后该子shell自动退出。
2、一个shell中的系统环境变量才会被复制到子shell中(用export定义的变量);
3、一个shell中的系统环境变量只对该shell或者它的子shell有效,该shell结束时变量消失(并不能返回到父shell中)。3、不用 export定义的变量只对该shell有效,对子shell也是无效的。
直接执行一个脚本文件是在一个子shell中运行的,而source则是在当前shell环境中运行的。
source可以让脚本影响它们的父shell环境,这和export去影响子shell环境相反.
❸ linux下如何用c语言调用shell命令
可以使用system函数调用。
system("shell_command");
可以实现在shell中调用shell_command的作用。
比如设置网卡IP为192.168.1.100,可以写作
system("ifconfig
eth0
192.168.1.100");
❹ LINUX中如何使用Shell,我刚用,都没找到地方
所谓的shell就是终端。
点从这里开始--系统工具--新建终端。
或者在XWIDOWS桌面里面直接点右键,在右键菜单中点新建终端。
我指的是redhatlinux g桌面系统。
❺ 如何调用linux系统的shell
你这挺怪,你ssh连接到另一台linux,看到的就是这机器的shell了,你要给这个用户帐号指定个shell,用nolongin自然就没了。
这么说吧,你用putty登陆到linux,看到的就是linux的shell了,帐号shell要先给,这个是在/etc/passed里写的,
不知道你是不是问的这个
❻ linux下怎样用c语言调用shell命令
C程序调用shell脚本共同拥有三种法子 :system()、popen()、exec系列数call_exec1.c ,
system() 不用你自己去产生进程。它已经封装了,直接增加自己的命令
exec 须要你自己 fork 进程,然后exec 自己的命令
popen() 也能够实现运行你的命令,比system 开销小
方法一、system()的使用。我直接上代码吧
int system(const char *command);
我在/home/book/shell新建一个test.sh文件例如以下:
<span style="font-size:18px;"><span style="font-size:18px;">#!bin/bash
echo $HOME
echo "the is test!"</span></span>
test.c文件例如以下:
<span style="font-size:18px;"><span style="font-size:18px;">#include<stdlib.h>
int main()
{
system("bash /home/book/shell/test.sh"); /* chmod +x test.sh ,路径前面要加上bash */
return 0;
}</span></span>
运行例如以下命令来编译:
<span style="font-size:18px;">gcc test.c -o test
</span>
测试命令:
<span style="font-size:18px;">./test</span>
结果例如以下:
<span style="font-size:18px;">/root
the is test!</span>
方法二:popen() 会调用fork()产生 子历程,然后从子历程中调用/bin/sh -c来履行 参数command的指令。参数type可应用 “r”代表读取。“w”代表写入。遵循此type值。popen()会建立 管道连到子历程的标准 输出设备 或标准 输入设备 ,然后返回一个文件指针。
随后历程便可利用 此文件指针来读取子历程的输出设备 或是写入到子历程的标准 输入设备 中。此外,全部应用 文 件指针(FILE*)操作的函数也都能够应用 ,除了fclose()以外。
返回值:若成功 则返回文件指针,否则返回NULL,差错 原因存于errno中。注意:在编写具SUID/SGID权限的程序时请尽量避免应用 popen()。popen()会继承环境变量。通过环境变量可能会造成系统安全的问题
FILE *popen(const char *command, const char *type);
int pclose(FILE *stream);
其它不用改变我们直接改动test.c文件:
#include<stdio.h>
int main()
{
char buffer[80];
FILE *fp=popen("bash /home/book/shell/test.sh","r");
fgets(buffer,sizeof(buffer),fp);
printf("%s",buffer);
pclose(fp);
return 0;
}
方法三:exec函数簇 (我不太懂,别人的。也没有验证。习惯方法一)
须要注意的是exec并非1个函数, 事实上它仅仅是一组函数的统称, 它包含以下6个函数:
#include <unistd.h>
int execl(const char *path, const char *arg, ...);
int execlp(const char *file, const char *arg, ...);
int execle(const char *path, const char *arg, ..., char *const envp[]);
int execv(const char *path, char *const argv[]);
int execvp(const char *file, char *const argv[]);
int execve(const char *path, char *const argv[], char *const envp[];
能够见到这6个函数名字不同, 并且他们用于接受的参数也不同.
实际上他们的功能都是几乎相同的, 由于要用于接受不同的参数所以要用不同的名字区分它们, 毕竟c语言没有函数重载的功能嘛..
可是实际上它们的命名是有规律的:
exec[l or v][p][e]
exec函数里的参数能够分成3个部分, 运行文件部分, 命令参数部分, 环境变量部分.
比如我要运行1个命令 ls -l /home/gateman
运行文件部分就是 "/usr/bin/ls"
命令参赛部分就是 "ls","-l","/home/gateman",NULL 见到是以ls开头 每1个空格都必须分开成2个部分, 并且以NULL结尾的啊.
环境变量部分, 这是1个数组,最后的元素必须是NULL 比如 char * env[] = {"PATH=/home/gateman", "USER=lei", "STATUS=testing", NULL};
好了说下命名规则:
e兴许, 参数必须带环境变量部分, 环境变零部分参数会成为运行exec函数期间的环境变量, 比较少用
l 兴许, 命令参数部分必须以"," 相隔, 最后1个命令参数必须是NULL
v 兴许, 命令参数部分必须是1个以NULL结尾的字符串指针数组的头部指针. 比如char * pstr就是1个字符串的指针, char * pstr[] 就是数组了, 分别指向各个字符串.
关于Linux命令的介绍,看看《linux就该这么学》,具体关于这一章地址3w(dot)linuxprobe/chapter-02(dot)html
p兴许, 运行文件部分能够不带路径, exec函数会在$PATH中找
还有1个注意的是, exec函数会代替运行它的进程, 也就是说, 一旦exec函数运行成功, 它就不会返回了, 进程结束. 可是假设exec函数运行失败, 它会返回失败的信息, 并且进程继续运行后面的代码!
通常exec会放在fork() 函数的子进程部分, 来替代子进程运行啦, 运行成功后子程序就会消失, 可是运行失败的话, 必须用exit()函数来让子进程退出!
❼ linux内核模块中调用shell脚本
内核模块是用C语言写的,如果你想开机启动脚本,可以将shell路径写在profile文件中
❽ Linux调用iptables Shell调用
如果你的网站是php的话应该可以实现
$ip=$_POST("ip")//这里获取你输入的ip地址,当然可以对ip地址格式进行判断,这里略过
system("你调用写好的脚本文件,必须有可执行权限")
比如你要删除一个文件
system("/bin/rm -rf $filename")
命令或者脚本都要完整路径
至于邮件也可以用system实现,你是要发送的你linux下的邮箱,还是其他比如163邮箱?请说清楚
具体命令是http://nxcom.vicp.net/?post=13
某个ip的上网记录无法用iptables来获取,只能获取某个ip访问的80端口
的信息
这里你必须写好iptables
iptables -A OUTPUT -s 192.168.1.100 -p tcp --dport 80 -j LOG
把符合上面的规则保存到某个日志文件中,然后读取即可
❾ 在linux下调用shell,是同步还是异步
系统调用是程序的事情 shell是人机接口,是你输入命令的地。 这两个完全无关。 你在shell里面输入命令,shell会根据你的命令执行程序, 执行的程序有可能调用系统的功能。
❿ linux系统调用 shell命令 c库函数怎么区分
首先,命令应该是好和其他两个区分开来的了,因为命令都是可以直接敲在shell上面回车执行的,而系统调用和库函数都不行;
其次,Linux系统调用和C库函数都是函数的形式,即都是“func(args)”的形式,但系统调用是
由系统内核对外提供的服务接口;C库函数和你自己写的普通的函数没有本质的区别,只是在C标准库中而已,Linux上面glibc就是C函数库。从表面上看两者不太好区分,不过,你可以从它们需要包含的头文件来区分,C库函数像printf在<stdio.h>中,std就是标准(standard)的缩写形式,因此在<stdxxx.h>中的函数,基本都是C库函数;像 ssize_t read(int fd, void *buf, size_t count);这样很多的系统调用是包含在<unistd.h>中的,unistd意思是UNIX Standard,从这个意义就可以区分了。
希望对你有所帮助,如还有问题,可随时联系我:-)