session.gc_maxlifetime

セッション

session.gc_maxlifetimeとは?

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

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

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

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

手順


1.session.gc_maxlifetimeを変更

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


セッションが切れる要件

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

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


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

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


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


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


セッションが切れる要件


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

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


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


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

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

セッションファイル仕様


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

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

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


session_start()

SessionHandler::gc

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



週間人気ページランキング / 9-10 → 9-16
順位 ページタイトル抜粋 アクセス数
1 ブラウザを閉じたらセッションデータはどうなるの? | セッション 9
1 Parse error: syntax error, unexpected 'public' (T_PUBLIC) | Parse error(エラーメッセージ) 9
2 curl で Cookie を使用する 7
3 セッション管理が必要な理由は、HTTPプロトコルには状態を保持する機能がないため | セッション 4
3 blurImageメソッド(Imagickクラス) カテゴリー 4
4 Catchable fatal error: Object of class DateTime could not be converted to string | Fatal error(エラーメッセージ) 3
4 Fatal error: Uncaught Error: Call to a member function modify() on string | Fatal error(エラーメッセージ) 3
4 Fatal error: Uncaught Error: Class 'Mecab_Tagger' not found in /var/www/★★.php:☆☆ | Fatal error(エラーメッセージ) 3
5 Warning: strlen() expects parameter 1 to be string, array given in ○○.php on line △△ | Warning(エラーメッセージ) 2
5 SQLite(エラーメッセージ) カテゴリー 2
5 Fatal error: Access level to ▲::$△ must be protected (as in class ●) or weaker | Fatal error(エラーメッセージ) 2
5 コード例 … 「例外処理」はネストすることができる 2
5 Read-only application cannot POST. | Twitter API(エラーメッセージ) 2
5 T_CONSTANT_ENCAPSED_STRING | エラーメッセージ 2
6 json_encode関数(JSON) カテゴリー 1
6 json_encode関数 | JSON 1
6 Parse error: syntax error, unexpected $end in ○○.php on line △△ | Parse error(エラーメッセージ) 1
6 or(||) | 演算子 1
6 Fatal error(エラーメッセージ) カテゴリー 1
6 ラッパークラス | クラスとオブジェクト 1
2024/9/17 1:01 更新