认识:ThinkPHP的编译缓存文件~runtime.php

1.定义单入口文件(index.php)

在单入口index.php中不定义这两项时,会生成编译缓存文件~runtime.php

define(‘RUNTIME_PATH‘,‘./App/Temp/‘);    //定义编译目录
define(‘APP_DEBUG‘,TRUE);           //开启调试模式

上述两行不能在index.php中作用,则index.php变为

1 <?php
2      define(‘APP_NAME‘,‘App‘);    //项目名称
3      define(‘APP_PATH‘,‘./App/‘);    //项目路径
4      include ‘./ThinkPHP/ThinkPHP.php‘;    //引入ThinkPHP核心运行文件
5 ?>

2.生成编译缓存文件(~runtime.php)

技术分享

3.复制~runtime.php中的全部内容到index.php中,运行效果会和之前一样。

技术分享

~runtime.php中缓存的编译内容,相当于把index.php引导的所有操作全部集成到~runtime.php文件中。

有了这个缓存的编译文件,index.php在下次运行时,不再引导,而是直接检测是否存在~runtime.php编译缓存文件,如果在,则直接运行~runtime.php。

 

 

其他详解(来自此处

项目编译机制是指系统第一次运行的时候会自动生成核心缓存文件~runtime.php和项目编译缓存文件~app.php。
这些编译缓存文件把核心和项目必须的文件打包到一个文件中,并且去掉所有空白和注释代码,因为存在一个预编译的过程,所以还会进行一些相关的目录检测,对于不存在的目录可以自动生成,这个自动生成机制后面还会提到。
当第二次执行的时候就会直接载入编译过的缓存文件,从而省去很多IO开销,加快执行速度。项目编译机制对运行没有任何影响,预编译操作和其他的目录检测机制只会执行一次,因此无论在预编译过程中做了多少复杂的操作,对后面的执行没有任何效率的缺失。
~runtime.php包含的文件由系统的core.php文件决定,如果是采用了模式扩展的话,就由模式扩展入口文件决定。默认的核心模式下面包含了下面的一些文件:系统定义文件defines.php、系统函数库functions.php、系统基类Think、异常基类ThinkException、日志类 Log、应用类 App、控制器基类 Action、视图类 View。
其他类库可以在操作方法中使用系统导入机制或者自动加载机制完成加载。
~app.php 通常包含了下面的一些文件:项目配置文件(由惯例配置、项目配置合并而成)、项目公共函数文件common.php。每个项目还可以单独添加自己的项目编译文件列表,只需要在项目配置目录下面定义app.php文件,返回需要额外添加到项目编译缓存的文件列表数组即可。

【入口文件index.php中设置】
编译缓存文件,默认是自动生成在项目目录下面的Runtime目录下面。、
define(‘RUNTIME_PATH‘,‘./MyApp/temp/‘); //如果希望自己设置目录,可以在入口文件里面设置RUNTIME_PATH进行更改
注意在Linux环境下面需要对RUNTIME_PATH目录设置可写权限。

注意在调试模式下面不会生成项目编译缓存,但是依然会生成核心缓存
define(‘NO_CACHE_RUNTIME‘,True); //不希望生成核心缓存文件的话
define(‘STRIP_RUNTIME_SPACE‘,false); //设置对编译缓存的内容是否进行去空白和注释
则生成的编译缓存文件是没有经过去注释和空白的,仅仅是把文件合并到一起,这样的好处是便于调试的错误定位,建议部署模式的时候把上面的设置为True或者删除该定义。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。