" />

欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

redis調(diào)用二維碼時(shí)的不斷刷新排查分析

 更新時(shí)間:2022年04月01日 10:24:09   作者:一夕如環(huán)  
這篇文章主要為大家介紹了redis調(diào)用二維碼時(shí)不斷刷新排查分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪

一、背景和現(xiàn)象

項(xiàng)目是PHP開發(fā)的,點(diǎn)擊登錄的時(shí)候就根據(jù)隨機(jī)數(shù)生成了二維碼,緩存在了redis。用戶用微信掃描了二維碼分析出需要請(qǐng)求的鏈接,然后微信瀏覽器就請(qǐng)求了服務(wù)器,服務(wù)器通過了隨機(jī)數(shù)認(rèn)證。正當(dāng)請(qǐng)求了之后,服務(wù)器就拿服務(wù)器找出來的的APPID去微信服務(wù)器請(qǐng)求。微信準(zhǔn)許登陸,服務(wù)器修改狀態(tài)。這個(gè)時(shí)候websocket服務(wù)器修改了狀態(tài),把修改狀態(tài)的事告訴瀏覽器,瀏覽器變更狀態(tài)。如果沒有websocket的情況下,瀏覽器不斷的詢問服務(wù)器是否修改了狀態(tài),不能設(shè)置得太頻繁所以慢。扯遠(yuǎn)了,這里關(guān)鍵就是說生成的二維碼一直在變,不知道怎么回事。redis+sentinel+haproxy的模型做好了,就切換到項(xiàng)目使用。可以打開頁面,本以為完全正常,誰知道在二維碼登錄的時(shí)候,二維碼一直在刷新。

二、分析

用戶在頁面上請(qǐng)求,二維碼就生成存在redis里面。頁面在獲取,獲取不到就繼續(xù)請(qǐng)求。問題可能出現(xiàn)在redis的讀寫權(quán)限上面。

三、排查

1、把redis的配置指向之前用的redis,空出redis集群來調(diào)試。通過haproxy登錄redis,模擬真實(shí)場(chǎng)景,然后用set命令。定義了一個(gè)鍵值。在用get讀取出來,能讀出值。說明在haproxy上讀寫都不成問題。

既然在用命令行讀寫沒問題,可以試試用PHP讀寫有沒有問題。

2、編輯PHP腳本,執(zhí)行。

<?php
$redis = new redis();
$result = $redis->connect('**.**.**.**', 6379);
$result = $redis->auth('******');
$result = $redis->set('test',"renhaoqiang");
$result = $redis->get('test');
var_dump($result); //結(jié)果:bool(true)
?>

執(zhí)行結(jié)果,

如此一來,PHP讀寫也不成問題。那就用apache執(zhí)行看看,

同樣沒問題。暫時(shí)排除讀寫權(quán)限問題。

3、其實(shí)可以先不做以上兩個(gè)步驟的排查。都還沒確定是不是真的是redis的問題。這一步找到集群中的master,然后直接在項(xiàng)目的配置文件中設(shè)置指向master,這樣就避開了haproxy,可以確定是不是haproxy的問題。

問題也沒有解決,那就只能先排除haproxy的問題了。難道是redis集群的問題?

4、那就用同樣的方法創(chuàng)建一個(gè)redis,打上去看有沒有問題。因?yàn)檫@種方式跟平時(shí)的網(wǎng)絡(luò)方式有點(diǎn)不同。首先去配置文件的目錄復(fù)制配置文件,改端口。創(chuàng)建了之后改項(xiàng)目配置指向的時(shí)候,發(fā)現(xiàn)問題還在,那就可以排除集群的兼容性??赡苁且?yàn)閔ost="net”的這種網(wǎng)絡(luò)方式。

docker run -d --net="host" -v /etc/localtime:/etc/localtime -v /etc/timezone:/etc/timezone -v /Redis-cluster/5379:/data -v /usr/local/configurefiles/redis-cluster/etc/redis-5379.conf:/usr/local/redis/etc/redis.conf --name redis-5379 **.**.**.**:5000/redis:3.2 redis-server /usr/local/redis/etc/redis.conf

5、用以前端口映射的那種方式新建一個(gè)redis,端口5267。

docker run -d -p 5267:6379 -v /etc/localtime:/etc/localtime -v /etc/timezone:/etc/timezone -v /RedisData:/data -v /usr/local/configurefiles/redis/etc:/usr/local/redis/etc --name redis **.**.**.**:5000/redis:3.2 redis-server /usr/local/redis/etc/redis.conf

發(fā)現(xiàn)問題依舊?,F(xiàn)在也可以暫時(shí)排除host="net”這種網(wǎng)絡(luò)方式的問題。和原來那種不同的只是映射的端口,那就是這個(gè)端口的問題了。

6、排查到這一步,問題漸漸冒出來了。應(yīng)該是5268這個(gè)端口已經(jīng)被綁定,換其他端口都不行。或者是配置文件綁定,或者是代碼綁定。配置文件全在我的掌握中,這個(gè)可以排除。因?yàn)樵谡江h(huán)境是用6379這個(gè)端口,那么代碼綁定這個(gè)也排除了。做這樣一種假設(shè),項(xiàng)目對(duì)redis的請(qǐng)求可以跟著我的配置隨時(shí)變,但是swoole沒重啟一次就固定一次。

先不想那么多,趕緊重啟websocket服務(wù)器,問題果然沒了。

原來是頁面請(qǐng)求二維碼的時(shí)候代碼就生成,存在了redis里面。但是websocket從redis里面一直沒有獲取到,因?yàn)樗亩丝谝恢笔桥f的那個(gè),頁面的隨機(jī)數(shù)一直都是在redis找不到一樣的,所以一直刷新,如此循環(huán)。重啟了swoole了之后,他請(qǐng)求的那個(gè)redis也是配置文件里面最新的,所以能成功在redis找到和瀏覽器一樣的隨機(jī)數(shù)。此次排除到,我的服務(wù)都,沒有問題。倒是曲折的排查過程更豐富我的邏輯思路。

以上就是redis調(diào)用二維碼時(shí)的不斷刷新排查分析的詳細(xì)內(nèi)容,更多關(guān)于redis調(diào)用二維碼不斷刷新排查的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Redis使用ZSET實(shí)現(xiàn)消息隊(duì)列的項(xiàng)目實(shí)踐

    Redis使用ZSET實(shí)現(xiàn)消息隊(duì)列的項(xiàng)目實(shí)踐

    本文主要介紹了Redis使用ZSET實(shí)現(xiàn)消息隊(duì)列的項(xiàng)目實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • mac下redis安裝、設(shè)置、啟動(dòng)停止方法詳解

    mac下redis安裝、設(shè)置、啟動(dòng)停止方法詳解

    這篇文章主要介紹了mac下redis安裝、設(shè)置、啟動(dòng)停止方法詳解,需要的朋友可以參考下
    2020-02-02
  • 淺析Redis Sentinel 與 Redis Cluster

    淺析Redis Sentinel 與 Redis Cluster

    本文主要介紹Redis Sentinel 及 Redis Cluster的區(qū)別及用法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-06-06
  • Redis安裝使用RedisJSON模塊的方法

    Redis安裝使用RedisJSON模塊的方法

    在使用Redis中,我們可以使用大量的Redis模塊來擴(kuò)展Redis的功能,本文主要介紹了Redis安裝使用RedisJSON模塊的方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2022-03-03
  • redis遠(yuǎn)程連接不上的解決辦法

    redis遠(yuǎn)程連接不上的解決辦法

    本文主要介紹了redis遠(yuǎn)程連接不上的解決辦法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • redis基本安裝判斷、啟動(dòng)使用方法示例

    redis基本安裝判斷、啟動(dòng)使用方法示例

    這篇文章主要介紹了redis基本安裝判斷、啟動(dòng)使用方法,結(jié)合實(shí)例形式分析了Redis針對(duì)是否安裝的判斷、啟動(dòng)等使用方法,需要的朋友可以參考下
    2020-02-02
  • 關(guān)于在Redis中使用Pipelining加速查詢的問題

    關(guān)于在Redis中使用Pipelining加速查詢的問題

    這篇文章主要介紹了在Redis中使用Pipelining加速查詢,Redis是一個(gè)client-server模式的TCP服務(wù),也被稱為Request/Response協(xié)議的實(shí)現(xiàn),本文通過一個(gè)例子給大家詳細(xì)介紹,感興趣的朋友一起看看吧
    2022-05-05
  • 如何自定義redis工具jar包供其他SpringBoot項(xiàng)目直接使用

    如何自定義redis工具jar包供其他SpringBoot項(xiàng)目直接使用

    這篇文章主要介紹了如何自定義redis工具jar包供其他SpringBoot項(xiàng)目直接使用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • 淺談Redis緩存雪崩解決方案

    淺談Redis緩存雪崩解決方案

    本文主要介紹了Redis緩存雪崩解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • Redis深入了解內(nèi)存淘汰與事務(wù)操作

    Redis深入了解內(nèi)存淘汰與事務(wù)操作

    將Redis用作緩存時(shí),Redis數(shù)據(jù)存在內(nèi)存中,如果內(nèi)存空間用滿,就會(huì)自動(dòng)驅(qū)逐老的數(shù)據(jù)。Redis事務(wù)是一個(gè)單獨(dú)的隔離操作:事務(wù)中的所有命令都會(huì)序列化、按順序地執(zhí)行。事務(wù)在執(zhí)行的過程中,不會(huì)被其他客戶端發(fā)送來的命令請(qǐng)求所打斷
    2022-07-07

最新評(píng)論