SpringBoot で Spring Session を使用して分散セッション共有の問題を解決する

SpringBoot で Spring Session を使用して分散セッション共有の問題を解決する

序文

Java を使用して Web アプリケーションを開発している場合は、HttpSession に非常に精通しているはずですが、HpptSession はデフォルトでメモリを使用してセッションを管理することが知られています。アプリケーションがスケールアウトされると、セッション共有の問題が発生してしまいます。

Spring Session は、セッション共有の問題を解決するために、Servlet HttpSession を作成および管理するためのソリューションを提供します。さらに重要なのは、Spring Boot で使用するのが非常に簡単だということです。

セッション共有の問題

HttpSession は、メモリに保存される Tomcat/Jetty などのサーブレット コンテナーによって作成および管理されます。 Web アプリケーションを分散クラスターにスケールアウトし、負荷分散に LVS または Nginx を使用すると、同じユーザーからの HTTP 要求が 2 つの異なるインスタンスに分散される可能性があります。異なるインスタンス間でセッション共有を確実に行う方法が、解決しなければならない問題になります。

最も簡単な解決策は、セッション データを Memcached/Redis などのメモリ外の統一された場所に保存することです。すると、HttpSession の作成と管理の Servlet コンテナの実装をどのように置き換えるかという疑問が再び生じます。

  1. Servlet コンテナによって提供されるプラグイン機能を使用して、HttpSession の作成および管理戦略をカスタマイズし、構成を通じてデフォルトの戦略を置き換えます。ただし、この方法には、Tomcat/Jetty などの Servlet コンテナのコー​​ドと組み合わせる必要があるという欠点があります。実際、この分野では、memcached-session-manager や tomcat-redis-session-manager などのオープンソース プロジェクトが長い間存在してきました。現在、Tomcat6/Tomcat7 のみがサポートされています。

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> タグを追加してください)

  1. <依存関係>    
  2. <グループID> org.springframework.boot</グループID>    
  3. <artifactId> spring- boot -starter- data - redis </artifactId>    
  4. </依存関係>    
  5. <依存関係>    
  6. <グループID> org.springframework.session</グループID>    
  7. <artifactId>スプリング-セッション</artifactId>    
  8. </依存関係>  

2. Spring アプリケーションを構成し、application.properties に次の構成を追加します。

  1. spring.session.store-type = redis  

これら 2 つの手順だけで統合が完了し、プロセス全体が完全にスムーズかつシームレスになります。

注: Redis サーバーがローカルのデフォルト設定 (localhost:6379) を使用していない場合は、Redis を設定する必要があります。どのように設定するのですか?ここを見て下さい。

検証してみましょう〜

確かに、Http Session は Spring Session によってパッケージ化されており、プログラミングには引き続き Http Session API を使用できます。

クッキーも通常通り作成され、キーは SESSION です。

  1. 127.0.0.1:6379 >キー *  
  2. 1) 「spring:session:sessions:083706a8-b2d8-480c-8b88-eafc798e7269」  
  3. 2) 「spring:session:sessions:expires:083706a8-b2d8-480c-8b88-eafc798e7269」  
  4. 3) 「spring:session:expirations:1490263320000」

redis-cli を使用して、関連データも Redis に保存されていることを確認します。

<<:  医療機関は、データセキュリティとコンプライアンスをハイブリッドクラウド導入の主要要因として挙げている。

>>:  Mafengwo ビッグデータ プラットフォームにおける Kafka クラスターの最適化とアプリケーション拡張

推薦する

全国の人々がオンラインで授業を受けたり仕事をしたりしていますが、Alibaba Cloud はトラフィックのピークにも耐えています。

「仕事は中止するがビジネスは中止しない」そして「授業は中止するが学習は中止しない」。 2月10日は学...

インケライブが軌道変更

生放送トラックにおける「斗魚と虎牙」の二強パターンはなかなか破れず、変革を求める英客は社交分野に根を...

共同購入サイトはマイナス成長が続いており、中小規模の共同購入の状況は懸念される。

共同購入サイトの数は3月に357件減少し、半年間で約1,000件減少した。 Admin5 Webma...

この記事ではPythonの分散プロセスインターフェースを紹介します

[[399138]] 1. はじめにスレッドとプロセスの間では、プロセスの方が安定しており、複数のマ...

WeChatチーム:偽造アカウントや著作権侵害アカウントに対処するため、マーケティングアカウントの連絡先数を制限します

さらに読む:フォローできるWeChatの友達と公開アカウントの数は5,000人に制限されていますWe...

あなたはまだ Google の PR 価値を重視していますか?それはもう重要ではないかもしれません。

最近、GoogleのPRアップデートにより、主要なウェブマスターフォーラムやQQグループのウェブマス...

SEOが人生から高品質のオリジナルコンテンツを改善する方法

今日、Weiboで莫言さんのスピーチ「ストーリーテラー」を見ましたが、とても感動しました。これは人生...

ソーシャルメディア配信ガイド!

有名人に説得されて何か買ったことはありますか?答えが「はい」であれば、それは普通のことです。私たちは...

デュアルプラットフォームがデジタルコマースをリードし、Yunxi Technologyは包括的なデジタルマーケティングソリューションを作成します

最近、「デジタル変革と未来のインテリジェント創造」をテーマにしたIT中国市場年次会議において、中国の...

Amazon クラウド テクノロジーにより、Yidiantianxia は AIGC の波の中で新しいマーケティング パラダイムを構築できるようになりました。

生成的 人工知能 それがもたらす熱狂は継続し、すべての人の思考を刺激し続けます。今日の「百モデル戦争...

Kubernetes が Docker を放棄するのはなぜですか?

[[403553]]画像はPexelsよりしかし、2020 年 12 月に、Kubernetes コ...

マルチクラウドへの移行の鍵は管理ツール

企業がクラウドに移行することは今やコンセンサスとなっており、さらに多くの企業が複数のクラウド プラッ...

2host-6USD/512M メモリ/xen/G ポート/sanjose

2host、ONEMAN IDC は 2009 年に設立され、VPS、サーバー、ホスティングを提供し...