session.gc_maxlifetime

セッション

session.gc_maxlifetimeとは?

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

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

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

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

手順


1.session.gc_maxlifetimeを変更

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


セッションが切れる要件

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

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


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

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


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


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


セッションが切れる要件


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

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


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


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

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

セッションファイル仕様


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

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

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


session_start()

SessionHandler::gc

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



週間人気ページランキング / 5-3 → 5-9
順位 ページタイトル抜粋 アクセス数
1 http_build_queryとは? / 構文 /パラメータ 4
2 Parse error: syntax error, unexpected end of file | Parse error(エラーメッセージ) 3
2 Warning: strlen() expects parameter 1 to be string, array given in ○○.php on line △△ | Warning(エラーメッセージ) 3
3 ブラウザを閉じたらセッションデータはどうなるの? | セッション 2
3 PHPにおけるメソッドのオーバーライドについて /「引数の数や型は、親クラスのメソッドと完全に一致していなければなりません。」とは具体的にどういう意味ですか? 2
3 Fatal error: require_once(): Failed opening required 'PEAR.php' | Fatal error(エラーメッセージ) 2
3 Fatal error: Uncaught PDOException: SQLSTATE[HY000] [2002] Connection refused | Fatal error(エラーメッセージ) 2
3 エラーメッセージ 2
3 Fatal error: Uncaught Error: Call to a member function modify() on string | Fatal error(エラーメッセージ) 2
3 Parse error: syntax error, unexpected 'public' (T_PUBLIC) | Parse error(エラーメッセージ) 2
3 Warning: Unexpected character in input: '\' (ASCII=92) state=1 in ○○.php on line △△ | Warning(エラーメッセージ) 2
3 セッション管理が必要な理由は、HTTPプロトコルには状態を保持する機能がないため | セッション 2
4 実際に遭遇した例 1
4 session.cookie_lifetime / session.use_cookies | セッション 1
4 コード例 … 「例外処理」はネストすることができる 1
4 Fatal error: Uncaught Error: Class 'Stripe\Checkout\Session' not found | Fatal error(エラーメッセージ) 1
4 session_start() | セッション 1
4 デバッグ カテゴリー 1
4 「try~catch」「set_error_handler」を組み合わせるメリット 1
4 Fatal error: Access level to ▲::$△ must be protected (as in class ●) or weaker | Fatal error(エラーメッセージ) 1
2025/5/10 1:01 更新