纯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 ); ?> <?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 ; 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
|
<?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次的访问时间如下:
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 ...
随机推荐
- MySql 主从复制及深入了解
分享一个不错的mysql文章 https://segmentfault.com/a/1190000008942618
- hadoop备战:hbase的分布式安装经验
配置HBase时,首先考虑的肯定是Hbase版本号与你所装的hadoop版本号是否匹配.这一点我在之前 的博客中已经说明清楚,hadoop版本号与hbase版本号的匹配度,那是官方提供的.以下的实验就 ...
- centos 时区设置初认识
由于一些需要,我租用了一个海外服务器,并开始了我的centos之旅. 由于之前一直用虚拟机,而且在国内,所以不需要考虑时区的问题,但是现在,这个服务器是在海外的,所以就必须考虑时区的问题了.更何况我的 ...
- Linux 进程间通信 有名管道(fifo)
有名管道特点: 1)无名管道只能用于具有亲缘关系的进程之间,这就限制了无名管道的使用范围 2)有名管道可以使互不相关的两个进程互相通信. 3)有名管道可以通过路径名来指出,并且在文件系统中可见,但内容 ...
- Mysql优化-典型的服务器配置
内存配置相关参数 mysql内存分配需要考虑到操作系统需要使用的内存,其他应用程序所要使用的内存,mysql的会话数以及每个会话使用的内存,然后就是操作系统实例所使用的内存.生产环境的mysql往往都 ...
- dell服务器 bios界面
正好遇上dell服务器,需要安装操作系统,也因此就简单记录一下遇到的一些小常识. 首先要进入dell服务器的服务器系统操作界面,一般在开机会有提示,时间足够反应,我遇到的是需要按 F9 进入操作界面, ...
- SQL Injection简介
- ubuntu下网页视频或音频无法播放
有时,网页的音频或视频内容在 Firefox 下无法正常下载和播放.所需的插件没找到.过期.被阻止.和其他插件或扩展冲突,或者是内容由于某种原因被阻止.本文会帮助你解决这些问题. Flash 插件 F ...
- DataTable转对象Model
我们经常需要从数据库表中取数,取数是以取DataTable的方式,但是我么希望以对象为单位进行这种操作.即存在把取到的DataTable(数据表)转换为ModelList(对象集合)的需求. 原理稍微 ...
- leetcood学习笔记-171-excel表列序号
题目描述: 方法: class Solution: def titleToNumber(self, s: str) -> int: num = 0 r = 1 for i in s[::-1]: ...