私はspring framework、apache、tomcat を使用しています。ログインページはスプリングセキュリティ で処理されており、ログインページへの最初のリクエストでユーザーのために新しいセッションが生成されるという問題 があります。デフォルトの動作では、ログインページにアクセスすると新しいセッションが作成され、ログインページに大きな負荷がかかった場合、何もせずにログインページを見ているユーザーが多すぎるため、ここに作成されます。 あなたはちょうど問題について考えていますが、私はそれがまれであることは知っていますが、それはどう対処するのでしょうか?ログインページにアクセスするとセッションが多すぎますか?
3
A
答えて
2
私はそれがまれだとは思わない。 1つの可能な溶質は、セッションタイムアウトを最小に設定することです。たとえば5分です。さらに、ユーザーがセッションがすでに存在する場合は、セッションのタイムアウトを増やすためのフィルタを作成できます。したがって、通常のユーザーは30分のセッションタイムアウトを持ち、ユーザーは片側のみを訪問して5分のタイムアウトを持ちます。ここで
は、トリックを用量フィルタである:
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpRequest = (HttpServletRequest)request;
// The false is important, otherwise a new session will be created.
HttpSession session = httpRequest.getSession(false);
if (session == null) {
chain.doFilter(request, response);
return;
}
session.setMaxInactiveInterval(30 * 60);
chain.doFilter(request, response);
}
もう一つの良いアドバイスは、Googleのボットのようなクローラをフィルタリングすることです。 "Bot Detection"は検索するのに適したキーワードです。
関連する問題
- 1. ValueError:タプル数が多すぎるとアンパックする値が多すぎます
- 2. URLが多すぎるためにウェブサイトにアクセスしました
- 3. アンドロイドにタイムアウトが多すぎますか?
- 4. ASP.NETセッションが大きすぎますか?
- 5. フレームワークと言語が多すぎます
- 6. ドッカーマウントが多すぎます
- 7. ブートストラップオプションが多すぎます
- 8. CUDAが多すぎます
- 9. リダイレクトが多すぎます
- 10. エコーが多すぎます
- 11. "オープンファイルが多すぎます"
- 12. CakePHP Authが多すぎるセッション変数を読み込む
- 13. MySQLのフィールドが多すぎますか?
- 14. エンティティが多すぎますか?
- 15. IOSでリダイレクトが多すぎますか?
- 16. Djangoのテンプレートタグが多すぎますか?
- 17. XMLのビューが多すぎますか?
- 18. dumpdata、引数が多すぎますか?
- 19. MySQL:「接続が多すぎますか?」
- 20. Java - BigDecimalsが多すぎますか?
- 21. NSTimersの数が多すぎますか?
- 22. 開始アクティビティが多すぎますか?
- 23. クッキーが多すぎますか?
- 24. タスクの数が多すぎますか?
- 25. Python - elif:return()文が多すぎますか?
- 26. モバイルサファリのSVGが多すぎますか?
- 27. JSONの量が多すぎますか?
- 28. EJBの数が多すぎますか?
- 29. Composerを使用するとファイルが多すぎますか?
- 30. JSF 1.2:小さすぎるセッションBeanが多すぎる:それは悪いのですか代替手段
ログインしているユーザーがセッションを既に持っていて、彼が5分間アイドル状態になっている場合、セッションも破棄されますか? –
はい、ユーザーがリクエストを1回だけ行うとします。これ以上の要求があれば、タイムアウトは30 * 60秒に延長されます。 – scheffield
偉大な、私は別のアプリで私が持っていた、別の問題を抱えている、使用時間0と多くのセッションがあります、どのようにもそれらを管理するには? –