这些shell命令一般服务商是不允许运行的,要不然服务器很快就让攻击掉了
在linux下请求页面可以用wget 和 curl.统计cpu利用率到文件可以用 top -b 文件名
php给我们提供了system(),exec(),passthru()这三个函数来调用外部的命令.
虽然这三个命令都能执行linux系统的shell命令,但是其实他们是有区别的:
system() 输出并返回最后一行shell结果.
exec() 不输出结果,返回最后一行shell结果,所有结果可以保存到一个返回的数组里面.
passthru() 只调用命令,把命令的运行结果原样地直接输出到标准输出设备上.
相同点:都可以获得命令执行的状态码
例子:system("/usr/local/bin/webalizer/webalizer");
第二,给予php运行的用户和本机用户权限.php运行的用户名可以通过在localhost运行以下的php文件查到:
php
echo shell_exec("id -a");
我的Ubuntu系统的php运行用户名是www-data(好蠢的名字...)
控制台下,执行 visudo,可以打开/etc/sudoers文件进行修改(利用visudo命令的意义在于,sudoers文件很重要,如果修改错了,visudo会提示你,而直接修改会导致系统出错,无法使用sudo...)
修改的地方在root的下一行:
'查到的php运行的用户名' ALL=(ALL) NOPASSWD:ALL
'本机用户名' ALL=(ALL) ALL
通过以上设置,应该就能完成ubuntu系统下php调用并执行shell脚本.
PS.相关的命令(详细请百度google之)
$output = shell_exec("xxx.sh");//只有失败的时候返回NULL
system("cmd string",$status);//$ststus在调用成功时返回true,失败返回false
如果php允许那么大的权限,可以用 exec 函数, 不过这样做很危险.
换个思考方式, 可以php向某个文件写入一个指定数据, shell脚本定时监测这个文件,然后判断内容,再执行指定脚本