Redis的字串資料類型,是最簡單的一種資料類型,但它也是學好其他redis的資料類型的基礎。以下介紹幾種redis的應用。
限流
使用redis可以做到限流的作用。 redis本身效能極高,可以用它來抵擋部分請求。
防禦大流量
現在網站攻擊日漸猖獗,靜態的資源可以用cdn,但動態的程式如何防禦。下面,展示一個redis來防禦大量請求的解決方案。
基本想法是限制一個ip一定時間內請求數,例如一個ip一秒的請求數不能超過10次。
偽代碼如下:
function ip_limit($cnt = 10) { $ip = $_SERVER['SERVER_ADDR']; $key = "limit:$ip:cnt"; $isExisit = $redis->set($key, 1, ['nx', 'ex'=>1]); if (!$isExisit || $redis->incr($key) <= $cnt) { // 通过 return true; } else { // 不通过 return false; } }
取得驗證碼頻率限制
簡訊驗證碼現在已經成為了web應用的標配的,許多的地方都會需要簡訊驗證碼。如:註冊時、修改密碼時、一些對安全要求比較高的操作。當然,驗證碼取得不是免費的,所以,我們不希望用戶無限制的取得驗證碼。
也是相同的思路,我們可以寫一個獲取簡訊驗證碼頻率的限制應用程式。
完成一個一分鐘內,只準取得一次驗證碼的應用,偽代碼如下:
function code_limit($mobile, $time = 60) { $key = "limit:$mobile:cnt"; $isExisit = $redis->set($key, 1, ['nx', 'ex'=>$time]); if (!$isExisit) { // 通过 return true; } else { // 不通过 return false; } }
存放session
使用redis存放session,是現在推薦的方式,他的好處是性能高,到期自動銷魂。 (PHP自身的session垃圾回收機制不是可靠的,過期銷魂是有機率的)。
該方式非常簡單,只需在修改php.ini檔案即可。
找到session.save_handler這行,修改為
session.save_handler = redis
將session.save_path修改為
session.save_path = "tcp://localhost:6379"
如何redis設定了密碼的話,只需修改為
session.save_path = "tcp://localhost:6379?auth=password"
如果不是單機應用,而是分散式的話,怎麼樣用redis來集中管理session呢?
也很簡單。也是只要修改php.ini檔案即可。如session集中管理在192.168.1.220這個機器上,其他機器的php.ini檔案修改如下:
session.save_handler = redis session.save_path = "tcp://192.168.1.220:6379?auth=password"
上面只是介紹了一些redis字串類型了應用,開發者們可以結合實踐專案和自己的想像力,創造出更多的應用
以上是Redis字串類型的幾種應用的詳細內容。更多資訊請關注PHP中文網其他相關文章!