序文 Java を使用して Web アプリケーションを開発している場合は、HttpSession に非常に精通しているはずですが、HpptSession はデフォルトでメモリを使用してセッションを管理することが知られています。アプリケーションがスケールアウトされると、セッション共有の問題が発生してしまいます。 Spring Session は、セッション共有の問題を解決するために、Servlet HttpSession を作成および管理するためのソリューションを提供します。さらに重要なのは、Spring Boot で使用するのが非常に簡単だということです。 セッション共有の問題 HttpSession は、メモリに保存される Tomcat/Jetty などのサーブレット コンテナーによって作成および管理されます。 Web アプリケーションを分散クラスターにスケールアウトし、負荷分散に LVS または Nginx を使用すると、同じユーザーからの HTTP 要求が 2 つの異なるインスタンスに分散される可能性があります。異なるインスタンス間でセッション共有を確実に行う方法が、解決しなければならない問題になります。 最も簡単な解決策は、セッション データを Memcached/Redis などのメモリ外の統一された場所に保存することです。すると、HttpSession の作成と管理の Servlet コンテナの実装をどのように置き換えるかという疑問が再び生じます。
2. Nginx の負荷分散アルゴリズムを ip_hash に設定し、各リクエストがアクセス IP のハッシュ結果に従って割り当てられるようにします。この方法では、同じ IP アドレスからの訪問者は固定のバックエンド サーバーにアクセスするため、動的 Web ページのセッション共有の問題が効果的に解決されます。 3. Shiro を使用してセッションを管理する場合は、Redis を使用して Shiro の SessionDao インターフェースを実装し、セッションが Redis によって管理されるようにすることができます。 4. フィルターを設計し、HttpServletRequestWrapper を使用し、独自の getSession() メソッドを実装して、セッション データの作成と管理の作業を引き継ぎます。 Spring-Session はこのアイデアに基づいて実装されます。 Spring Boot に Spring Session を統合する Spring Session は、セッションを保存するために Redis、Mongo、JDBC、Hazelcast の使用をサポートしています。ここでは、Redis を例として使用します。 1. Maven 依存関係を導入します (この例では dependencyManagement を使用していますが、使用しない場合は <version> タグを追加してください)
2. Spring アプリケーションを構成し、application.properties に次の構成を追加します。
これら 2 つの手順だけで統合が完了し、プロセス全体が完全にスムーズかつシームレスになります。 注: Redis サーバーがローカルのデフォルト設定 (localhost:6379) を使用していない場合は、Redis を設定する必要があります。どのように設定するのですか?ここを見て下さい。 検証してみましょう〜 確かに、Http Session は Spring Session によってパッケージ化されており、プログラミングには引き続き Http Session API を使用できます。 クッキーも通常通り作成され、キーは SESSION です。
redis-cli を使用して、関連データも Redis に保存されていることを確認します。 |
<<: 医療機関は、データセキュリティとコンプライアンスをハイブリッドクラウド導入の主要要因として挙げている。
>>: Mafengwo ビッグデータ プラットフォームにおける Kafka クラスターの最適化とアプリケーション拡張
単一のクラウドで十分なのに、盲目的にマルチクラウドを追求するのは、「なぜ肉を食べないのか」というよう...
ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービスSEO最適化に特化したウ...
Liuyi Cloud は、主にクラウド サーバー、仮想ホスト、CDN、高防御サービスを提供する中国...
ビジネスが成長するにつれて、コンピューティング インフラストラクチャの拡大によって障害のリスク ポイ...
この記事を読んでいるあなたは、次のような状況に陥っているかもしれません。Web サイトを更新する必要...
著者: Yu Leichun、PaaS 製品部門、中国モバイル クラウド機能センター前回の記事では、...
justhost から良いニュースが届きました: (1) すべての VPS は、トラフィック制限なし...
この記事は、NetEase Cloud Music のリアルタイム コンピューティング プラットフォ...
今日は、クラウド ネイティブ時代においても Spring が優れたプラットフォームの 1 つであり続...
私は DigitalOcean から KVM ベースの VPS を購入しました。中国にとても優しいサ...
1. LVSと負荷分散の概要: LVS はLinux Virtual Serverの略で、 Linu...
カナダに登録された会社(NEQ # 2266846825)であるservaricaは、多くの方がご存...
業界の業務再開を支援するため、Tencent Cloud Server(VPS)は現在スーパープロモ...
ウェブサイトのコンテンツはなぜそれほど重要なのでしょうか?コンテンツは王様、外部リンクは女王様です。...
黄金の秋、収穫の季節がやって来ます。最近、江蘇省北部の有名な地方ポータルの責任者らが台州に集まり、地...