《PHP教程:Zend Framework實現多服務器共享SESSION數據的方法》要點:
本文介紹了PHP教程:Zend Framework實現多服務器共享SESSION數據的方法,希望對您有用。如果有疑問,可以聯系我們。
本文實例講述了Zend Framework實現多服務器共享SESSION數據的辦法.分享給大家供大家參考,具體如下:PHP教程
一、問題起源PHP教程
大型網站通常有多個服務器,并且使用多個二級域名.這樣一臺服務器產生的session就不能為所有服務器所共享.這樣用戶在一個地方登錄就不能全部通行PHP教程
二、PHP SESSION 的工作原理 PHP教程
在解決問題之前,先來了解一下 PHP SESSION 的工作原理.在客戶端(如瀏覽器)登錄網站時,被訪問的 PHP 頁面可以使用 session_start() 打開 SESSION,這樣就會產生客戶端的唯一標識 SESSION ID(此 ID 可通過函數 session_id() 獲取/設置).SESSION ID 可以通過兩種方式保留在客戶端,使得哀求不同的頁面時,PHP 程序可以獲知客戶端的 SESSION ID;一種是將 SESSION ID 自動加入到 GET 的 URL 中,或者 POST 的表單中,默認情況下,變量名為 PHPSESSID;另一種是通過 COOKIE,將 SESSION ID 保存在 COOKIE 中,默認情況下,這個 COOKIE 的名字為 PHPSESSID.這里我們主要以 COOKIE 方式進行說明,因為應用比較廣泛.PHP教程
那么 SESSION 的數據保存在哪里呢?當然是在服務器端,但不是保存在內存中,而是保存在文件或數據庫中.默認情況下,php.ini 中設置的 SESSION 保存方式是 files(session.save_handler = files),即使用讀寫文件的方式保存 SESSION 數據,而 SESSION 文件保存的目錄由 session.save_path 指定,文件名以 sess_ 為前綴,后跟 SESSION ID,如:sess_c72665af28a8b14c0fe11afe3b59b51b.文件中的數據即是序列化之后的 SESSION 數據了.如果拜訪量大,可能產生的 SESSION 文件會比較多,這時可以設置分級目錄進行 SESSION 文件的保存,效率會提高很多,設置方法為:session.save_path="N;/save_path",N 為分級的級數,save_path 為開始目錄.當寫入 SESSION 數據的時候,PHP 會獲取到客戶端的 SESSION_ID,然后根據這個 SESSION ID 到指定的 SESSION 文件保存目錄中找到相應的 SESSION 文件,不存在則創建之,最后將數據序列化之后寫入文件.讀取 SESSION 數據是也是類似的操作流程,對讀出來的數據需要進行解序列化,生成相應的 SESSION 變量.PHP教程
三、多服務器共享 SESSION 的主要障礙及解決方法PHP教程
通過了解 SESSION 的工作原理,我們可以發現,在默認情況下,各個服務器會各自分別對同一個客戶端產生 SESSION ID,如對于同一個用戶瀏覽器,A 服務器產生的 SESSION ID 是 30de1e9de3192ba6ce2992d27a1b6a0a,而 B 服務器生成的則是 c72665af28a8b14c0fe11afe3b59b51b.另外,PHP 的 SESSION 數據都是分別保存在本服務器的文件系統中.如下圖所示:PHP教程
PHP教程
確定了問題所在之后,就可以著手進行解決了.想要共享 SESSION 數據,那就必須實現兩個目標:一個是各個服務器對同一個客戶端產生的 SESSION ID 必須相同,并且可通過同一個 COOKIE 進行傳遞,也就是說各個服務器必須可以讀取同一個名為 PHPSESSID 的 COOKIE;另一個是 SESSION 數據的存儲方式/位置必須保證各個服務器都能夠拜訪到.簡單地說就是多服務器共享客戶端的 SESSION ID,同時還必須共享服務器端的 SESSION 數據.
第一個目標的實現其實很簡單,只需要對 COOKIE 的域(domain)進行特殊地設置即可,默認情況下,COOKIE 的域是當前服務器的域名/IP 地址,而域不同的話,各個服務器所設置的 COOKIE 是不能相互拜訪的,如 www.aaa.com 的服務器是不能讀寫 www.bbb.com 服務器設置的 COOKIE 的.這里我們所說的同一網站的服務器有其特殊性,那就是他們同屬于同一個一級域,如:aaa.infor96.com 和 www.infor96.com 都屬于域 .infor96.com,那么我們就可以設置 COOKIE 的域為 .infor96.com,這樣 aaa.infor96.com、www.infor96.com 等等都可以拜訪此 COOKIE.PHP 代碼中的設置方法如下:PHP教程
<?php ini_set('session.cookie_domain', '.infor96.com'); ?>
這樣各個服務器共享同一客戶端 SESSION ID 的目的就達到了.
第二個目標的實現可以使用文件共享方式,如 NFS 方式,但設置、操作上有些復雜.我們可以將數據放在memcache中.這樣各個服務器就可以方便地拜訪同一個數據源,獲取相同的 SESSION 數據了.
????
解決辦法如下圖所示:PHP教程
PHP教程
ok.PHP教程
更多關于zend相關內容感興趣的讀者可查看本站專題:《Zend FrameWork框架入門教程》、《php優秀開發框架總結》、《Yii框架入門及常用技巧總結》、《ThinkPHP入門教程》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》PHP教程
希望本文所述對大家基于Zend Framework框架的PHP程序設計有所贊助.PHP教程
歡迎參與《PHP教程:Zend Framework實現多服務器共享SESSION數據的方法》討論,分享您的想法,維易PHP學院為您提供專業教程。