


Analysis on ThinkPHP's implementation of static caching and dynamic caching
This article mainly introduces the example code of ThinkPHP to implement static caching and dynamic caching, which has certain reference value. Interested friends can refer to it
Static Cache
To use the static caching function, you need to enable the HTML_CACHE_ON parameter and set the static caching rule file using the HTML_CACHE_RULES configuration parameter.
Define static rules
'HTML_CACHE_ON' => true, // 开启静态缓存 'HTML_CACHE_TIME' => 60, // 全局静态缓存有效期(秒) 'HTML_FILE_SUFFIX' => '.shtml', // 设置静态缓存文件后缀 'HTML_CACHE_RULES' => array( // 定义静态缓存规则 // 定义格式1 数组方式 '静态地址' => array('静态规则', '有效期', '附加规则'), // 定义格式2 字符串方式 '静态地址' => '静态规则', )
The root directory of the static cache file is under the path defined by HTML_PATH, and only operations that define static rules will be statically cached. And static cache supports different storage types. Static caching only works under GET requests.
Static address
Global operation static rules
'read'=>array('{id}',60)//定义所有的read操作的静态规则
Definition of global controller static rules
'user:'=>array('User/{:action}_{id}','600')//定义所有的User控制器的静态规则
Definition Static rules for the operation of a certain controller //Define the read operation of the Blog controller for static caching
'blog:read'=>array('{id}',0)//参数为0表示永久缓存
Define global static caching rules
'*'=>array('{$_SERVER.REQUEST_URI|md5}')//这个属于特殊情况下的使用,任何模块的操作都适用
Static rules
Static rules are used to define the names of static files to be generated. The definition of static rules must ensure that there will be no conflicts.
Use system variables
{$_×××|function}//_GET、_REQUEST、_SERVER、_SESSION、_COOKIE {$_GET.name} {$_SERVER.REQUEST_URI|md5}
Use framework-defined variables
{:module}/{:controller}_{:action}//{:module} 、{:controller} 和{:action}分别表示当前模块名、控制器名和操作名。
Use _GET variables
{var|function}//{id}其实等效于 {$_GET.id}
Use functions directly
{|function}//{|time},time函数获取时间后作为文件名称
Mixed definition
'{id},{name|md5}' //在{}之外的字符作为字符串对待,如果包含有"/",会自动创建目录。 {:module}/{:action}_{id}//会在静态目录下面创建模块名称的子目录,然后写入操作名_id.shtml 文件。
Dynamic cache
[S method data cache]
Cache initialization
S(array('type'=>'xcache','expire'=>60));
The system is currently Supported cache types include: Apachenote, Apc, Db, Eaccelerator, File, Memcache, Redis, Shmop, Sqlite, Wincache and Xcache. If the S method does not pass in the type parameter for initialization, the DATA_CACHE_TYPE parameter value set in the configuration file is read as the default type. In the same way, if the prefix parameter is not passed in, the DATA_CACHE_PREFIX parameter value of the configuration file will be read. If the expire parameter is not passed in, the DATA_CACHE_TIME configuration value will be read as the default.
For global caching, we generally recommend adding the prefix (cache prefix) parameter to distinguish different applications to avoid confusion.
Set up the cache
The data cache can support cache queues. Simply put, you can limit the number of caches. You only need to specify the length parameter during initialization.
S('name',$value); S('name',$value,300);//缓存数据300秒 S('name',$value,array('type'=>'file','expire'=>300));//改变之前的缓存方式或者更多的参数 S(array('type'=>'xcache','length'=>100,'expire'=>60));//系统只会缓存最近的100条缓存数据。
Read cache
$value = S('name');//如果缓存标识不存在或者已经过期,则返回false,否则返回缓存值。
Delete cache
S('name',null);
Note: When using each cache, ThinkPHP needs to load the corresponding driver file and set the corresponding configuration.
Usage Example
$user = M('User'); $value = S('list'); if (empty($value)) { $list = $user->select(); S('list', $list, 3600); echo '这个是直接从数据库中读取的文件'; dump($list); } else { echo '这个是缓存文件'; dump($value); }
[Quick Cache]
The system also provides a fast cache method F for faster operations, however, The F method has no validity period. The F method can support different storage types. If it is a file type, it is saved under the DATA_PATH directory by default.
Fast cache Data
F('data',$Data); F('data',$Data,TEMP_PATH);//快速缓存Data数据,保存到指定的目录 F('User/data',$Data);//F方法支持自动创建缓存子目录,在DATA_PATH目录下面缓存data数据,如果User子目录不存在,则自动创建。
Get cached data
$Data = F('data');
Delete cached data
F('data',NULL);
[Query cache]
The query cache function supports all databases, and supports all caching methods and validity periods.
When using query cache, you only need to call the cache method of the Model class.
$Model->cache(true)->where('status=1')->select();
If cache(true) is used, a query cache with a unique identifier will be generated based on the current query conditions and other information during the query. If a key is specified, the name of the key will be generated directly. query cache.
$Model->cache('cache_name')->select();
By default, the cache method uses the cache method set by the DATA_CACHE_TYPE parameter (the system default value is File, which means file cache is used). The cache validity period is the time set by the DATA_CACHE_TIME parameter. The cache method of the query cache can also be specified separately. and validity period.
$Model->cache(true,60,'xcache')->select();
If the key of the query cache is specified, the content of the query cache can be directly obtained externally through the S method.
$value = S('cache_name');
In addition to the select method, the query cache also supports the find and getField methods, as well as their derived methods (including statistical query and dynamic query methods).
$Model->where($map)->cache('key',60)->find();
This article mainly comes from the official documentation. If you have any questions, please refer to the ThinkPHP3.2 official documentation-caching
The above is the entire content of this article. I hope it will be helpful to everyone's study. For more related content, please pay attention to the PHP Chinese website!
Related recommendations:
ThinkPHP implements one-click cache clearing method
Summary of several methods of PHP clearing cache
The above is the detailed content of Analysis on ThinkPHP's implementation of static caching and dynamic caching. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

To run the ThinkPHP project, you need to: install Composer; use Composer to create the project; enter the project directory and execute php bin/console serve; visit http://localhost:8000 to view the welcome page.

ThinkPHP has multiple versions designed for different PHP versions. Major versions include 3.2, 5.0, 5.1, and 6.0, while minor versions are used to fix bugs and provide new features. The latest stable version is ThinkPHP 6.0.16. When choosing a version, consider the PHP version, feature requirements, and community support. It is recommended to use the latest stable version for best performance and support.

Steps to run ThinkPHP Framework locally: Download and unzip ThinkPHP Framework to a local directory. Create a virtual host (optional) pointing to the ThinkPHP root directory. Configure database connection parameters. Start the web server. Initialize the ThinkPHP application. Access the ThinkPHP application URL and run it.

Performance comparison of Laravel and ThinkPHP frameworks: ThinkPHP generally performs better than Laravel, focusing on optimization and caching. Laravel performs well, but for complex applications, ThinkPHP may be a better fit.

"Development Suggestions: How to Use the ThinkPHP Framework to Implement Asynchronous Tasks" With the rapid development of Internet technology, Web applications have increasingly higher requirements for handling a large number of concurrent requests and complex business logic. In order to improve system performance and user experience, developers often consider using asynchronous tasks to perform some time-consuming operations, such as sending emails, processing file uploads, generating reports, etc. In the field of PHP, the ThinkPHP framework, as a popular development framework, provides some convenient ways to implement asynchronous tasks.

ThinkPHP installation steps: Prepare PHP, Composer, and MySQL environments. Create projects using Composer. Install the ThinkPHP framework and dependencies. Configure database connection. Generate application code. Launch the application and visit http://localhost:8000.

ThinkPHP is a high-performance PHP framework with advantages such as caching mechanism, code optimization, parallel processing and database optimization. Official performance tests show that it can handle more than 10,000 requests per second and is widely used in large-scale websites and enterprise systems such as JD.com and Ctrip in actual applications.

Development suggestions: How to use the ThinkPHP framework for API development. With the continuous development of the Internet, the importance of API (Application Programming Interface) has become increasingly prominent. API is a bridge for communication between different applications. It can realize data sharing, function calling and other operations, and provides developers with a relatively simple and fast development method. As an excellent PHP development framework, the ThinkPHP framework is efficient, scalable and easy to use.
