php 开启opcode,php 开启 opcode 测试

php 开启opcode,php 开启 opcode 测试php 开启 opcode 测试 合理使用 实验环境系统信息 Linuxlocalho localdomain3 10 0 514 10 2 el7 x86 64 1SMPFriMar30 04 05UTC2017x86 64×86 64×86 64GNU Linux 内存 512MCPU1 核 PHP 版本 PHP7 0 21 amp ZendOPcach

php 开启 opcode 测试,合理使用~

实验环境系统信息 Linux localhost.localdomain 3.10.0-514.10.2.el7.x86_64 #1 SMP Fri Mar 3 00:04:05 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux

内存 512M CPU 1核

PHP 版本 PHP 7.0.21 & Zend OPcache v7.0.21

opcode 介绍php 运行方式Scanning(Lexing) ,将PHP代码转换为语言片段(Tokens)

Parsing, 将Tokens转换成简单而有意义的表达式

Compilation, 将表达式编译成Opocdes

Execution, 顺次执行Opcodes,每次一条,从而实现PHP脚本的功能。

Zend 中opcode 缓存结构体

struct _zend_op {

opcode_handler_t handler; // 执行该opcode时调用的处理函数 znode result; // 函数返回信息 znode op1; // 参数1 znode op2; // 参数2 ulong extended_value;

uint lineno;

zend_uchar opcode; // opcode代码};参数配置参考地址 点击这里

opcode 注意事项opcode 生成规则是,通过时间戳进行生成新 opcode,在生产环境中如果发布版本回退,老的opcode 生成时间会大于回退版本文件的当前时间戳的。 也就是说不会再更新啦。

测试结果

测试代码

for($i=0;$i<100;$i++){

echo “Hello Opcache”;

}执行命令 ab -n 1000 -c 100 http://192.168.1.110:8080/t1.php

开启时测试结果结果Concurrency Level: 100

Time taken for tests: 0.976 seconds

Complete requests: 1000

Failed requests: 0

Write errors: 0

Total transferred: bytes

HTML transferred: bytes

Requests per second: 1024.27 [#/sec] (mean)

Time per request: 97.630 [ms] (mean)

Time per request: 0.976 [ms] (mean, across all concurrent requests)

Transfer rate: 1430.38 [Kbytes/sec] received

关闭后测试结果Concurrency Level: 100

Time taken for tests: 1.695 seconds

Complete requests: 1000

Failed requests: 0

Write errors: 0

Total transferred: bytes

HTML transferred: bytes

Requests per second: 589.89 [#/sec] (mean)

Time per request: 169.522 [ms] (mean)

Time per request: 1.695 [ms] (mean, across all concurrent requests)

Transfer rate: 823.78 [Kbytes/sec] received

结论在开启 opcache 后 每秒钟请求从 589.89 增长到了 1024.27 合理利用 opcache 会给程序带来不错的优化效果

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233637.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • cshtml的美化

    cshtml的美化c#webapp美化工作美化工作更改css框架css在cshtml中的位置网上的bootstrap模板资源1.从网站上下载模板2.使用模板更多的资料美化工作默认大家已经掌握了MVC框架的概念和使用方式,本文章只将如何在MVC基础上进行简单的美化工作更改css框架css在cshtml中的位置对html语言有所了解的各位应该知道,css一般写在头中,也就是<head></head>所在的位置中,在cshtml中也是这样。注意看MVC框架的_Layout.cshtml中的

    2022年6月16日
    35
  • jar和war的区别

    jar和war的区别Jar、war在文件结构上,二者并没有什么不同,它们都采用zip或jar档案文件压缩格式。但是它们的使用目的有所区别:jar1.Jar文件(扩展名为.Jar,JavaApplicationArchive)包含Java类的普通库、资源(resources)、辅助文件(auxiliaryfiles)等。2.jar包是java打的包,一般只是包括一些编译后class文件和一些部署文件,在声…

    2022年5月24日
    43
  • pmp证书(职称证书丢失补办流程)

    前言OpenSSL中的概念很多,网上的文档也非常的多,在这里做一下总结,首先明确以下内容。Https访问完整流程1)客户端发起一个https请求,连接到服务器的443端口。2)服务端把自己的信息以数字证书的形式返回给客户端(证书内容有密钥公钥,网站地址,证书颁发机构,失效日期等)。证书中有一个公钥来加密信息,私钥由服务器持有。3)验证证书的合法性客户端收到服务器的响应后会先验证证书的合法性(证书中包含的地址与正在访问的地址是否一致,证书是否过期)。4)生成随机密码(RSA签名)如果验

    2022年4月18日
    128
  • c语言实现冒泡排序算法_c语言如何实现动态数组

    c语言实现冒泡排序算法_c语言如何实现动态数组冒泡排序作为学习排序最基本的算法,具有稳定性与实用性。下面是C语言冒泡排序的源代码#include<stdio.h>intmain(void){inta[10]={6,4,3,2,7,8,9,10,1,5};inti,k,w;for(i=0;i<9;i++){for(k=0;k<9-i;k++){if(a[k]>a[k+1]){…

    2025年6月7日
    4
  • linux 权限详解rwx[通俗易懂]

    linux 权限详解rwx[通俗易懂]第2~10个字符当中的每3个为一组,左边三个字符表示所有者权限,中间3个字符表示与所有者同一组的用户的权限,右边3个字符是其他用户的权限。这三个一组共9个字符,代表的意义如下:r(Read,读取):对文件而言,具有读取文件内容的权限;对目录来说,具有浏览目录的权限。w(Write,写入):对文件而言,具有新增、修改文件内容的权限;对目录来说,具有删除、移动目录内文件的权限。x(eXec

    2022年6月1日
    94
  • mysql中OPTIMIZE TABLE的作用

    mysql中OPTIMIZE TABLE的作用

    2021年9月18日
    53

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号