doushuhuai7247 2016-01-22 16:47
浏览 345
已采纳

PHP exec()和运行shell脚本给出了不同的结果

I have script.sh that sends a request to some URL and prints the execution time using whet. Here is the source code:

time wget http://some.url

When I run it from command line, I see time result with an accuracy of 3 decimal places:

real    0m0.584s
user    0m0.000s
sys     0m0.002s

But, when I run this SH using PHP function exec("script.sh", $output) - , I see time result with an accuracy of only 2 decimal places:

0.00user 0.00system 0:00.32elapsed 0%CPU (0avgtext+0avgdata 3788maxresident)k

How can I get the same result, as I do see in command line?

  • 写回答

1条回答 默认 最新

  • drgovyk64676 2016-01-22 20:28
    关注

    The answer is in the manual:

    Note: some shells (e.g., bash(1)) have a built-in time command that provides less functionality than the command described here. To access the real command, you may need to specify its pathname (something like /usr/bin/time).

    You're getting the increased precision from the bash builtin; if you run /usr/bin/time from the shell you will see two decimal places as well.

    Unfortunately, time is a special case, in that it's a keyword and not actually a builtin command. Otherwise bash's builtin command could be used to force it.

    So it looks like you're stuck with two decimal places unless you want to try a different method:

    start_time=`date +%s%N`
    wget http://some.url
    end_time=`date +%s%N`
    bc -l <<< "scale=4;($end_time - $start_time) / 1000000000"
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!