纯PHP Codeigniter(CI) ThinkPHP效率测试
2012-11-05 13:45
375 查看
最近一直想做一个技术类的新闻站点,想做的执行效率高些,想用PHP做,一直纠结于用纯PHP做还是用CI或者THINKPHP。用纯PHP效率高,缺点n多,比如安全方面、构架方面等等等等;用CI、thinkPHP的话这些需要考虑的就少些,但是怕效率方面差得太多。后来就想先测测吧,如果差得太多,就自己写个“框架”,满足自己的需求即可的框架。
CI版本是2.1.3,thinkphp用的是3.1。
因为大多数站点所做的事情就是查询数据库,因此此次的测试着重于数据库查询并显示。测试的数据库是dede的sys_enum,631条数据。目标就是查询出这些数据并显示到页面上计算消耗时间。
===========================================================================
1.
对于纯PHP,思路是在开始时记一下毫秒数,结束时记一下毫秒数,相减后得结果。纯PHP简单,直接贴代码:
执行结果如下:(单位毫秒)
![](http://static.oschina.net/uploads/space/2012/1105/112523_A74j_246558.jpg)
===========================================================================
2.对于Codeigniter的效率测试如下
CI已经框架化,为了能够计算总时间,我把计算时间的代码加到了index.php入口文件的前后。
即
这段放开头
这段放结尾
Control是这么写的
为了像那么回事
我分别用了model 和view
model是这样的
View的关键代码是这样的
下面是10次的执行时间
![](http://static.oschina.net/uploads/space/2012/1105/131145_zlz0_246558.jpg)
===========================================================================
3.对于thinkPHP:
我在自建的入口文件里填写如下代码:
还有View的关键代码如下
得到10次的访问时间如下:
![](http://static.oschina.net/uploads/space/2012/1105/173850_Zh2J_246558.jpg)
4.结论哈:
然后取10次的平均值是:
11.565332031250 (PHP)
54.319799804790 (CI)
132.997436523438 (ThinkPHP)
CI与纯PHP
54.319799804790/11.565332031250=4.696778238447 约等于4.7倍
ThinPHP与PHP
[b]132.997436523438/11.565332031250=11.499664355859[/b] 约等于11.5倍
5:总结
那么也就是说,纯PHP是CI的4.5是ThinkPHP的11.5倍
我想还是我自己写个简单的框架吧,能够完成开发效率就OK的框架吧。
CI版本是2.1.3,thinkphp用的是3.1。
因为大多数站点所做的事情就是查询数据库,因此此次的测试着重于数据库查询并显示。测试的数据库是dede的sys_enum,631条数据。目标就是查询出这些数据并显示到页面上计算消耗时间。
===========================================================================
1.
对于纯PHP,思路是在开始时记一下毫秒数,结束时记一下毫秒数,相减后得结果。纯PHP简单,直接贴代码:
<?php $begin=microtime(); $begin=microtime_float($begin); ?> <?php function microtime_float($time) { list($usec, $sec) = explode(" ", $time); return (((float)$usec + (float)$sec)*1000); } ?> <?php $link = mysql_connect('localhost', 'root', 'founder') or die('Could not connect: ' . mysql_error()); mysql_select_db('dedecmsv57utf8sp1') or die('Could not select database'); $query='SELECT * FROM dede_sys_enum'; $result = mysql_query($query) or die('Query failed: ' . mysql_error()); echo "<table width=\"416\" border=\"0\" cellpadding=\"1\" cellspacing=\"0\"><tr><td>ID</td><td>ename</td><td>egroup</td></tr>"; while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) { echo "\t<tr>\n"; foreach ($line as $col_value) { echo "\t\t<td>$col_value</td>\n"; } echo "\t</tr>\n"; } echo "</table>\n"; mysql_free_result($result); mysql_close($link); $end=microtime(); $end=microtime_float($end); echo 'time:'.($end-$begin); ?>
执行结果如下:(单位毫秒)
![](http://static.oschina.net/uploads/space/2012/1105/112523_A74j_246558.jpg)
===========================================================================
2.对于Codeigniter的效率测试如下
CI已经框架化,为了能够计算总时间,我把计算时间的代码加到了index.php入口文件的前后。
即
<?php $begin=microtime(); $begin=microtime_float($begin); ?>
这段放开头
$end=microtime(); $end=microtime_float($end); echo 'time:'.($end-$begin); ?>
这段放结尾
Control是这么写的
class Test extends CI_Controller { public function index() { $this->load->model('testm'); $data['test']=$this->testm->testmf(); $this->load->view('test',$data); } }
为了像那么回事
我分别用了model 和view
model是这样的
class Testm extends CI_Model { public function testmf() { $this->load->database(); $sql="SELECT * FROM dede_sys_enum"; return $this->db->query($sql); } }
View的关键代码是这样的
<?php foreach($test->result() as $row) echo "<tr><td>".$row->id."</td><td>".$row->ename."</td><td>".$row->evalue."</td><td>".$row->egroup."</td><td>".$row->disorder."</td><td>".$row->issign."</td></tr>"; ?>
下面是10次的执行时间
![](http://static.oschina.net/uploads/space/2012/1105/131145_zlz0_246558.jpg)
===========================================================================
3.对于thinkPHP:
我在自建的入口文件里填写如下代码:
$begin=microtime(); $begin=microtime_float($begin); function microtime_float($time) { list($usec, $sec) = explode(" ", $time); return (((float)$usec + (float)$sec)*1000); } require("./tp/ThinkPHP.php"); $end=microtime(); $end=microtime_float($end); echo 'time:'.($end-$begin);然后按要求做了action
class IndexAction extends Action { public function index(){ $Sys_enum=new Model("sys_enum"); $list =$Sys_enum->select(); $this->assign('test', $list); $this->display(); } }
还有View的关键代码如下
<?php foreach($test as $row) echo "<tr><td>".$row['id']."</td><td>".$row['ename']."</td><td>".$row['evalue']."</td><td>".$row['egroup']."</td><td>".$row['disorder']."</td><td>".$row['issign']."</td></tr>"; ?>
得到10次的访问时间如下:
![](http://static.oschina.net/uploads/space/2012/1105/173850_Zh2J_246558.jpg)
4.结论哈:
然后取10次的平均值是:
11.565332031250 (PHP)
54.319799804790 (CI)
132.997436523438 (ThinkPHP)
CI与纯PHP
54.319799804790/11.565332031250=4.696778238447 约等于4.7倍
ThinPHP与PHP
[b]132.997436523438/11.565332031250=11.499664355859[/b] 约等于11.5倍
5:总结
那么也就是说,纯PHP是CI的4.5是ThinkPHP的11.5倍
我想还是我自己写个简单的框架吧,能够完成开发效率就OK的框架吧。
相关文章推荐
- 纯PHP Codeigniter(CI) ThinkPHP效率测试
- 纯PHP Codeigniter(CI) ThinkPHP效率测试
- 关于doitphp,thinkphp,yii,ci,doophp等框架的性能对比测试
- 关于doitphp,thinkphp,yii,ci,doophp等框架的性能对比测试
- CI框架源码阅读笔记5 基准测试 BenchMark.php
- CodeIgniter源码阅读笔记(4)——性能测试Benchmark.php
- Codeigniter(CI) 去掉 URL 中的 index.php
- Pear Benchmarking测试PHP程序效率
- CodeIgniter(CI)去掉默认url中的index.php
- PHP内置的Math函数效率测试
- CI框架源码阅读笔记5 基准测试 BenchMark.php
- PHP框架之CI:CodeIgniter
- nginx rewrite php的CI(CodeIgniter)框架
- CI(CodeIgniter)简单统计访问人数实现方法[原创]_php实例_脚本之家
- php中使用mysqli和pdo扩展,测试连接mysql数据库的效率。
- 第5月第16天 php crud CodeIgniter CI_DB_active_record
- 去掉CodeIgniter(CI)默认url中的index.php
- PHP CodeIgniter(CI)框架中去掉 index.php方法
- PHP判断素数,循环,筛选——默认可执行时间秒数,默认可执行空间。用来测试运行效率
- CI(codeigniter)框架,routes.php设置正确,但是显示服务器错误,是__construct少写了一个下划线