require和require_once经济性能对比

require和require_once都是PHP函数,开发人员可以使用它们在某个特定的脚本中导入外部PHP文件。你可以根据应用程序的复杂度调用一次或若干次require_once/require。使用require(而不是require_once)可以提高应用程序的性能

测试前准备:

创建4个空的类来模拟主脚本要使用的外部PHP文件脚本。

ClassA.php:

<?php

class ClassA
{

}

ClassB.php:

<?php

class ClassB
{

}

ClassC.php:

<?php

class ClassC
{

}

ClassD.php:

<?php

class ClassD
{

}

使用require_once导入外部文件:

index.php:

<?php

require_once './ClassA.php';
require_once './ClassB.php';
require_once './ClassC.php';
require_once './ClassD.php';

echo "Only testing require_once";

重启服务器,使用ab压力测试工具模拟10000个请求,同一时间有5个并发请求。

ab.exe -c 5 -n 10000 http://www.demo.com/optimization/index.php

测试结果:

D:\phpStudy\Apache\bin>ab.exe -c 5 -n 10000 http://www.demo.com/optimization/index.php
This is ApacheBench, Version 2.3 <$Revision: 1748469 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking www.demo.com (be patient)
Completed 1000 requests
Completed 2000 requests
Completed 3000 requests
Completed 4000 requests
Completed 5000 requests
Completed 6000 requests
Completed 7000 requests
Completed 8000 requests
Completed 9000 requests
Completed 10000 requests
Finished 10000 requests


Server Software:        Apache/2.4.23
Server Hostname:        www.demo.com
Server Port:            80

Document Path:          /optimization/index.php
Document Length:        25 bytes

Concurrency Level:      5
Time taken for tests:   17.446 seconds
Complete requests:      10000
Failed requests:        0
Total transferred:      2280000 bytes
HTML transferred:       250000 bytes
Requests per second:    573.20 [#/sec] (mean)
Time per request:       8.723 [ms] (mean)
Time per request:       1.745 [ms] (mean, across all concurrent requests)
Transfer rate:          127.63 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.4      0       2
Processing:     2    8  90.4      4    2503
Waiting:        1    7  90.5      3    2503
Total:          2    8  90.4      4    2504

Percentage of the requests served within a certain time (ms)
  50%      4
  66%      5
  75%      5
  80%      5
  90%      5
  95%      5
  98%      6
  99%      6
 100%   2504 (longest request)

使用ab工具测试require_once,可以看到相应时间是8.723ms,该脚本每秒支持573.20个请求。

 

使用require导入外部文件:

index_1.php:

<?php

require './ClassA.php';
require './ClassB.php';
require './ClassC.php';
require './ClassD.php';

echo "Only testing require";

重启服务器,使用ab压力测试工具模拟10000个请求,同一时间有5个并发请求。

ab.exe -c 5 -n 10000 http://www.demo.com/optimization/index_1.php

测试结果:

D:\phpStudy\Apache\bin>ab.exe -c 5 -n 10000 http://www.demo.com/optimization/index_1.php
This is ApacheBench, Version 2.3 <$Revision: 1748469 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking www.demo.com (be patient)
Completed 1000 requests
Completed 2000 requests
Completed 3000 requests
Completed 4000 requests
Completed 5000 requests
Completed 6000 requests
Completed 7000 requests
Completed 8000 requests
Completed 9000 requests
Completed 10000 requests
Finished 10000 requests


Server Software:        Apache/2.4.23
Server Hostname:        www.demo.com
Server Port:            80

Document Path:          /optimization/index_1.php
Document Length:        20 bytes

Concurrency Level:      5
Time taken for tests:   17.207 seconds
Complete requests:      10000
Failed requests:        0
Total transferred:      2230000 bytes
HTML transferred:       200000 bytes
Requests per second:    581.16 [#/sec] (mean)
Time per request:       8.604 [ms] (mean)
Time per request:       1.721 [ms] (mean, across all concurrent requests)
Transfer rate:          126.56 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.4      0      21
Processing:     1    8  86.5      4    2320
Waiting:        1    7  86.5      3    2320
Total:          1    8  86.5      4    2320

Percentage of the requests served within a certain time (ms)
  50%      4
  66%      5
  75%      5
  80%      5
  90%      5
  95%      6
  98%      7
  99%      7
 100%   2320 (longest request)

D:\phpStudy\Apache\bin>ab.exe -c 5 -n 10000 http://www.demo.com/optimization/index_1.php
This is ApacheBench, Version 2.3 <$Revision: 1748469 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking www.demo.com (be patient)
Completed 1000 requests
Completed 2000 requests
Completed 3000 requests
Completed 4000 requests
Completed 5000 requests
Completed 6000 requests
Completed 7000 requests
Completed 8000 requests
Completed 9000 requests
Completed 10000 requests
Finished 10000 requests

使用ab工具测试require,可以看到相应时间是8.604ms,该脚本每秒支持581.16个请求。

 

转载于:https://www.cnblogs.com/zhouguowei/p/9444085.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值