這篇文章主要介紹了PHP資料庫操作memcache用法,結合實例形式詳細分析了memcache的下載、安裝、配置及相關使用技巧,需要的朋友可以參考下
#具體如下:
在一個高並發的web應用中,資料庫存取瓶頸一直是個大問題,一旦達到某個極限,資料庫很容易崩潰,但是如果我們把常用的資料放到記憶體中,在需要的時候從記憶體中取,不光讀取速度快,而且節省資料庫IO。
memcache簡介
Memcache是一個高效能的分散式的記憶體物件快取系統,透過在記憶體裡維護一個統一的巨大的hash表,它能夠用來儲存各種格式的數據,包括圖像、影片、文件以及資料庫檢索的結果等。簡單的說就是將資料呼叫到記憶體中,然後從記憶體中讀取,從而大大提高讀取速度。
memcache的mem是記憶體(memory),cache是緩存,結合是記憶體快取的意思。當我們應用memcache時,讀取資料先從memcache內讀取,若查找不到再去資料庫裡查找,並將資料存入memcache,待下次查找時便能輕易找到。
要注意:
memcache是記憶體型的資料庫,因為記憶體的關閉釋放的特性,memcache也無法持久化儲存內容;
memcache內部是分塊存儲,所以大於1M的資料也無法儲存。
memcache依賴libevent函式庫,安裝前需確認已經安裝了libevent函式庫。
memcache是個輕量級的記憶體資料庫,只支援key-value型的儲存。
memcache中沒有關於用戶,密碼的設置,所以在配置時要配置防火牆的連接埠限制連接,以達到安全的目的。
使用repcached也能輕易實作memcache的單master單slave主從複製。
memcache的應用程式場景
儲存大量不需要持久性儲存或資料庫內已存在不會變動的資料。
讀取數據非常頻繁數據,要求小於1M。
資料型別簡單的key-value型資料。
計算好的結果和渲染後的網頁範本檔。
因其原子遞增性,可以用來計數。
因為可以設定資料過期時間的特性,儲存期限資料。不過要注意,memcache會在分配的內存不足時以最近最少使用原則(LRU)重用內存,可能會導致資訊提前被刪除。
用memcache儲存session訊息,以達到多伺服器session共享。需要設定:php.ini:
session.save_handler = memcache //设置session的储存方式为memcache memcache.hash_strategy = "consistent"//设置memcache的hash算法为一致性哈希算法。 session.save_path = "tcp:/ip:port" //设置session储存的位置,多台memcache用逗号隔开。
#memcache伺服器的安裝
memcache的安裝簡單,伺服器可以在其官網http://www.memcached.org/下載,解壓縮後在其目錄下運行./configure -prefix=/path編譯,然後make / make test / make install 得到可以直接執行的二進位。 使用./memcached指令即可開啟伺服器,其常用參數如下:
-p port 監聽埠(預設: 11211)-d 以後台方式執行Memcached
-u username 運行Memcached的帳戶-m n 最大的記憶體使用, 單位是MB,預設64 MB
-c connections 最大連線數量, 預設是1024#memcache的常用指令
用memcache客戶端或telnet連線到memcache後,就可以對memcache進行操作了。
memcache資料結構簡單,所以命令列指令也很少,下面以一個常用指令來簡析一下指令格式:
add key flags expire_time length \r\n value
flags:是否壓縮/序列化,通常為0。 expire_time:從儲存後多久過期。以秒(s)為單位,最大為30天的長度,超過30天的長度被視為時間戳表示"到什麼時候過期",若設為0表示永不過期。
length:value長度,輸入長度回車之後,指令列會讀取你接下來輸入的length個字元。
set key flags expire_time length //如果有值则覆盖原值,没有则新增,add在有值时会存储失败 get key //获取key的值 replace key flags expire_time length// 替换一个已存在的key append/preappend key flags expire_time length// 给key的value后面/前面添加新内容。 preappend key flags expire_time length // 给key的value前面添加新内容。 inc/dec key [n] //key的值递增/递减1/[n] delete key //删除一个key flush_all [n] //[在n秒后]删除全部数据 stats [options] //获取memcache[有关某一项]的详细信息#########PHP的memcache擴充及應用############在https://pecl. php.net/index.php搜尋取得到所需的memcache擴充包。 ######linux系統,直接挑選版本(推薦最新stable穩定版)下載,解壓縮後在解壓縮目錄下用phpize工具產生configure文件,並用它安裝,安裝完成後在/php.ini添加extension。具體可參考前文:http://www.jb51.net/article/121314.htm。 ######windows下要點擊鏈接右邊的“windows logo DLL”鏈接,並在新打開的頁面中,按照版本、32位/64位、線程安全/非線程安全來選擇自己所需要的擴展,具體選項可以在phpinfo();頁面看到。下載完成後,將其放入phppath/ext/目錄下,然後在php.ini中新增extension=php_memcacache.dll;重新啟動伺服器完成安裝。 ###
在phpinfo()页面中看到memcache扩展后,说明安装成功,我们就可以在php脚本中使用关于memcache的类函数库了。
在手册中我们可以找到许多关于php的memcache扩展的使用,以下是一个典型的memcache使用流程。
$m=new Memcache(); $m->connect($host,$port); $m->add($key,$value[,flags,$expire_time]); $content=$m->get($key); $m->close();
这是一个简单的memcache连接程序,在进行memcache分布式存储时,还需要用到$memcache->addServer()
向memcache集群中添加服务器。
相关推荐:
ThinkPHP框架中使用Memcached缓存数据步骤详解
以上是PHP資料庫中memcache的用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!