検索
ホームページJava&#&チュートリアルSpringBoot が Spring Session を統合して分散セッションを実装する方法

Spring は、分散セッションを処理するためのソリューションである Spring-Session を提供します。 Spring-Session は、Redis、MongoDB、MySQL などの共通ストレージのサポートを提供します。Spring-Session は、HttpSession との透過的な統合を提供します。つまり、開発者は Spring-Session でサポートされる実装を使用して、HttpSession を Spring-Session に切り替えることができます。

1. 構成と開発

ステップ 1. 依存関係の追加

Redis と Spring-Session の依存関係を pom.xml ファイルに追加します。プロジェクトバッグ。

        <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session-data-redis</artifactId>
        </dependency>

ステップ 2. Redis と Spring-Session の永続化メソッドを構成する

作者は、SpringBoot 構成ファイルとして application.properties を使用することに慣れています。または、application.properties を使用することもできます。 .yml を設定に追加します。 application.properties 構成ファイルに次の構成を追加します。

# 配置 Redis 服务器地址(此处是一个虚假地址)
spring.redis.host=10.211.12.6
# 配置 Redis 端口
spring.redis.port=6379
# 配置 Redis 密码
spring.redis.password=123456
# 其他 Redis 的配置还有很多,例如 Redis 连接池的配置,此处暂时只配置上述几项关键点
# spring session 配置
spring.session.store-type=redis

ステップ 3. JSON シリアル化メカニズムを使用する

Spring-Session はデフォルトで JDK シリアル化メカニズムを使用します。これには、クラスが Serializable インターフェイスとシリアル化を実装する必要があります。はバイナリバイトです 配列は理解するのが難しいです。 JSON シリアル化メカニズムを使用すると、シリアル化された文字列が理解しやすくなります。

package com.test.conf;

import com.alibaba.fastjson.support.spring.GenericFastJsonRedisSerializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.serializer.RedisSerializer;

// spring session 使用 json 序列化机制
@Configuration
public class SessionConfig {
    @Bean
    public RedisSerializer<Object> springSessionDefaultRedisSerializer() {
        return new GenericFastJsonRedisSerializer();
    }
}

#ステップ 4. @EnableRedisHttpSession アノテーションを SpringBoot スタートアップ クラスに追加して Spring-Session を開きます

package com.test;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

@SpringBootApplication
// 开启 Spring-Session
@EnableRedisHttpSession
// @EnableRedisHttpSession(maxInactiveIntervalInSeconds = 1800, redisNamespace = "test:session")
public class TestSessionAppApplication {

    public static void main(String[] args) {
        SpringApplication.run(TestSessionAppApplication.class, args);
    }
}

@EnableRedisHttpSession アノテーションを追加して Spring-Session を開きます。アノテーションには個別に設定できるいくつかのパラメータがあり、その中で、maxInactiveIntervalInSeconds はセッションの有効期限を表し、デフォルト値は 30 分です。redisNamespace は、セッションが Redis に保存されるときの名前空間、つまり、保存されたセッションのキー名のプレフィックスを表します。 Redis では、デフォルト値は "spring :session" ですが、実際のプロジェクトでは、リソースを節約するために異なるシステムが同じ Redis を使用する場合があります。異なるシステムのセッションを区別するために、システムごとに個別の名前空間を設定できます。

2. テスト

2.1 コントローラー層の書き込みテストデモ

    @RequestMapping(value = "testSession")
    public String testSession(HttpServletRequest request) {
        HttpSession session = request.getSession();
        log.info("sessionId:[{}]", session.getId());
        session.setAttribute("name", "Lucy");
        session.setAttribute("age", "20");
        return session.getAttribute("name").toString();
    }

2.2 テストプロセス

同時に、別のポート 9001 で SpringBoot プロジェクトを開始します。 /9002. ローカル コンピューター上の分散クラスター内のさまざまなノードをシミュレートします。 Google Chrome を使用してリンク http://localhost:9001/testSession を開くと、サーバーは次のようなログを出力します。

sessionId:[5c417104-4f6d-430d-b569-cbc1e19cdf02]

クライアントは Redis サーバーにログインし、Redis のセッション コンテンツを表示します。

[testuser@vm ~]$ redis-cli -h 10.211.12.6 -p 6379
10.211.12.6:6379> auth 123456
OK
10.211.12.6:6379> keys *
1) "spring:session:expirations:1658127780000"
2) "spring:session:sessions:5c417104-4f6d-430d-b569-cbc1e19cdf02"
3) "spring:session:sessions:expires:5c417104-4f6d-430d-b569-cbc1e19cdf02"

Redis は、RedisSession ごとに 3 つのキーと値のペア (以下、キーと値と呼びます) を保存します。

  • 最初のキーと値には、この RedisSession の ID が保存されます。 Session. は、Set タイプの Redis データ構造です。このキーの最後の値 1658127780000 は、次の分にロールアウトされたセッション有効期限の瞬間に基づいて計算されたタイムスタンプです。

  • 2 番目の Key-Value はセッションの詳細情報を格納するために使用され、セッションの最新アクセス時刻 (lastAccessedTime) とセッションの最新アクセス時刻 (lastAccessedTime) を含むハッシュ型 Redis データ構造です。有効期限間隔 (maxInactiveInterval)、デフォルトは 30 分、ここに保存される秒の値)、作成時間 (creationTime)、sessionAttr など。

  • 3 番目のキーと値は、Redis でのセッションの有効期限を表すために使用され、文字列型の Redis データ構造です。この Key-Value には有用なデータは格納されず、セッションの有効期限を示すためにのみ設定されます。 Redis でのこのキーの有効期限は、セッションの有効期限間隔です。ttl コマンドを使用すると、キーの有効期限、つまりセッションの有効期限を表示できます。

このテスト中の、Redis 内のデータの詳細は次のとおりです。

10.211.12.6:6379> type spring:session:expirations:1658127780000
set
10.211.12.6:6379> smembers spring:session:expirations:1658127780000
1) "\"expires:5c417104-4f6d-430d-b569-cbc1e19cdf02\""
10.211.12.6:6379>
10.211.12.6:6379> type spring:session:sessions:5c417104-4f6d-430d-b569-cbc1e19cdf02
hash
10.211.12.6:6379> hgetall spring:session:sessions:5c417104-4f6d-430d-b569-cbc1e19cdf02
 1) "lastAccessedTime"
 2) "1658125969794"
 3) "maxInactiveInterval"
 4) "1800"
 5) "creationTime"
 6) "1658125925139"
 7) "sessionAttr:age"
 8) "\"20\""
 9) "sessionAttr:name"
10) "\"Lucy\""
10.211.12.6:6379>
10.211.12.6:6379> type spring:session:sessions:expires:5c417104-4f6d-430d-b569-cbc1e19cdf02
string
10.211.12.6:6379> get spring:session:sessions:expires:5c417104-4f6d-430d-b569-cbc1e19cdf02
""
10.201.42.26:6379>

ブラウザの Cookie を確認する この時点では、次の図に示すように、ブラウザにはすでに Cookie が使用されています。

SpringBoot怎么整合Spring Session实现分布式会话

ブラウザを更新すると、バックエンドによって出力される SessionId は変更されず、Redis のセッション コンテンツは追加されず、ブラウザは通常どおりコンテンツを返します。これは、このノードのセッション動作が正常であることを意味します。

同じブラウザで、別のテスト ポート リンク http://localhost:9002/testSession を開きます。ブラウザは自動的に Cookie を運びます。バックエンドの印刷コンテンツと Redis コンテンツは同じです (有効期限はが更新されました)。これは、クラスター セッションがノード間で共有されていることを示します。

3. Spring-Session の欠点

Spring-Session は、クラスター セッションのサポートを簡単にする、使いやすく、ほぼ透過的な統合方法を提供しますが、実際、Spring-Session にはいくつかの欠陥があります。 。

  • セッションの有効期限切れイベントと破棄イベントをリアルタイムで公開することは不可能です。

  • シリアル化メソッドは、一部の特定のタイプではサポートされていない可能性があります。セッション。あまり良くありません;

  • Redis はセッションを保存するために 3 つのキー値を必要とするため、若干多くのスペースを必要とします;

  • In高い同時実行性のシナリオ。セッションは CAS (比較および設定) 操作ではないため、いくつかの同時実行性の問題 (軽微な問題) が発生する可能性があります。

Spring-Session にはいくつかの欠点がありますが、全体的にはまだ非常に使いやすいです。さらに、一連のフィルターを自分で作成して Spring-Session の欠点を最適化し、分散セッションを実装することもできます。

以上がSpringBoot が Spring Session を統合して分散セッションを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事は亿速云で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
Javaがクロスプラットフォームデスクトップアプリケーションを開発するための人気のある選択肢なのはなぜですか?Javaがクロスプラットフォームデスクトップアプリケーションを開発するための人気のある選択肢なのはなぜですか?Apr 25, 2025 am 12:23 AM

javaispopularforsoss-platformdesktopapplicationsduetoits "writeonce、runaynay" philosophy.1)itusesbytecodatiTatrunnanyjvm-adipplatform.2)ライブラリリケンディンガンドジャヴァフククレアティック - ルルクリス

Javaでプラットフォーム固有のコードを作成する必要がある場合がある状況について話し合います。Javaでプラットフォーム固有のコードを作成する必要がある場合がある状況について話し合います。Apr 25, 2025 am 12:22 AM

Javaでプラットフォーム固有のコードを作成する理由には、特定のオペレーティングシステム機能へのアクセス、特定のハードウェアとの対話、パフォーマンスの最適化が含まれます。 1)JNAまたはJNIを使​​用して、Windowsレジストリにアクセスします。 2)JNIを介してLinux固有のハードウェアドライバーと対話します。 3)金属を使用して、JNIを介してMacOSのゲームパフォーマンスを最適化します。それにもかかわらず、プラットフォーム固有のコードを書くことは、コードの移植性に影響を与え、複雑さを高め、パフォーマンスのオーバーヘッドとセキュリティのリスクをもたらす可能性があります。

プラットフォームの独立性に関連するJava開発の将来の傾向は何ですか?プラットフォームの独立性に関連するJava開発の将来の傾向は何ですか?Apr 25, 2025 am 12:12 AM

Javaは、クラウドネイティブアプリケーション、マルチプラットフォームの展開、および言語間の相互運用性を通じて、プラットフォームの独立性をさらに強化します。 1)クラウドネイティブアプリケーションは、GraalvmとQuarkusを使用してスタートアップ速度を向上させます。 2)Javaは、埋め込みデバイス、モバイルデバイス、量子コンピューターに拡張されます。 3)Graalvmを通じて、JavaはPythonやJavaScriptなどの言語とシームレスに統合して、言語間の相互運用性を高めます。

Javaの強力なタイピングは、プラットフォームの独立性にどのように貢献しますか?Javaの強力なタイピングは、プラットフォームの独立性にどのように貢献しますか?Apr 25, 2025 am 12:11 AM

Javaの強力なタイプ化されたシステムは、タイプの安全性、統一タイプの変換、多型を通じてプラットフォームの独立性を保証します。 1)タイプの安全性は、コンパイル時間でタイプチェックを実行して、ランタイムエラーを回避します。 2)統一された型変換ルールは、すべてのプラットフォームで一貫しています。 3)多型とインターフェイスメカニズムにより、コードはさまざまなプラットフォームで一貫して動作します。

Javaネイティブインターフェイス(JNI)がプラットフォームの独立性をどのように妥協できるかを説明します。Javaネイティブインターフェイス(JNI)がプラットフォームの独立性をどのように妥協できるかを説明します。Apr 25, 2025 am 12:07 AM

JNIはJavaのプラットフォームの独立を破壊します。 1)JNIは特定のプラットフォームにローカルライブラリを必要とします。2)ローカルコードをターゲットプラットフォームにコンパイルおよびリンクする必要があります。3)異なるバージョンのオペレーティングシステムまたはJVMは、異なるローカルライブラリバージョンを必要とする場合があります。

Javaのプラットフォームの独立性を脅かしたり強化したりする新しいテクノロジーはありますか?Javaのプラットフォームの独立性を脅かしたり強化したりする新しいテクノロジーはありますか?Apr 24, 2025 am 12:11 AM

新しいテクノロジーは、両方の脅威をもたらし、Javaのプラットフォームの独立性を高めます。 1)Dockerなどのクラウドコンピューティングとコンテナ化テクノロジーは、Javaのプラットフォームの独立性を強化しますが、さまざまなクラウド環境に適応するために最適化する必要があります。 2)WebAssemblyは、Graalvmを介してJavaコードをコンパイルし、プラットフォームの独立性を拡張しますが、パフォーマンスのために他の言語と競合する必要があります。

JVMのさまざまな実装は何ですか、そしてそれらはすべて同じレベルのプラットフォームの独立性を提供しますか?JVMのさまざまな実装は何ですか、そしてそれらはすべて同じレベルのプラットフォームの独立性を提供しますか?Apr 24, 2025 am 12:10 AM

JVMの実装が異なると、プラットフォームの独立性が得られますが、パフォーマンスはわずかに異なります。 1。OracleHotspotとOpenJDKJVMは、プラットフォームの独立性で同様に機能しますが、OpenJDKは追加の構成が必要になる場合があります。 2。IBMJ9JVMは、特定のオペレーティングシステムで最適化を実行します。 3. Graalvmは複数の言語をサポートし、追加の構成が必要です。 4。AzulzingJVMには、特定のプラットフォーム調整が必要です。

プラットフォームの独立性は、開発コストと時間をどのように削減しますか?プラットフォームの独立性は、開発コストと時間をどのように削減しますか?Apr 24, 2025 am 12:08 AM

プラットフォームの独立性により、開発コストが削減され、複数のオペレーティングシステムで同じコードセットを実行することで開発時間を短縮します。具体的には、次のように表示されます。1。開発時間を短縮すると、1セットのコードのみが必要です。 2。メンテナンスコストを削減し、テストプロセスを統合します。 3.展開プロセスを簡素化するための迅速な反復とチームコラボレーション。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、