溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Zend Framework如何實現(xiàn)多服務器共享SESSION數(shù)據(jù)

發(fā)布時間:2021-08-27 10:46:19 來源:億速云 閱讀:140 作者:小新 欄目:開發(fā)技術

小編給大家分享一下Zend Framework如何實現(xiàn)多服務器共享SESSION數(shù)據(jù),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一、問題起源

大型網(wǎng)站通常有多個服務器,并且使用多個二級域名。這樣一臺服務器產(chǎn)生的session就不能為所有服務器所共享。這樣用戶在一個地方登錄就不能全部通行

二、PHP SESSION 的工作原理

在解決問題之前,先來了解一下 PHP SESSION 的工作原理。在客戶端(如瀏覽器)登錄網(wǎng)站時,被訪問的 PHP 頁面可以使用 session_start() 打開 SESSION,這樣就會產(chǎn)生客戶端的唯一標識 SESSION ID(此 ID 可通過函數(shù) session_id() 獲取/設置)。SESSION ID 可以通過兩種方式保留在客戶端,使得請求不同的頁面時,PHP 程序可以獲知客戶端的 SESSION ID;一種是將 SESSION ID 自動加入到 GET 的 URL 中,或者 POST 的表單中,默認情況下,變量名為 PHPSESSID;另一種是通過 COOKIE,將 SESSION ID 保存在 COOKIE 中,默認情況下,這個 COOKIE 的名字為 PHPSESSID。這里我們主要以 COOKIE 方式進行說明,因為應用比較廣泛。

那么 SESSION 的數(shù)據(jù)保存在哪里呢?當然是在服務器端,但不是保存在內(nèi)存中,而是保存在文件或數(shù)據(jù)庫中。默認情況下,php.ini 中設置的 SESSION 保存方式是 files(session.save_handler = files),即使用讀寫文件的方式保存 SESSION 數(shù)據(jù),而 SESSION 文件保存的目錄由 session.save_path 指定,文件名以 sess_ 為前綴,后跟 SESSION ID,如:sess_c72665af28a8b14c0fe11afe3b59b51b。文件中的數(shù)據(jù)即是序列化之后的 SESSION 數(shù)據(jù)了。如果訪問量大,可能產(chǎn)生的 SESSION 文件會比較多,這時可以設置分級目錄進行 SESSION 文件的保存,效率會提高很多,設置方法為:session.save_path="N;/save_path",N 為分級的級數(shù),save_path 為開始目錄。當寫入 SESSION 數(shù)據(jù)的時候,PHP 會獲取到客戶端的 SESSION_ID,然后根據(jù)這個 SESSION ID 到指定的 SESSION 文件保存目錄中找到相應的 SESSION 文件,不存在則創(chuàng)建之,最后將數(shù)據(jù)序列化之后寫入文件。讀取 SESSION 數(shù)據(jù)是也是類似的操作流程,對讀出來的數(shù)據(jù)需要進行解序列化,生成相應的 SESSION 變量。

三、多服務器共享 SESSION 的主要障礙及解決辦法

通過了解 SESSION 的工作原理,我們可以發(fā)現(xiàn),在默認情況下,各個服務器會各自分別對同一個客戶端產(chǎn)生 SESSION ID,如對于同一個用戶瀏覽器,A 服務器產(chǎn)生的 SESSION ID 是 30de1e9de3192ba6ce2992d27a1b6a0a,而 B 服務器生成的則是 c72665af28a8b14c0fe11afe3b59b51b。另外,PHP 的 SESSION 數(shù)據(jù)都是分別保存在本服務器的文件系統(tǒng)中。如下圖所示:

Zend Framework如何實現(xiàn)多服務器共享SESSION數(shù)據(jù)

確定了問題所在之后,就可以著手進行解決了。想要共享 SESSION 數(shù)據(jù),那就必須實現(xiàn)兩個目標:一個是各個服務器對同一個客戶端產(chǎn)生的 SESSION ID 必須相同,并且可通過同一個 COOKIE 進行傳遞,也就是說各個服務器必須可以讀取同一個名為 PHPSESSID 的 COOKIE;另一個是 SESSION 數(shù)據(jù)的存儲方式/位置必須保證各個服務器都能夠訪問到。簡單地說就是多服務器共享客戶端的 SESSION ID,同時還必須共享服務器端的 SESSION 數(shù)據(jù)。
第一個目標的實現(xiàn)其實很簡單,只需要對 COOKIE 的域(domain)進行特殊地設置即可,默認情況下,COOKIE 的域是當前服務器的域名/IP 地址,而域不同的話,各個服務器所設置的 COOKIE 是不能相互訪問的,如 www.aaa.com 的服務器是不能讀寫 www.bbb.com 服務器設置的 COOKIE 的。這里我們所說的同一網(wǎng)站的服務器有其特殊性,那就是他們同屬于同一個一級域,如:aaa.infor96.com 和 www.infor96.com 都屬于域 .infor96.com,那么我們就可以設置 COOKIE 的域為 .infor96.com,這樣 aaa.infor96.com、www.infor96.com 等等都可以訪問此 COOKIE。PHP 代碼中的設置方法如下:

<?php
ini_set('session.cookie_domain', '.infor96.com');
?>

這樣各個服務器共享同一客戶端 SESSION ID 的目的就達到了。
第二個目標的實現(xiàn)可以使用文件共享方式,如 NFS 方式,但設置、操作上有些復雜。我們可以將數(shù)據(jù)放在memcache中。這樣各個服務器就可以方便地訪問同一個數(shù)據(jù)源,獲取相同的 SESSION 數(shù)據(jù)了。
    
解決辦法如下圖所示:

Zend Framework如何實現(xiàn)多服務器共享SESSION數(shù)據(jù)

以上是“Zend Framework如何實現(xiàn)多服務器共享SESSION數(shù)據(jù)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

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

AI