**phpGrace 緩存機制說明**
在項目開發過程中我們經常會利用緩存來緩解數據查詢、復雜運算帶來的服務器壓力以應對高并發!
phpGrace 封裝了簡潔高效的緩存方案,支持文件、memcache、redis三種形式的緩存方式。
**設置緩存類型及相關配置 /phpGrace/config.php(全局配置)**
~~~
<?php
return?array(
????......
????//支持的緩存類型
????'allowCacheType'?????=>?array('file',?'memcache',?'redis'),
????//緩存設置
????'cache'?????????????=>?array(
????????'type'??????????=>?'memcache',?//支持類型?:?file?[文件型],?memcache?,?redis
????????//以下配置為?memcache?及?redis?類型緩存的必須設置
????????'host'??????????=>?'127.0.0.1',?//主機地址
????????'port'??????????=>?'11211',?????//端口?memcache?一般端口為?11211,?redis?一般為?6379
????????'pre'???????????=>?'grace_'?????//緩存變量前綴
????)
);
~~~
統一規則的緩存操作方法【**控制器成員方法**】:
**cache($name, $id = null, $queryMethod, $timer =3600, $isSuper = true)?**
php 控制器內置了統一的緩存處理函數 cache,此方法會動態的判斷緩存的有效性,并根據實際情況去調用數據查詢、運算等方法。
參數:
~~~
1、緩存名稱
2、影響id?【可以是字符串的組合】
3、數據車查詢函數
4、有效期【可選參數,默認?3600秒】
5、是否為全局緩存【可選參數,默認?是】
???【是】緩存名稱格式:緩存前綴+緩存名稱+影響id
???【否】緩存名稱格式:緩存前綴+控制器名稱+方法名稱+緩存名稱+影響id
~~~
**調用:**
在控制器內容直接使用 cache 函數即可:
~~~
$this->cache('test',?'1002abc',?'__查詢函數名稱');
~~~
**刪除指定的緩存?removeCache($name, $id = null, $isSuper = true)
**參數:
~~~
1、緩存名稱
2、影響id
3、是否全局
~~~
**清空緩存?clearCache**
使用?clearCache 函數可以快速的情況所有緩存
**開發環境下一句代碼關閉全部緩存**
在入口頁面添加以下代碼即可關閉所有緩存!
~~~
define('PG_CLOSE_CACHE',?true);
~~~
為什么要這樣??
您可以預先寫好緩存代碼,數據在開發時是實時的,當開發完成、測試完畢刪除這行代碼,服務器端就可以完美運行在緩存環境下了 ^\_^
- 序言
- 環境需求
- 目錄結構&命名規則
- 初始化
- 第一章 控制器與路由
- 1.1 創建控制器
- 1.2 基礎控制器
- 1.3 url 解析規則
- 第二章 數據與模型
- 1.1 數據庫配置
- 1.2 獲取數據庫操作對象
- 1.3 數據庫操作(CRUD)
- 1.4 數據分頁詳解
- 1.5 phpGrace事務處理
- 1.6 數據驗證
- 1.7 表單令牌
- 1.8 全局模型創建與調用
- 第三章 視圖
- 1.1 創建視圖文件
- 1.2 視圖調用及引用
- 1.3 視圖文件路徑模式
- 第四章 會話機制
- 1.1 cookie 操作
- 1.2 文件型 SESSION
- 1.3 memcache形式的 SESSION
- 1.4 redis 形式的 SESSION
- 第五章 緩存機制
- 1.1 緩存的概述和配置
- 1.2 文件型緩存
- 1.3 memcache 形式的緩存
- 1.4 redis 形式的緩存
- 第六章 配置、常量、語言
- 1.1 全局配置、分組配置
- 1.2 預定義常量
- 1.2 語言包使用說明
- 第七章 工具大全
- 1.1 函數小工具
- 1.2 函數工具庫
- 第八章 安全與擴展
- 1.1 框架部署安全
- 1.2 phpGrace 安全概述
- 1.3 phpGrace 擴展說明
- 實戰項目(內容管理系統)
- 前端實戰graceui
- 項目API接口實戰