首頁 >資料庫 >Redis >Redis字串類型的幾種應用

Redis字串類型的幾種應用

齐天大圣
齐天大圣原創
2020-05-11 10:00:431434瀏覽

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, [&#39;nx&#39;, &#39;ex&#39;=>$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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn