1.1.linux下的Memcache安裝: php
用 pecl 命令行工具安裝: html
pecl install memcache
或直接從源碼安裝: linux
phpize ./configure make make install
1.2.Windows下的Memcache安裝: web
memcached的基本設置: 算法
1.3.php.ini中的配置: sql
[Memcache] 數據庫
; 一個高性能的分佈式的內存對象緩存系統,經過在內存裏維護一個統一的巨大的hash表,
; 它可以用來存儲各類格式的數據,包括圖像、視頻、文件以及數據庫檢索的結果等。 windows
; 是否在遇到錯誤時透明地向其餘服務器進行故障轉移。
memcache.allow_failover = On 緩存
; 接受和發送數據時最多嘗試多少個服務器,只在打開memcache.allow_failover時有效。memcache.max_failover_attempts = 20 服務器
; 數據將按照此值設定的塊大小進行轉移。此值越小所需的額外網絡傳輸越多。
; 若是發現沒法解釋的速度下降,能夠嘗試將此值增長到32768。
memcache.chunk_size = 8192
; 鏈接到memcached服務器時使用的默認TCP端口。
memcache.default_port = 11211
; 控制將key映射到server的策略。默認值"standard"表示使用先前版本的老hash策略。
; 設爲"consistent"能夠容許在鏈接池中添加/刪除服務器時沒必要從新計算key與server之間的映射關係。
;memcache.hash_strategy = "standard"; 控制將key映射到server的散列函數。默認值"crc32"使用CRC32算法,而"fnv"則表示使用FNV-1a算法。
; FNV-1a比CRC32速度稍低,可是散列效果更好。
;memcache.hash_function = "crc32"
;memcache也能夠做爲session的存儲模塊,具體參看:memcache PHP 的 session.save_handler.
進入系統後臺,在[系統基本參數]下面的「性能選項」卡當中,關於memcache進行以下配置:
cfg_memcache_enable:是否啓用memcache緩存,若是爲否(N),默認使用文件緩存;
這個選項設置爲開啓:Y
cfg_memcache_mc_defa:默認memcache緩存服務器地址;
這個選項中填入服務器地址:memcache://127.0.0.1:11211/default127
cfg_memcache_mc_oth:附加memcache緩存服務器地址;
這個若是沒有能夠爲空。
cfg_puccache_time : 需緩存內容全局緩存時間(秒),這個裏面須要設定緩存週期,默認爲36000秒
因爲封裝成小助手的形式,因此在使用的時候先初始化:
helper('cache');
幾個簡單的方法:
$rs = GetCache('memberlogin', $mid); if (empty($rs)) { $rs = $dsql -> GetOne("SELECT * FROM `#@__member` WHERE mid='{$mid}' "); SetCache('memberlogin', $mid, $rs, 1800); }