国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Sessions共享技術設計

RdouTyping / 2331人閱讀

摘要:方法銷毀大于給定的所有數據,對本身擁有過期機制的系統如和而言,該方法可以留空。注意事項瀏覽器標簽腳本執行過程中,打開標簽訪問同一個腳本,會被,直到執行完畢。

概述

分布式session是實現分布式部署的前提, 當前項目由于歷史原因未實現分布式session, 但是由于在kubernets中部署多個pod時, 負載均衡的調用鏈太長, 導致會話不能保持, 所以迫切需要分布式session.

實現方案 a. 修改配置文件php.ini

直接在PHP中配置, 或者在代碼中集成

session.save_handler = redis
session.save_path = "tcp://127.0.0.1:6379"
b. 代碼中動態設置
ini_set("session.save_handler", "redis");
ini_set("session.save_path", "tcp://127.0.0.1:6379");
c. 實現SessionHandlerInterface接口

php提供了SessionHandlerInterface接口, 按照此接口進行implements, 即可完成session共享。

/**
 * @see http://php.net/manual/zh/class.sessionhandlerinterface.php
 */
SessionHandlerInterface {
    abstract public bool close ( void )
    abstract public bool destroy ( string $session_id )
    abstract public int gc ( int $maxlifetime )
    abstract public bool open ( string $save_path , string $session_name )
    abstract public string read ( string $session_id )
    abstract public bool write ( string $session_id , string $session_data )
}

/**
 * @see http://php.net/manual/zh/class.sessionhandler.php
 */
MySessionHandler implements SessionHandlerInterface , SessionIdInterface {
    public bool close ( void )
    public string create_sid ( void )
    public bool destroy ( string $session_id )
    public int gc ( int $maxlifetime )
    public bool open ( string $save_path , string $session_name )
    public string read ( string $session_id )
    public bool write ( string $session_id , string $session_data )
}

如上是PHP文檔中對此interface的描述, 下面介紹下迅速過一下涉及到的幾個方法:

方法 說明
open 方法用于基于文件的session存儲系統, 該方法中可不放置任何代碼,可以將其置為空方法。
close 和open 方法一樣,也可以被忽略,對大多數驅動而言都用不到該方法。
read 應該返回與給定$sessionId, 相匹配的session數據的字符串版本。
write 應該講給定$data 寫到持久化存儲系統相應的$sessionId destroy 從持久化存儲中移除 $sessionId 對應的數據。
gc 方法銷毀大于給定 $lifetime 的所有session數據,對本身擁有過期機制的系統如 MemcachedRedis 而言,該方法可以留空。

實現完成后使用session_set_save_handler完成session驅動的注冊

$handler = new MySessionHandler();
session_set_save_handler($handler, true);
// 下面這行代碼可以防止使用對象作為會話保存管理器時可能引發的非預期行為
register_shutdown_function("session_write_close");

session_start();
// 現在可以使用 $_SESSION 保存以及獲取數據了
Warning: 在腳本執行完畢之后, PHP內部會清除對象, 所以有可能不調用writeclose回調函數, 這樣可能會引發非預期的行為, 所以當使用對象作為會話保存管理器時, 需要通過注冊 shutdown回調函數來規避風險。通常,你可以通過調用register_shutdown_function()函數來注冊session_write_close()回調函數
d. 自定義session驅動

可通過memcachedredisdb等實現分布式session,考慮先實現redis session驅動


我們知道一般情況下cookie中存儲著session id, 所以實現自定義session, 需要一些配置, 配置如下:

參數 默認值 選項 描述
sess.driver files files/database/redis/memcached/custom 使用的存儲 session 的驅動
sess.cookie_name my_session [A-Za-z_-] characters only session cookie 的名稱
sess.expiration 7200 (2 hours) Time in seconds (integer) 你希望 session 持續的秒數 如果你希望 session 不過期(直到瀏覽器關閉),將其設置為 0
sess.save_path NULL None 指定存儲位置,取決于使用的存儲 session 的驅動
sess.time_to_update 300 Time in seconds (integer) 該選項用于控制過多久將重新生成一個新 session ID 設置為 0 將禁用 session ID 的重新生成
sess.regenerate_destroy FALSE TRUE/FALSE (boolean) 當自動重新生成 session ID 時,是否銷毀老的 session ID 對應的數據 如果設置為 FALSE ,數據之后將自動被垃圾回收器刪除

使用時, $_SESSION 的操作改為 RedisSession 類操作.

例如:

$_SESSION["aa"] = 123; 改為 RedisSession::set("aa", 123);
echo $_SESSION["aa"]; 改為 echo RedisSession::get("aa");

redis驅動實現
Warning: 由于Redis沒有鎖機制, 這個驅動的鎖是通過一個保持300s的值來模擬的。

Redis 是一種存儲引擎,通常用于緩存,并由于他的高性能而流行起來,這可能也正是你使用 Redis 驅動的原因。

缺點是它并不像關系型數據庫那樣普遍,需要你的系統中安裝了 phpredis 這個 PHP 擴展,它并不是 PHP 程序自帶的。 可能的情況是,你使用 Redis 驅動的原因是你已經非常熟悉 Redis 了并且你使用它還有其他的目的。

當然不想安裝phpredis客戶端時, 能承受一定的性能損失, 可使用predis包

https://github.com/nrk/predis

和文件驅動和數據庫驅動一樣,你必須通過 sess.save_path 參數來配置存儲 session 的位置。 這里的格式有些不同,同時也要復雜一點,這在 phpredis 擴展的 README 文件中有很好的解釋,鏈接如下:
https://github.com/phpredis/p...

Warning: 這里的 Session 類并沒有真的用到 "redis" 的 session.save_handler , 只是 采用了它的路徑的格式而已。

注意事項 a. 瀏覽器A標簽腳本執行過程中,打開B標簽訪問同一個腳本,會被pending,直到A執行完畢。
原因該腳本執行了session_start(),而php session_start()后對該session的寫入是排他的,只有當腳本執行結束或顯式執行session_destroy()才能釋放session文件鎖。
b. 自定義session驅動并不是那么簡單, 需要用到很多知識來正確的實現它。

你不僅要知道session一般的工作原理,而且要知道它在PHP中如何實現的,還要知道它的內部存儲機制是如何工作的,如何去處理并發,如何去避免死鎖(不能去掉鎖),以及如何處理潛在的安全問題

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/29259.html

相關文章

  • session與登錄機制

    摘要:每次消費時,如果顧客出示這張卡片,則此次消費就會與以前或以后的消費相聯系起來。由于可以被人為的禁止,必須有其他機制以便在被禁止時仍然能夠把傳遞回服務器。 github 地址:戳這里 session 概念 指一類用來在客戶端與服務器之間保持狀態的解決方案 這種解決方案的存儲結構 特點 由于 Session 是以文本文件形式存儲在服務器端的,所以不怕客戶端修改 Session 內容。...

    nifhlheimr 評論0 收藏0
  • 都9102年了,還問Session和Cookie的區別

    摘要:前言最近看了一些同學的面經,發現無論什么技術崗位,還是會問到和的區別。所有學技術的同學都知道和函數怎么用,知道和的區別就是是儲存在服務端的,是存儲在瀏覽器的。的誕生是為了能讓無狀態的報文帶上一些特殊的數據,讓服務端能夠辨識請求的身份。 1 前言 最近看了一些同學的面經,發現無論什么技術崗位,還是會問到 Session 和 Cookie 的區別。 所有學技術的同學都知道 Session ...

    Bowman_han 評論0 收藏0
  • Web Session 淺入淺出

    摘要:通過瀏覽器的,可以看到此次會話的請求內容和響應內容。是協議的一部分。真實的產品,一般是創建一個保證唯一的,不易猜測出來的字符串。因此需要數據持久化的多提供者的方案。 使用過幾種Web App開發語言和框架,都會接觸到Session的概念。即使是一個簡單站點訪問計數的功能,也常常使用Session來實現的。其他常用的領域還有購物車,登錄用戶等。但是,對Session一直是一知半解,知其然...

    李昌杰 評論0 收藏0
  • session和cookie機制及laravel框架下相關應用

    摘要:服務器檢查該,以此來辨認用戶狀態。五下的相關應用應用在中配置如下配置項用于設置存儲方式,默認是,即存儲在文件中,該文件位于配置項配置的路徑,即。配置項用于設置有效期,默認為分鐘。配置項用于配置數據是否加密。 一、cookie的由來 ??當用戶訪問某網站時,web服務器會將部分信息保存到本地計算機上,當用戶再次關顧該網站時,服務器會去查看用戶是否登錄過該網站,如果登錄過,就會將這些記錄在...

    NicolasHe 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<