## PHP四大加速缓存器opcache,apc,xcache,eAccelerator
eAccelerator,xcache,**opcache**(5.5默认 linux下安装php时记得加上 --enable-opcache ),apc(偏数据库缓存,分系统和用户缓存,不推荐5.5将弃之?)是PHP缓存扩展,
memcached缓存是数据库缓存扩展(APC比较偏向数据库缓存的),一般两者只有要安装其中一个即可
注意:([详情连接](https://www.chenweiliang.com/cwl-940.html))
实际测试中发现当Cache数量超过一定阀值的时候,APC的性能不如Memcache
opcache的性能优于其他几个缓存器
**一般会选择opcache+memcached|redis这个组合**
如果储存的量不大,tp 的file 缓存,和redis |memcached差不多。但是内存读取肯定要快。如果存储的值多,redis |memcached强大的i/o能力会强于 普通的文件读写
# [使用 OpCache 提升 PHP 5.5+ 程序性能](https://www.cnblogs.com/chunguang/p/5538093.html)(从编译提高)
作用是将PHP代码预编译生成的脚本文件 `Opcode` 缓存在共享内存中供以后反复使用,从而避免了从磁盘读取代码再次编译的时间消耗 省去了每次加载和解析 PHP 脚本的开销。同时,它还应用了一些代码优化模式,使得代码执行更快。从而加速PHP的执行(避免重复编译,减少 CPU 和内存开销)
![](https://img.kancloud.cn/fa/2a/fa2ab11242283efeb687203e1c282897_815x297.png)
php.ini 打开 zend\_extension="D:\\phpStudy\\php\\php-7.2.14\\ext\\php\_opcache.dll"
```
[opcache]
zend_extension = php_opcache.dll
opcache.enable = 0
opcache.memory_consumption = 128
opcache.max_accelerated_files = 10000
opcache.revalidate_freq = 60
; Required for Moodle
opcache.use_cwd = 1
opcache.validate_timestamps = 1
opcache.save_comments = 1
opcache.enable_file_override = 0
```
>[danger] 不要在编写调试代码中开启opcache,否则你会体会到你的增删改查不能即时同步的痛苦!
thinkphp的缓存:
~~~
'TMPL_CACHE_ON' => true, // 是否开启模板编译缓存,设为false则每次都会重新编译
'TMPL_CACHE_TIME' => 0, // 模板缓存有效期 0 为永久,(以数字为值,单位:秒)
'DB_FIELDS_CACHE' => true, // 启用字段缓存
'DATA_CACHE_TIME' => 0, // 数据缓存有效期 0表示永久缓存
'DATA_CACHE_TYPE' => 'File', // 数据缓存类型,支持:File|Db|Apc|Memcache|Shmop|Sqlite|Xcache|Apachenote|Eaccelerator
~~~
[静态文件缓存 和S函数动态数据缓存](https://www.cnblogs.com/dee0912/p/5223923.html)(从数据层面提高)
[thinkphp的静态缓存,数据缓存,快速缓存,查询缓存](https://www.cnblogs.com/chinalorin/p/5855386.html)
*****
### [**详细用法**](https://beltxman.com/archives/1835.html)
配置文件在目录:application-Common-Conf-config.php里设置默认配置项
静态文件缓存配置格式 静态规则是用于定义要生成的静态文件的名称 建议配置在application/module/Config/config.php
~~~
// 静态缓存配置
'HTML_CACHE_ON' => true, // 开启静态缓存
'HTML_CACHE_TIME' => 3600, // 全局静态缓存有效期(秒)
'HTML_PATH' => APP_PATH . 'Html/', //设置已经生成的静态页保存路径(默认HTML_PATH 即./Application/Html/)
'HTML_FILE_SUFFIX' => '.html', // 设置静态缓存文件后缀
'HTML_CACHE_RULES' => array( // 定义静态缓存规则
//静态规则是用于定义要生成的静态文件的名称
// 对商品进行缓存
// 'Product:plist' => 'Product/plist_{id}_{pid}',
// 对单个操作进行缓存
// 'Index:index' => 'Index/index',
// 对Index控制器的所有操作缓存
'Index:' => 'Index/{:action}_{id}',
// 对Download控制器的所有操作缓存
'Download:' => 'Download/{:action}_{id}',
// 对Product控制器的所有操作缓存并设置缓存过期时间为7200秒
'Product:' => array('Product/{:action}_{id}', '7200'),
'projectorSelect'=>array('{:module}/{:controller}_{:action}',86400),
'*'=>array('{$_SERVER.REQUEST_URI|md5}'),
),
~~~
启用静态文件后每次都会检查访问的url(访问的url定义了静态规则)是否生成了静态文件则访问静态文件否则访问view模板文件在生成
格式:
~~~
静态地址分四种:
Return Array(
'静态地址'=>array('静态规则','有效期',附加规则),
'ActionName'=>array('静态规则','静态缓存有效期','附加规则'), //第一种 定义所有的read操作的静态规则'read'=>array('{id}',60)
'ControllerName:'=>array('静态规则','静态缓存有效期','附加规则'),//第二种 定义全局的控制器静态规则,例如定义所有的User控制器的静态规则 'user:'=>array('User/{:action}_{id}','600')
'ControllerName:ActionName'=>array('静态规则','静态缓存有效期','附加规则'),//第三种 定义某个控制器的操作的静态规则,例如,我们需要定义Blog控制器的read操作进行静态缓存 'blog:read'=>array('{id}',0)
'*'=>array('静态规则','静态缓存有效期','附加规则'),//第四种 定义全局的静态缓存规则,这个属于特殊情况下的使用,任何模块的操作都适用 例如:'*'=>array('{$_SERVER.REQUEST_URI|md5}'), 表示根据当前的URL进行缓存。
…更多操作的静态规则
)
~~~
格式的例子:[详情参考文档](http://document.thinkphp.cn/manual_3_2.html#html_cache)
~~~
'read'=>array('{id}',60) #定义所有的read操作(方法)的静态规则 其中,{id} 表示取$_GET['id'] 为静态缓存文件名,第二个参数表示缓存60秒
'user:'=>array('User/{:action}_{id}','600')#定义所有的User控制器的静态规则(全局的控制器静态规则) {:action} 表示当前的操作名称
'blog:read'=>array('{id}',0)#定义Blog控制器的read操作进行静态缓存
'read'=>array('Think{id},{name}','60', 'md5') #即md5('Think'.$_GET['id']. ', '.$_GET['name']);
'empty:index'=>array('{module}_{:action}',0);#定义空控制器的静态规则
'User:index'=>array('User/{:action}',0);#定义空操作的静态规则
'*'=>array('{$_SERVER.REQUEST_URL|md5}')#全局静态规则任何控制器和方法都适用
~~~
静态文件动态生成的方法: [方法](https://baijiahao.baidu.com/s?id=1611993886976390068&wfr=spider&for=pc)
**$this->buildHtml('静态文件', '静态路径','模板文件');**
**参数一:静态文件**,是指生成后的静态文件名,文件保存路径完整的就是:静态路径/静态文件。例如静态文件设置a/index.那么保存的路径就是项
目路径/Html/a/index.html(默认的静态路径在项目路径的Html文件夹下,没有可以自己创建)
**参数二:静态路径**,上面已经说明了默认的路径,3.0中可以在入口文件里加入参数来更改静态路径。
define('HTML\_PATH', './');(将静态路径义为网站根目录)
**参数三:模板文件**,我感觉官方这个描述是不正确的,准确的来说应该是目标模块,就是需要生成静态文件的模块。格式:模块名:操作。比如要生成Index下的a方法为静态文件,那就是Index:a。如果为空则默认生成当前操作的静态文件。
下面三个是等效的??:
$this->buildHtml("index",'',"");
$this->buildHtml("index",'',"Index:index");
$this->buildHtml("index",'',"index");
- 目录结构与基础
- 修改数据后页面无变化
- 防跨目录设置
- input
- 系统目录
- 自动生成的文件以及目录
- 类自动加载
- url生成
- 数据增删改查
- 增加数据
- 数据更新
- 数据删除
- 数据查询
- 架构
- 生命周期
- 入口文件
- URL访问规则
- 配置
- 默认惯例配置配置
- 初始应用配置
- 路由
- 域名路由
- URL生成
- 数据库操作
- 方法列表
- 连接数据库
- 分布式数据库
- 查询构造器
- 查询数据
- 添加数据
- 更新数据
- 删除数据
- 查询语法
- 聚合查询(统计)
- 时间查询
- 高级查询
- 视图查询
- 子查询
- 辅助查询之链式操作
- where
- table
- alias
- field
- order
- limit
- page
- group
- having
- join
- union
- distinct
- lock
- cache
- comment
- fetchSql
- force
- bind
- partition
- strict
- failException
- sequence(pgsql专用)
- 查询事件
- 事务操作
- 监听SQL
- 存储过程
- 数据集
- 控制器
- 跳转和重定向
- 空控制器和空操作
- 分层控制器
- Rest控制器
- 资源控制器
- 自动定位控制器
- tp3的增删改查
- 方法注入
- 模型
- 属性方法一览
- 类方法详解
- Model
- 调用model不存在的属性
- 调用model中不存在的方法
- 调用model中不存在的静态方法
- hasOne
- belongsTo
- hasMany {Relation}
- belongsToMany
- hasManyThrough
- morphMany
- morphOne
- morphTo
- ::hasWhere {Query}
- ::has
- relationCount
- data 【model】
- setInc {integer|true}
- setDec {integer|true}
- save {integer | false}
- saveAll {array}
- delete {integer}
- ::get 查询单条数据 {Model}
- ::all 查询多条数据{Model [ ]}
- ::create 新增单条数据 {Model}
- ::update 更新单条数据 {Model}
- ::destroy {integer}
- ::scope {Query}
- getAttr {mixed}
- xxx
- append
- appendRelationAttr
- hidden
- visible
- except
- readonly
- auto
- together
- allowField
- isUpdate
- validate
- toCollection
- toJson
- toArray
- 定义
- 新增
- 更新
- 查询
- 删除
- 聚合
- 获取器
- 修改器
- 时间戳
- 只读字段
- 软删除
- 类型转换
- 数据完成
- 查询范围
- 模型分层
- 数组访问和转换
- JSON序列化
- 事件
- 关联
- 一对一关联
- 主表一对一关联
- 从表一对一关联(相对关联)
- 一对多关联
- 主表定义一对多关联
- 从表定义一对多关联
- 远程一对多
- 多对多关联
- 多态关联
- 动态属性
- 关联预载入with()
- 关联统计
- N+1查询
- 聚合模型
- Model方法集合
- 表单验证
- 验证器
- 验证规则
- 错误信息
- 验证场景
- 控制器验证
- 模型验证
- 内置规则
- 静态调用
- 表单令牌
- Token身份令牌
- 视图
- 模版
- 变量输出
- 函数输出
- Request请求参数
- 模板注释及原样输出
- 三元运算
- 内置标签
- 模板继承
- 模板布局
- 日志
- 日志初始化
- 日志驱动
- 日志写入
- 独立日志
- 日志清空
- 写入授权
- 自定义日志
- 错误和调试
- 异常
- php系统异常及thinkphp5异常机制
- 异常处理
- 抛出异常
- 异常封装
- resful
- 404页面
- 调试模式
- Trace调试
- SQL调试
- 变量调试
- 性能调试
- 远程调试
- 安全
- 输入安全
- 数据库安全
- 上传安全
- 其它安全建议
- xss过滤
- 扩展
- 函数
- 类库
- 行为
- 驱动
- Composer包
- Time
- 数据库迁移工具
- Workerman
- MongoDb
- htmlpurifier XSS过滤
- 新浪SAE
- oauth2.0
- 命令行及生成文件
- 系统现成命令
- 创建类库文件
- 生成类库映射文件
- 生成路由缓存
- 清除缓存文件
- 生成配置缓存文件
- 生成数据表字段缓存
- 自定义命令行
- 开始
- 调用命令
- 杂项
- 助手函数
- URL重写
- 缓存
- 缓存总结
- Session
- Cookie
- 多语言
- 分页
- 上传
- 验证码
- 图像处理
- 文件处理
- 单元测试
- 自定义表单令牌