一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

解析php中session的實現原理以及大網站應用應注意的問題

php SESSION原理
我們知道,session是在服務器端保持用戶會話數據的一種方法,對應的cookie是 在客戶端保持用戶數據。HTTP協議是一種無狀態協議,服務器響應完之后就失去了與瀏覽器的聯系,最早,NETscape將cookie引入瀏覽器,使得 數據可以客戶端跨頁面交換,那么服務器是如何記住眾多用戶的會話數據呢?

首先要將客戶端和服務器端建立一一聯系,每個客戶 端都得有一個唯一標識,這樣服務器才能識別出來。建議唯一標識的方法有兩種:cookie或者通過GET方式指定。默認配置的php使用session的 時會建立一個名叫”phpSESSID”的cookie(可以通過php.ini修改session.name值指定),如果客戶端禁用cookie,你 也可以指定通過GET方式把session id傳到服務器(修改php.ini中session.use_trans_sid等參數)。

我們查看服務器端session.save_path目錄會發現很多類似sess_vv9lpgf0nmkurgvkba1vbvj915這樣的文件,這個 其實就是session id “vv9lpgf0nmkurgvkba1vbvj915″對應的數據。真相就在這里,客戶端將session id傳遞到服務器服務器根據session id找到對應的文件,讀取的時候對文件內容進行反序列化就得到session的值,保存的時候先序列化再寫入。

事實就是這 樣,所以如果服務器不支持session或者你想自定義session,完全可以DIY,通過php的uniqid生成永不重復的session id,然后找個地方存儲session的內容即可,你也可以學flickr把session存儲在MySQL數據庫中。

使用session之前為什么必須先執行session_start()?
了 解的原理之后,所謂的session其實就是客戶端一個session id服務器端一個session file,新建session之前執行session_start()是告訴服務器要種一個cookie以及準備好session文件,要不然你的 session內容怎么存;讀取session之前執行session_start()是告訴服務器,趕緊根據session id把session文件反序列化。

只有一個session函數可以在session_start()之前執行,session_name():讀取或指定session名稱(比如默認的就是”phpSESSID”),這個當然要在session_start之前執行。

session影響系統性能
session 在大訪問量網站上確實影響系統性能,影響性能的原因之一由文件系統設計造成,在同一個目錄下超過10000個文件時,文件的定位將非常耗時,php支持 session目錄hash,我們可以通過修改php.ini中session.save_path = “2;/path/to/session/dir”,那么session將存儲在兩級子目錄中,每個目錄有16個子目錄[0~f],不過好像php session不支持創建目錄,你需要事先把那么些目錄創建好 。

還有一個問題就是小文件的效率問題,一般我們的 session數據都不會太大(1~2K),如果有大量這樣1~2K的文件在磁盤上,IO效率肯定會很差,php手冊上建議使用Reiserfs文件系 統,不過Reiserfs的前景堪憂,Reiserfs的作者把媳婦給殺了,SuSE也拋棄了Reiserfs。

其實還有很多中 存儲session的方式,可以通過php -i|grep “Registered save handlers”查看,比如Registered save handlers => files user sqlite eaccelerator可以通過文件、用戶、sqlite、eaccelerator來存,如果服務器裝了memcached,還有會mmcache的 選項。當然還有很多,比如MySQL、PostgreSQL等等。都是不錯的選擇。

session的同步
我們前端可能有很多臺服務器,用戶在A服務器上登錄了,種下了session信息,然后訪問網站的某些頁面沒準跳到B服務器上去了,如果這個時候B服務器上沒有session信息又沒有做特殊處理,可能就會出問題了。
session同步有很多種,如果你是存儲在memcached或者MySQL中,那就很容易了,指定到同樣的位置即可,如果是文件形式的,你可以用NFS統一存儲

還有一種方式是通過加密的cookie來實現,用戶在A服務器上登錄成功,在用戶的瀏覽器上種上一個加密的cookie,當用戶訪問B服務器時,檢查有無 session,如果有當然沒問題,如果沒有,就去檢驗cookie是否有效,cookie有效的話就在B服務器上重建session。這種方法其實很有 用,如果網站有很多個子頻道,服務器也不在一個機房,session沒辦法同步又想做統一登錄那就太有用了。

當然還有一種方法就 是在負載均衡那一層保持會話,把訪問者綁定在某個服務器上,他的所有訪問都在那個服務器上就不需要session同步了,這些都是運維層面的東西。就說這 么多吧,根據自己的應用來選擇使用session,不要因為大家都說session影響系統性能就畏首畏尾,知道問題,解決問題才是關鍵,惹不起躲得起不適合這里。

php技術解析php中session的實現原理以及大網站應用應注意的問題,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 六月激情 | 成人看片黄a毛片 | 国产成人精品久久一区二区小说 | 久久精品二区 | 国产色婷婷 | 成 人 色综合 | 亚洲国产图片 | 日本视频网站在线www色 | 亚洲综合区图片小说区 | 伊人小婷婷色香综合缴缴情 | 免费看美女的逼 | a高清免费毛片久久 | 国产精品第1页 | 日韩中文字幕在线亚洲一区 | 欧美色欧美色 | 天天狠天天透天天伊人 | 一区二区三区免费视频网站 | 中文字幕精品一区二区三区在线 | 91精品啪国产在线观看免费牛牛 | 黄色片视频网站 | 国产精品_国产精品_国产精品 | 国产欧美精品专区一区二区 | 91资源在线 | 美女扒开腿被男人猛视频 | 久久亚洲精品无码观看不卡 | 亚洲免费一区 | 国产69成人免费视频观看 | 香蕉成人影院 | 精品一区二区三区四区 | 四虎国产精品一区二区 | 国产乱人伦精品一区二区 | 亚洲欧美成人综合久久久 | 四虎免费在线观看视频 | 国产精品黄大片在线播放 | 法国性xxxxx极品 | 水蜜桃一二二区视在线 | 精品久久久久久久一区二区伦理 | 国产99er66在线视频 | 美女动作一级毛片 | 日韩视频一区二区三区 | 久久久久久91精品色婷婷 |