溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP使用Redis的應(yīng)用場(chǎng)景

發(fā)布時(shí)間:2020-05-13 14:55:24 來源:億速云 閱讀:115 作者:Leah 欄目:編程語言

今天小編給大家分享的是PHP使用Redis的應(yīng)用場(chǎng)景的詳細(xì)介紹,相信大部分人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,話不多說,一起往下看吧。

Redis是一個(gè)開源的使用ANSI C語言編寫、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫,并提供多種語言的API。

簡(jiǎn)單字符串緩存實(shí)戰(zhàn)

$redis->connect('127.0.0.1', 6379);
$strCacheKey  = 'Test_bihu';
//SET 應(yīng)用
$arrCacheData = [
    'name' => 'job',
    'sex'  => '男',
    'age'  => '30'
];
$redis->set($strCacheKey, json_encode($arrCacheData));
$redis->expire($strCacheKey, 30);  # 設(shè)置30秒后過期
$json_data = $redis->get($strCacheKey);
$data = json_decode($json_data);
print_r($data->age); //輸出數(shù)據(jù)
//HSET 應(yīng)用
$arrWebSite = [
    'google' => [
        'google.com',
        'google.com.hk'
    ],
];
$redis->hSet($strCacheKey, 'google', json_encode($arrWebSite['google']));
$json_data = $redis->hGet($strCacheKey, 'google');
$data = json_decode($json_data);
print_r($data); //輸出數(shù)據(jù)

簡(jiǎn)單隊(duì)列實(shí)戰(zhàn)

$redis->connect('127.0.0.1', 6379);
$strQueueName  = 'Test_bihu_queue';
//進(jìn)隊(duì)列
$redis->rpush($strQueueName, json_encode(['uid' => 1,'name' => 'Job']));
$redis->rpush($strQueueName, json_encode(['uid' => 2,'name' => 'Tom']));
$redis->rpush($strQueueName, json_encode(['uid' => 3,'name' => 'John']));
echo "---- 進(jìn)隊(duì)列成功 ---- <br /><br />";
//查看隊(duì)列
$strCount = $redis->lrange($strQueueName, 0, -1);
echo "當(dāng)前隊(duì)列數(shù)據(jù)為: <br />";
print_r($strCount);
//出隊(duì)列
$redis->lpop($strQueueName);
echo "<br /><br /> ---- 出隊(duì)列成功 ---- <br /><br />";
//查看隊(duì)列
$strCount = $redis->lrange($strQueueName, 0, -1);
echo "當(dāng)前隊(duì)列數(shù)據(jù)為: <br />";
print_r($strCount);

簡(jiǎn)單發(fā)布訂閱實(shí)戰(zhàn)

//以下是 pub.php 文件的內(nèi)容 cli下運(yùn)行
ini_set('default_socket_timeout', -1);
$redis->connect('127.0.0.1', 6379);
$strChannel = 'Test_bihu_channel';
//發(fā)布
$redis->publish($strChannel, "來自{$strChannel}頻道的推送");
echo "---- {$strChannel} ---- 頻道消息推送成功~ <br/>";
$redis->close();
//以下是 sub.php 文件內(nèi)容 cli下運(yùn)行
ini_set('default_socket_timeout', -1);
$redis->connect('127.0.0.1', 6379);
$strChannel = 'Test_bihu_channel';
//訂閱
echo "---- 訂閱{$strChannel}這個(gè)頻道,等待消息推送...----  <br/><br/>";
$redis->subscribe([$strChannel], 'callBackFun');
function callBackFun($redis, $channel, $msg)
{
    print_r([
        'redis'   => $redis,
        'channel' => $channel,
        'msg'     => $msg
    ]);
}

簡(jiǎn)單計(jì)數(shù)器實(shí)戰(zhàn)

$redis->connect('127.0.0.1', 6379);
$strKey = 'Test_bihu_comments';
//設(shè)置初始值
$redis->set($strKey, 0);
$redis->INCR($strKey);  //+1
$redis->INCR($strKey);  //+1
$redis->INCR($strKey);  //+1
$strNowCount = $redis->get($strKey);
echo "---- 當(dāng)前數(shù)量為{$strNowCount}。 ---- ";

排行榜實(shí)戰(zhàn)

$redis->connect('127.0.0.1', 6379);
$strKey = 'Test_bihu_score';
//存儲(chǔ)數(shù)據(jù)
$redis->zadd($strKey, '50', json_encode(['name' => 'Tom']));
$redis->zadd($strKey, '70', json_encode(['name' => 'John']));
$redis->zadd($strKey, '90', json_encode(['name' => 'Jerry']));
$redis->zadd($strKey, '30', json_encode(['name' => 'Job']));
$redis->zadd($strKey, '100', json_encode(['name' => 'LiMing']));
$dataOne = $redis->ZREVRANGE($strKey, 0, -1, true);
echo "---- {$strKey}由大到小的排序 ---- <br /><br />";
print_r($dataOne);
$dataTwo = $redis->ZRANGE($strKey, 0, -1, true);
echo "<br /><br />---- {$strKey}由小到大的排序 ---- <br /><br />";
print_r($dataTwo);

簡(jiǎn)單字符串悲觀鎖實(shí)戰(zhàn)

解釋:悲觀鎖(Pessimistic Lock), 顧名思義,就是很悲觀。

每次去拿數(shù)據(jù)的時(shí)候都認(rèn)為別人會(huì)修改,所以每次在拿數(shù)據(jù)的時(shí)候都會(huì)上鎖。

場(chǎng)景:如果項(xiàng)目中使用了緩存且對(duì)緩存設(shè)置了超時(shí)時(shí)間。

當(dāng)并發(fā)量比較大的時(shí)候,如果沒有鎖機(jī)制,那么緩存過期的瞬間,

大量并發(fā)請(qǐng)求會(huì)穿透緩存直接查詢數(shù)據(jù)庫,造成雪崩效應(yīng)。

/**
 * 獲取鎖
 * @param  String  $key    鎖標(biāo)識(shí)
 * @param  Int     $expire 鎖過期時(shí)間
 * @return Boolean
 */
public function lock($key = '', $expire = 5) {
    $is_lock = $this->_redis->setnx($key, time()+$expire);
    //不能獲取鎖
    if(!$is_lock){
        //判斷鎖是否過期
        $lock_time = $this->_redis->get($key);
        //鎖已過期,刪除鎖,重新獲取
        if (time() > $lock_time) {
            unlock($key);
            $is_lock = $this->_redis->setnx($key, time() + $expire);
        }
    }
    return $is_lock? true : false;
}
/**
 * 釋放鎖
 * @param  String  $key 鎖標(biāo)識(shí)
 * @return Boolean
 */
public function unlock($key = ''){
    return $this->_redis->del($key);
}
// 定義鎖標(biāo)識(shí)
$key = 'Test_bihu_lock';
// 獲取鎖
$is_lock = lock($key, 10);
if ($is_lock) {
    echo 'get lock success<br>';
    echo 'do sth..<br>';
    sleep(5);
    echo 'success<br>';
    unlock($key);
} else { //獲取鎖失敗
    echo 'request too frequently<br>';
}

簡(jiǎn)單事務(wù)的樂觀鎖實(shí)戰(zhàn)

解釋:樂觀鎖(Optimistic Lock), 顧名思義,就是很樂觀。

每次去拿數(shù)據(jù)的時(shí)候都認(rèn)為別人不會(huì)修改,所以不會(huì)上鎖。

watch命令會(huì)監(jiān)視給定的key,當(dāng)exec時(shí)候如果監(jiān)視的key從調(diào)用watch后發(fā)生過變化,則整個(gè)事務(wù)會(huì)失敗。

也可以調(diào)用watch多次監(jiān)視多個(gè)key。這樣就可以對(duì)指定的key加樂觀鎖了。

注意watch的key是對(duì)整個(gè)連接有效的,事務(wù)也一樣。

如果連接斷開,監(jiān)視和事務(wù)都會(huì)被自動(dòng)清除。

當(dāng)然了exec,discard,unwatch命令都會(huì)清除連接中的所有監(jiān)視。

$strKey = 'Test_bihu_age';
$redis->set($strKey,10);
$age = $redis->get($strKey);
echo "---- Current Age:{$age} ---- <br/><br/>";
$redis->watch($strKey);
// 開啟事務(wù)
$redis->multi();
//在這個(gè)時(shí)候新開了一個(gè)新會(huì)話執(zhí)行
$redis->set($strKey,30);  //新會(huì)話
echo "---- Current Age:{$age} ---- <br/><br/>"; //30
$redis->set($strKey,20);
$redis->exec();
$age = $redis->get($strKey);
echo "---- Current Age:{$age} ---- <br/><br/>"; //30
//當(dāng)exec時(shí)候如果監(jiān)視的key從調(diào)用watch后發(fā)生過變化,則整個(gè)事務(wù)會(huì)失敗

以上就是PHP使用Redis的應(yīng)用場(chǎng)景的匯總,內(nèi)容較為全面,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ骺赡軙?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI