當前位置:
首頁 > 最新 > 負載均衡中使用 Redis 實現共享 Session

負載均衡中使用 Redis 實現共享 Session

作者: Corwien

原文:https://segmentfault.com/a/1190000011558000

最近在研究Web架構方面的知識,包括資料庫讀寫分離,Redis緩存和隊列,集群,以及負載均衡(LVS),今天就來先學習下我在負載均衡中遇到的問題,那就是session共享的問題。

一、負載均衡

負載均衡:把眾多的訪問量分擔到其他的伺服器上,讓每個伺服器的壓力減少。

通俗的解釋就是:把一項任務交由一個開發人員處理總會有上限處理能力,這時可以考慮增加開發人員來共同處理這項任務,多人處理同一項任務時就會涉及到調度問題,即任務分配,這和多線程理念是一致的。nginx在這裡的角色相當於任務分配者。

如我們第一次訪問 這個域名,可能會對應這個IP 的伺服器,然後第二次訪問,IP可能會變為 的伺服器,這就是百度採用了負載均衡,一個域名對應多個伺服器,將訪問量分擔到其他的伺服器,這樣很大程度的減輕了每個伺服器上訪問量。

但是,這裡有一個問題,如果我們登錄了百度的一個賬號,如網頁的百度網盤,但是每次有可能請求的是不同的伺服器,我們知道每個伺服器都會有自己的會話session,所以會導致用戶每次刷新網頁又要重新登錄,這是非常糟糕的體驗,因此,根據以上問題,希望session可以共享,這樣就可以解決負載均衡中同一個域名不同伺服器對應不同session的問題。

二、Redis介紹

目前多伺服器的共享session,用的最多的是redis。

關於Redis的基礎知識,可以看我之前的博文Redis開發學習。

再簡單的梳理下:

1.redis是key-value的存儲系統,屬於非關係型資料庫

2.特點:支持數據持久化,可以讓數據在內存中保存到磁碟里(memcached:數據存在內存里,如果服務重啟,數據會丟失)

3.支持5種數據類型:string,hash,list,set,zset

4.兩種文件格式(即數據持久化)

RDB(全量數據):多長時間/頻率,把內存中的數據刷到磁碟中,便於下次讀取文件時進行載入。

AOF(增量請求):類似mysql的二進位日誌,不停地把對資料庫的更改語句記錄到日誌中,下次重啟服務,會根據二進位日誌把數據重寫一次,載入到內存里,實現數據持久化

5.存儲

內存存儲

磁碟存儲(RDB)

log文件(AOF)

三、實現的核心思想

首先要明確session和cookie的區別。瀏覽器端存的是cookie每次瀏覽器發請求到服務端是http 報文頭是會自動加上你的cookie信息的。服務端拿著用戶的cookie作為key去存儲里找對應的value(session)。

同一域名下的網站的cookie都是一樣的。所以無論幾台伺服器,無論請求分配到哪一台伺服器上同一用戶的cookie是不變的。也就是說cookie對應的session也是唯一的。

所以,這裡只要保證多台業務伺服器訪問同一個redis伺服器(或集群)就行了。

四、PHP會話session配置改為Redis

我們可以看到PHP默認的的session配置使用文件形式保存在伺服器臨時目錄中,我們需要Redis作為保存session的驅動,所以,這裡需要對配置文件進行修改,PHP的自定義會話機制改為Redis。

這裡有三種修改方式:

1.修改配置文件php.ini

找到配置文件 ,修改為下面內容,保存並重啟服務

2.代碼中動態配置修改

直接在代碼中加入以下內容:

註:如果配置文件redis.conf里設置了連接密碼requirepass,save_path需要這樣寫tcp://127.0.0.1:6379?auth=authpwd ,否則保存session的時候會報錯。

測試:

3.自定義會話機制

使用 方法自定義會話機制,網上發現了一個封裝非常好的類,我們可以直接使用這個類來實現我們的共享session操作。

在你的項目入口處調用上邊的類:上邊的方法等於是重寫了session寫入文件的方法,將數據寫入到了Redis中。

初始化文件

測試 test.php

在Redis客戶端使用命令查看我們的這條數據是否存在:

我們可以看到,我們的數據被保存在了Redis端了,鍵為: .

喜歡這篇文章嗎?立刻分享出去讓更多人知道吧!

本站內容充實豐富,博大精深,小編精選每日熱門資訊,隨時更新,點擊「搶先收到最新資訊」瀏覽吧!


請您繼續閱讀更多來自 IT程序員 的精彩文章:

TAG:IT程序員 |