一、概念
redis是一個key-value儲存系統。和Memcached類似,它支援儲存的value類型相對更多,包括string(字串)、list(鍊錶)、set(集合)、zset(有序集合)和hash(哈希類型)。這些資料類型都支援push/pop、add/remove及取交集並集和差集及更豐富的操作,而且這些操作都是原子性的。
redis支援各種不同方式的排序。與memcached一樣,為了確保效率,資料都是快取在記憶體中。區別的是redis會週期性的把更新的資料寫入磁碟或把修改操作寫入追加的記錄文件,並且在此基礎上實現了master-slave(主從)同步。
1、安裝:Linux系統可以透過官網位址:http://redis.io/download下載原始碼包進行編譯安裝
2、啟動Redis服務指令:
(1)redis-server
(2)service redisd start
3、Redis的常用指令使用:
(1)連線:redis- cli -h 4d16d28254bb6204b508678696e23d67 -p 6a311cfe3deb63d6a24aa0d16573ed7e -a 63a4ba0522130d078aae98b8ca9ec042
(2)測試是否可用:輸入PING,回傳PONG回應
(3)可透過「SET key value」來設定key和value值;
(4)透過「GET KEY」取得Key對應的Value值。
1、PHP自帶了Redis類,用於作為操作Redis的擴展,因此可以透過該類別進行連線:
$redis = new Redis();
$redis->connect('f7e6dec31ab1a0471d06c55afaca8d77',22c02222df6596cdb70150289ecf0ad9);
$redis->auth('b6c2e8ec22fb2036f3eb34924f1fc200');
2、通常情況下,由於Redis支援string,hash,list,set及zset五種資料類型,Redis在開發中時常被用作快取和佇列兩種服務:
(1)Redis用作快取的PHP範例:
$redis->set(<key>,<value>); //设置key和value的键值对 $redis->get(<key>);//获取Key对应的Value值 (2)Redis用作锁的操作: $redis->setnx(<key>,<value>); //设置key和value的键值对,如果key的value已经存在则不操作 $redis->get(<key>);//获取Key对应的Value值 (3)Redis用作队列的PHP示例: $redis->lpush(<key>,<value>);//从列表头部插入数据,列表名为key $redis->lpop(<key>);//从列表尾部去除并移除数据,列表名为key
除了上述的常用操作之外,PHP還支援Redis使用的各種資料類型操作,如mset、hset等。
1、Redis是一個速度非常快的非關聯式資料庫,它可以儲存鍵(key)與5種不同類型的值(value)之間的映射(mapping),可以將儲存在記憶體的鍵值對資料持久化到硬碟,可以使用複製特性來擴展讀取性能,還可以使用客戶端分片來擴展寫入性能;
2、當數據依賴不再需要,Redis這種基於記憶體的性質,與在執行一個事務時將每個變化都寫入硬碟的資料庫系統相比就顯得執行效率非常高,寫與讀取操作速度沒有明顯差別;
3、與其他資料儲存方式的比較:
#4、使用Redis的優點:
(1)有memcached使用經驗的讀者可能知道,使用者只能用APPEND指令將資料加入到已有字串的結尾。 memcached的文檔中聲明,可以用APPEND指令來管理元素列表。這很好!使用者可以將元素追加到字串的結尾,並將那個字串當作列表來使用。但隨後如何刪除這些元素呢? memcached採用的辦法是採用黑名單(blacklist)來隱藏清單裡面的元素,從而避免對元素執行讀取、更新、寫入(或資料庫請求和memcached寫入)等操作。相反地,Redis的LIST和SET允許使用者直接添加或刪除元素。
(2)使用Redis代替memcached可以解決這個問題以及其他問題,不僅可以讓程式碼變得更簡短、更易懂、更易維護,而且還可以使程式碼的運行速度更快(因為使用者不需要透過讀取資料庫來更新資料)。除此之外,在其他許多情況下,Redis的效率和易用性也比關聯式資料庫好得多。
相關推薦:
以上是PHP操作Redis實例講解的詳細內容。更多資訊請關注PHP中文網其他相關文章!