這篇文章介紹的內容是關於PHP實現多伺服器SESSION共用,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
PHP實現多伺服器SESSION共用
為什麼要session共用
現在稍微大一點的網站基本上都有好幾個子網域名稱,比如www.feiniu.com, search.feiniu.com, member.feiniu.com,這些網站如果需要共用使用者登入資訊,那麼就需要做到session共用,當然前提是有相同的主域。
PHP的session原理
用戶端訪問php頁面,執行session_start,產生session_id,一般我們是把session_id儲存到cookie上,session內容儲存在服務端,用戶端訪問訪問不同的頁面都會把session_id傳到服務端,通過session_id來擷取session內容。
流程是這樣,可是不同的伺服器會對同一個用戶端產生不同的session_id,這樣的話不同伺服器就不能得到相同的session內容了。而且PHP 預設的 SESSION 資料都是分別儲存在本伺服器的檔案系統中。
所以我們要解決session共用,就必須解決兩個問題:
1. 多台伺服器用同一個session_id
這個比較容易解決,只要在php中設定存session_id的cookie網域名稱為網站主域就可以了開啟PHP.ini, 設定session.cookie_domain = .feiniu.com, 當然也可以在php代碼當中設定ini_set("session.cookie_domain","feiniu.com");
2. 多台伺服器用同一個session_id訪問到相同的session內容
要實現這點,就必須把session內容儲存到讓所有伺服器都能訪問到的地方,php的session內容是預設儲存到本伺服器的檔案中的,一般的解決方案是存入資料庫,memcache或者redis這種快取服務器,當然用預設的檔案儲存體方式也可以,用NFS統一儲存。如何修改session儲存引擎,參考這篇文章:http://blog.csdn.net/yagas/article/details/7593415
3. 如何選擇儲存引擎
預設檔案儲存體:這種方式的session銷毀依託於php垃圾收集器,在高並發或銷毀時間較長的情況下,在SESSION目錄下產生大量檔案,當然可以設定分級目錄進行 SESSION 檔案的儲存。這會導致兩個問題:第一、尋找檔案慢;第二,每個目錄下可容納的檔案數是有限的,可能會導致新SESSION儲存失敗。
資料庫儲存:把Session儲存在資料庫裡可以防止Session資料被垃圾收集器刪除,可以固化儲存session資料。但是用資料庫來同步session,會加大資料庫的IO,增加資料庫的負擔。而且資料庫讀寫速度較慢,不利於session的適時同步。
memcache儲存:
以這種方式來同步session,不會加大資料庫的負擔,並且安全性比較高,把session放到記憶體裡面,比從檔案中讀取要快很多。
但是memcache把記憶體分成很多種規格的儲存塊,有塊就有大小,這種方式也就決定了,memcache不能完全利用記憶體,會產生記憶體片段,如果儲存塊不足,還會產生記憶體溢出
那些不需要“分布”的,不需要共用的,或者乾脆規模小到只有一台伺服器的應用,memcached不會帶來任何好處,相反還會拖慢系統效率,因為網路連接同樣需要資源。
redis儲存:與memcache相比,redis訪問稍稍慢一點點,好處是:
redis支援的資料結構較多,可以儲存數組或對象,而memcache只能儲存字串
在session機器重啟的情況下,memcache所有使用者都必須重新獲得 session,而redis不會
在突然湧來大量使用者產生了很多資料把儲存 session 的機器記憶體佔滿了的情況下,memcache 會罷工,所有 key 都沒到期的話就不停的覆蓋最後寫入的資料,而 redis 只是會變慢 ,不會影響程式的邏輯