您好,登錄后才能下訂單哦!
這篇文章主要介紹thinkPHP多域名情況下如何使用memcache方式共享session數(shù)據(jù),文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
一、問(wèn)題起源
稍大一些的網(wǎng)站,通常都會(huì)有好幾個(gè)服務(wù)器,每個(gè)服務(wù)器運(yùn)行著不同功能的模塊,使用不同的二級(jí)域名,而一個(gè)整體性強(qiáng)的網(wǎng)站,用戶系統(tǒng)是統(tǒng)一的,即一套用戶名、密碼在整個(gè)網(wǎng)站的各個(gè)模塊中都是可以登錄使用的。各個(gè)服務(wù)器共享用戶數(shù)據(jù)是比較容易實(shí)現(xiàn)的,只需要在后端放個(gè)數(shù)據(jù)庫(kù)服務(wù)器,各個(gè)服務(wù)器通過(guò)統(tǒng)一接口對(duì)用戶數(shù)據(jù)進(jìn)行訪問(wèn)即可。但還存在一個(gè)問(wèn)題,就是用戶在這個(gè)服務(wù)器登錄之后,進(jìn)入另一個(gè)服務(wù)器的別的模塊時(shí),仍然需要重新登錄,這就是一次登錄,全部通行的問(wèn)題,映射到技術(shù)上,其實(shí)就是各個(gè)服務(wù)器之間如何實(shí)現(xiàn)共享 SESSION 數(shù)據(jù)的問(wèn)題。
二、PHP SESSION 的工作原理
在解決問(wèn)題之前,先來(lái)了解一下 PHP SESSION 的工作原理。在客戶端(如瀏覽器)登錄網(wǎng)站時(shí),被訪問(wèn)的 PHP 頁(yè)面可以使用session_start() 打開(kāi) SESSION,這樣就會(huì)產(chǎn)生客戶端的唯一標(biāo)識(shí) SESSION ID(此 ID 可通過(guò)函數(shù)session_id() 獲取/設(shè)置)。SESSION ID 可以通過(guò)兩種方式保留在客戶端,使得請(qǐng)求不同的頁(yè)面時(shí),PHP程序可以獲知客戶端的 SESSION ID;一種是將 SESSION ID 自動(dòng)加入到 GET 的 URL 中,或者 POST的表單中,默認(rèn)情況下,變量名為 PHPSESSID;另一種是通過(guò) COOKIE,將 SESSION ID 保存在 COOKIE中,默認(rèn)情況下,這個(gè) COOKIE 的名字為 PHPSESSID。這里我們主要以 COOKIE方式進(jìn)行說(shuō)明,因?yàn)閼?yīng)用比較廣泛。
那么 SESSION 的數(shù)據(jù)保存在哪里呢?當(dāng)然是在服務(wù)器端,但不是保存在內(nèi)存中,而是保存在文件或數(shù)據(jù)庫(kù)中。默認(rèn)情況下,php.ini中設(shè)置的 SESSION 保存方式是 files(session.save_handler = files),即使用讀寫(xiě)文件的方式保存SESSION 數(shù)據(jù),而 SESSION 文件保存的目錄由 session.save_path 指定,文件名以 sess_為前綴,后跟 SESSIONID,如:sess_c72665af28a8b14c0fe11afe3b59b51b。文件中的數(shù)據(jù)即是序列化之后的 SESSION數(shù)據(jù)了。如果訪問(wèn)量大,可能產(chǎn)生的 SESSION 文件會(huì)比較多,這時(shí)可以設(shè)置分級(jí)目錄進(jìn)行 SESSION文件的保存,效率會(huì)提高很多,設(shè)置方法為:session.save_path=”N;/save_path”,N為分級(jí)的級(jí)數(shù),save_path 為開(kāi)始目錄。當(dāng)寫(xiě)入 SESSION 數(shù)據(jù)的時(shí)候,PHP 會(huì)獲取到客戶端的SESSION_ID,然后根據(jù)這個(gè) SESSION ID 到指定的 SESSION 文件保存目錄中找到相應(yīng)的 SESSION文件,不存在則創(chuàng)建之,最后將數(shù)據(jù)序列化之后寫(xiě)入文件。讀取 SESSION數(shù)據(jù)是也是類似的操作流程,對(duì)讀出來(lái)的數(shù)據(jù)需要進(jìn)行解序列化,生成相應(yīng)的 SESSION 變量。
三、多服務(wù)器共享 SESSION 的主要障礙及解決辦法
通過(guò)了解 SESSION 的工作原理,我們可以發(fā)現(xiàn),在默認(rèn)情況下,各個(gè)服務(wù)器會(huì)各自分別對(duì)同一個(gè)客戶端產(chǎn)生 SESSIONID,如對(duì)于同一個(gè)用戶瀏覽器,A 服務(wù)器產(chǎn)生的 SESSION ID 是30de1e9de3192ba6ce2992d27a1b6a0a,而 B 服務(wù)器生成的則是c72665af28a8b14c0fe11afe3b59b51b。另外,PHP 的 SESSION數(shù)據(jù)都是分別保存在本服務(wù)器的文件系統(tǒng)中。
確定了問(wèn)題所在之后,就可以著手進(jìn)行解決了。想要共享 SESSION 數(shù)據(jù),那就必須實(shí)現(xiàn)兩個(gè)目標(biāo):一個(gè)是各個(gè)服務(wù)器對(duì)同一個(gè)客戶端產(chǎn)生的SESSION ID 必須相同,并且可通過(guò)同一個(gè) COOKIE 進(jìn)行傳遞,也就是說(shuō)各個(gè)服務(wù)器必須可以讀取同一個(gè)名為 PHPSESSID的 COOKIE;另一個(gè)是 SESSION 數(shù)據(jù)的存儲(chǔ)方式/位置必須保證各個(gè)服務(wù)器都能夠訪問(wèn)到。簡(jiǎn)單地說(shuō)就是多服務(wù)器共享客戶端的SESSION ID,同時(shí)還必須共享服務(wù)器端的 SESSION 數(shù)據(jù)。
第一個(gè)目標(biāo)的實(shí)現(xiàn)其實(shí)很簡(jiǎn)單,只需要對(duì) COOKIE 的域(domain)進(jìn)行特殊地設(shè)置即可,默認(rèn)情況下,COOKIE的域是當(dāng)前服務(wù)器的域名/IP 地址,而域不同的話,各個(gè)服務(wù)器所設(shè)置的 COOKIE 是不能相互訪問(wèn)的,如 www.aaa.com的服務(wù)器是不能讀寫(xiě) www.bbb.com 服務(wù)器設(shè)置的 COOKIE的。這里我們所說(shuō)的同一網(wǎng)站的服務(wù)器有其特殊性,那就是他們同屬于同一個(gè)一級(jí)域,如:tieba.xiaoyuan.com 和www.xiaoyuan.com 都屬于域 .xiaoyuan.com,那么我們就可以設(shè)置 COOKIE 的域?yàn)?xiaoyuan.com,這樣 tieba.xiaoyuan.com、www.xiaoyuan.com 等等都可以訪問(wèn)此COOKIE。PHP 代碼中的設(shè)置方法如下:
<?php ini_set('session.cookie_domain', '.xiaoyuan.com'); ?>
這樣各個(gè)服務(wù)器共享同一客戶端 SESSION ID 的目的就達(dá)到了。
第二個(gè)目標(biāo)的實(shí)現(xiàn)可以使用文件共享方式,有2種方式可以解決,一是用數(shù)據(jù)庫(kù)存session,還有就是試用memcache。這里用MEMCACHE來(lái)解決.
我用的是thinkphp框架,已經(jīng)支持memcache方式存取session.架好memcache服務(wù)器后,只需要在配置文件里面設(shè)置好memcache的IP和端口,然后指定COOKIE_DOMAIN參數(shù)就可以了,然后就可以按正常操作session的方式進(jìn)行操作,這時(shí)已經(jīng)可以多域名共享session了
以上是“thinkPHP多域名情況下如何使用memcache方式共享session數(shù)據(jù)”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。