session.gc_maxlifetime

セッション

session.gc_maxlifetimeとは?

 状態:-  閲覧数:2,312  投稿日:2017-02-10  更新日:2017-02-10  
データが 'ごみ' とみなされ、消去されるまでの秒数
・セッション有効期間はデフォルトで24分
・=1440秒
※正確には1/100の確率でこの時間

セッションのガベージコレクション (ごみの収集)
・セッション開始時に行われる

セッションの長さを変更するためには?

 閲覧数:666 投稿日:2017-02-10 更新日:2017-02-10 

手順


1.session.gc_maxlifetimeを変更

2.セッションファイルの保存先であるsession.save_pathを、サイト独自のパスへ変更
<理由>
・同じサーバーでsession.gc_maxlifetimeが短いサイトがあった場合
・そのタイミングで(サーバ側の)セッション(ファイル)を削除してしまうから
セッション内容にドメイン区別は含まれていないため、同じ保存先を指定していると、他のタイミングでの削除の影響を受ける可能性がある
注意: 異なる値を session.gc_maxlifetime に指定している 別々のスクリプトがセッションデータの保存場所を共有している場合、 一番小さい設定値に達した時点でデータが消去されます。このような場合には、 お互いに session.save_path を使用します。


セッションが切れる要件

 閲覧数:628 投稿日:2017-02-10 更新日:2017-02-10 

セッション期間を決定する各種期間


サーバ
・セッションファイル
・session.gc_maxlifetime
・デフォルトでは、1/100の確率で24分

クライント
・クッキー
session.cookie-lifetime
・デフォルトでは、0
→ ブラウザが閉じるまで有効


セッションが継続するためには?


下記何れも必要
・セッションファイル
・クッキー


セッションが切れる要件


下記何れか
・セッションファイル削除
・クッキー削除

デフォルトでは?
・ブラウザが閉じるまでクッキーは有効だが、(1/100の確率で)最短24分でセッションファイルが削除される
→ セッションは切れる


セッションの有効期間とか設定とか挙動とかを調べました
セッションタイムアウトの時間を設定する


セッションのガベージコレクション (ごみの収集)はなぜ必要なの?

 閲覧数:652 投稿日:2017-02-10 更新日:2017-02-10 

セッションファイル仕様


ユーザがアクセスする度毎にセッションファイルは繰り返し作成されていく
・セッションファイルがどんどん溜まっていく
・サーバのディスク容量を圧迫してしまう
→ 有効期限の切れた(=古くて必要のない)セッションファイルは、誰かがどこかのタイミングで必ず削除する必要がある

セッションのガベージコレクション (GC)の役割
・この「有効期限の切れたセッションファイルの削除」
・GCが起動するとsession.gc_maxlifetimeで指定した有効期限の切れたセッションファイルを全て削除してくれる

セッション(session)の有効期限を設定するには


session_start()

SessionHandler::gc

コメント投稿(ログインが必要)



週間人気ページランキング / 3-4 → 3-10
順位 ページタイトル抜粋 アクセス数
1 PHPで定数を定義する方法は2種類ある / 配列定数の定義 5
2 ブラウザを閉じたらセッションデータはどうなるの? | セッション 4
2 curl で Cookie を使用する 4
3 SQLite(エラーメッセージ) カテゴリー 3
3 Fatal error: Call to undefined method MDB2_Error::execute() in ○○ on line △△ | Fatal error(エラーメッセージ) 3
3 PHPにおけるメソッドのオーバーライドについて /「引数の数や型は、親クラスのメソッドと完全に一致していなければなりません。」とは具体的にどういう意味ですか? 3
3 「POSIX正規表現」と「PCRE正規表現」の違い 3
3 Parse error: syntax error, unexpected 'public' (T_PUBLIC) | Parse error(エラーメッセージ) 3
3 session_start() | セッション 3
4 バッファリング | 出力バッファリング制御(関数) 2
4 ブラウザを閉じたらセッションデータはどうなるの? | セッション 2
4 セッション管理が必要な理由は、HTTPプロトコルには状態を保持する機能がないため | セッション 2
4 Fatal error: Uncaught HeadlessChromium\Exception\OperationTimedOut: Operation timed out (3sec) in | Fatal error(エラーメッセージ) 2
4 Fatal error: Access level to ▲::$△ must be protected (as in class ●) or weaker | Fatal error(エラーメッセージ) 2
4 Notice(エラーメッセージ) カテゴリー 2
4 register_shutdown_function | 関数処理 関数 2
5 Fatal error: Uncaught PDOException: SQLSTATE[HY000] [2002] Connection refused | Fatal error(エラーメッセージ) 1
5 コード例 … 「例外処理」はネストすることができる 1
5 親クラスのコンストラクタは自動実行されないから、明示的に呼び出す必要がある 1
5 シリアライズ(シリアル化) | 関数 1
2025/3/11 1:01 更新