纯PHP Codeigniter(CI) ThinkPHP效率测试
最近一直想做一个技术类的新闻站点,想做的执行效率高些,想用PHP做,一直纠结于用纯PHP做还是用CI或者THINKPHP。用纯PHP效率高,缺点 n多,比如安全方面、构架方面等等等等;用CI、thinkPHP的话这些需要考虑的就少些,但是怕效率方面差得太多。后来就想先测测吧,如果差得太多, 就自己写个“框架”,满足自己的需求即可的框架。
CI版本是2.1.3,thinkphp用的是3.1。
因为大多数站点所做的事情就是查询数据库,因此此次的测试着重于数据库查询并显示。测试的数据库是dede的sys_enum,631条数据。目标就是查询出这些数据并显示到页面上计算消耗时间。
===========================================================================
1.
对于纯PHP,思路是在开始时记一下毫秒数,结束时记一下毫秒数,相减后得结果。纯PHP简单,直接贴代码:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
<?php$begin=microtime();$begin=microtime_float($begin);?><?phpfunction 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;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);?> |
执行结果如下:(单位毫秒)

===========================================================================
2.对于Codeigniter的效率测试如下
CI已经框架化,为了能够计算总时间,我把计算时间的代码加到了index.php入口文件的前后。
即
|
1
2
3
4
|
<?php$begin=microtime();$begin=microtime_float($begin);?> |
这段放开头
|
1
2
3
4
|
$end=microtime();$end=microtime_float($end);echo 'time:'.($end-$begin);?> |
这段放结尾
Control是这么写的
|
1
2
3
4
5
6
7
8
|
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是这样的
|
1
2
3
4
5
6
7
|
class Testm extends CI_Model { public function testmf() { $this->load->database(); $sql="SELECT * FROM dede_sys_enum"; return $this->db->query($sql); }} |
View的关键代码是这样的
|
1
2
3
4
|
<?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次的执行时间

===========================================================================
3.对于thinkPHP:
我在自建的入口文件里填写如下代码:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
$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
|
1
2
3
4
5
6
7
8
|
class IndexAction extends Action { public function index(){ $Sys_enum=new Model("sys_enum"); $list =$Sys_enum->select(); $this->assign('test', $list); $this->display(); }} |
还有View的关键代码如下
|
1
2
3
4
|
<?phpforeach($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次的访问时间如下:

4.结论哈:
然后取10次的平均值是:
11.565332031250 (PHP)
54.319799804790 (CI)
132.997436523438 (ThinkPHP)
CI与纯PHP
54.319799804790/11.565332031250=4.696778238447 约等于4.7倍
ThinPHP与PHP
132.997436523438/11.565332031250=11.499664355859 约等于11.5倍
5:总结
那么也就是说,纯PHP是CI的4.5是ThinkPHP的11.5倍
我想还是我自己写个简单的框架吧,能够完成开发效率就OK的框架吧。
纯PHP Codeigniter(CI) ThinkPHP效率测试的更多相关文章
- NHibernate Demo 和 效率测试
本文关于NHibernate的Demo和效率测试,希望对大家有用. 1.先去官网下载Nhibernate 2.放入到项目中并建立Helper类 private static ISession _Ses ...
- 关于 pgsql 数据库json几个函数用法的效率测试
关于 pgsql 数据库json几个函数用法的效率测试 关于pgsql 几个操作符的效率测试比较1. json::->> 和 ->> 测试方法:单次运行100次,运行10个单次 ...
- Python_线程、线程效率测试、数据隔离测试、主线程和子线程
0.进程中的概念 三状态:就绪.运行.阻塞 就绪(Ready):当进程已分配到除CPU以外的所有必要资源,只要获得处理机便可立即执行,这时的进程状态成为就绪状态. 执行/运行(Running)状态:当 ...
- 进程池原理及效率测试Pool
为什么会有进程池的概念? 当我们开启50个进程让他们都将100这个数减1次减到50,你会发现特别慢! 效率问题,原因: 1,开辟内存空间.因为每开启一个进程,都会开启一个属于这个进程池的内存空间,因为 ...
- postgresql-int,bigint,numeric效率测试
在postgresql9.5的时候做过一个测试就是sum()的效率最终的测试结果是sum(int)>sum(numeric)>sum(bigint)当时比较诧异为啥sum(bigint)效 ...
- ORM for Net主流框架汇总与效率测试
框架已经被越来越多的人所关注与使用了,今天我们就来研究一下net方面的几个主流ORM框架,以及它们的效率测试(可能会有遗漏欢迎大家讨论). ORM框架:Object/Relation Mapping( ...
- Python--day39--进程池原理及效率测试
#为什么要有进程池的概念 #效率 #每次开启进程都要创建一个属于这个进程的内存空间 #寄存器 堆栈 文件 #进程过多 操作系统调度进程 # #进程池 #python中的 先创建一个属于进程的池子 #这 ...
- 关于pgsql 几个操作符的效率测试比较
关于pgsql 几个操作符的效率测试比较1. json::->> 和 ->> 测试方法:单次运行100次,运行10个单次取平均时间.测试结果:->> 效率高 5% ...
- CodeIgniter(CI)框架中的验证码
在CodeIgniter框架中,CI本身自带了验证码,但是查看文档的时候,发现: 需要新建一个表,用来存储验证码信息.因为习惯了session存储验证码信息,所以我把我认为比较好看的验证码应用在了CI ...
随机推荐
- 13、如何拆分含有多种分隔符的字符串 14、如何判断字符串a是否以字符串b开头或结尾 15、如何调整字符串中文本的格式 16、如何将多个小字符串拼接成一个大的字符串
13.如何拆分含有多种分隔符的字符串 import re s = "23:41:2314\1234#sdf\23;" print(re.split(r'[#:\;]+',s)) ...
- WebServer Project-01-反射
简介 上网浏览网页,离不开服务器,客户请求页面,服务器响应页面,响应的内容是根据每个web请求来产生动态内容的,其内部即启动多个线程来产生不同内容.这种请求响应的交互,都是基于HTTP协议的. 当然现 ...
- 如何解决 react-create-app 里面的 no-unused-vars ?
如果每次启动都有一大串的no-unused-vars 是不是感觉特别烦,不用担心啦,有个配置可以解决它: 在Hbuild 里面可以新建一个 .eslintrc 其他文件(伤心的是我在webStorm ...
- javascript中的insertBefore方法
<SCRIPT LANGUAGE="JavaScript"> window.onload=function(){ var a =document.createEleme ...
- 磁盘设备在 Linux 下的表示方法
在 Linux 系统中磁盘设备文件的命名规则为: 主设备号 + 次设备号 + 磁盘分区号 对于目前常见的磁盘,一般表示为: sd[a-z]x 主设备号代表设备的类型,相同的主设备号表示同类型的设备. ...
- springboot + zipkin(brave-okhttp实现)
一.前提 1.zipkin基本知识:附8 zipkin 2.启动zipkin server: 2.1.在官网下载服务jar,http://zipkin.io/pages/quickstart.html ...
- Redis 小调研
一. 概况: Redis是一款开源的.网络化的.基于内存的.可进行数据持久化的Key-Value存储系统.它的数据模型建立在外层,类似于其它结构化存储系统,是通过Key映射Value的方式来建立字典以 ...
- mysql数据库 --数据类型、约束条件
今日内容 表的详细使用 1.创建表的完成语法 2.字段类型 整型.浮点型.字符类型.日期类型.枚举与集合类型 3.约束条件 primary key.unique.not null.default 一. ...
- scala自定义隐式转换
Scala自定义隐式转换 一.编写隐式转换类 /** * Author Mr. Guo * Create 2019/4/20 - 17:40 */ object StringImprovments { ...
- nacos配置服务入门
1.nacos服务端部署 参见官方文档:https://nacos.io/zh-cn/docs/quick-start.html 2.nacos配置中心功能使用 在pol文件中添加依赖: 在启动类中使 ...