這篇文章介紹的內容是關於PHP實現多伺服器SESSION共享,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
現在稍微大一點的網站基本上都有好幾個子域名,例如www.feiniu.com, search.feiniu.com, member.feiniu.com,這些網站如果需要共用使用者登入訊息,那麼就需要做到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");
1
2
#3
2. 多台伺服器用同一個session_id存取到相同的session內容
要实现这点,就必须把session内容存储到让所有服务器都能访问到的地方,php的session内容是默认存储到本服务器的文件中的,一般的解决方案是存入数据库,memcache或者redis这种缓存服务器,当然用默认的文件存储方式也可以,用NFS统一存储。 如何修改session存储引擎,参考这篇文章:http://blog.csdn.net/yagas/article/details/7593415
3. 如何選擇儲存引擎
那些不需要「分佈」的,不需要共享的,或者乾脆規模小到只有一台伺服器的應用,memcached不會帶來任何好處,相反還會拖慢系統效率,因為網路連線同樣需要資源。
redis儲存:與memcache相比,redis存取稍微慢一點,好處是:
redis支援的資料結構較多,可以儲存數組或對象,而memcache只能儲存字串
在session機器重啟的情況下,memcache所有使用者都必須重新取得session ,而redis不會
在突然湧來大量用戶產生了很多數據把存儲session 的機器內存佔滿了的情況下,memcache 會罷工,所有key 都沒過期的話就不停的覆蓋最後寫入的數據,而redis 只是會變慢,不會影響程式的邏輯
相關推薦:
#以上是PHP實作多伺服器SESSION共享的詳細內容。更多資訊請關注PHP中文網其他相關文章!