Springboot2のセッションタイムアウト設定が無効になる問題の解決方法
問題:
今日、プロジェクトで設定タイムアウトの問題が発生し、SpringBoot2 の application.properties の変更が反映されませんでした。
解決策:
Spring Boot によって使用される組み込みコンテナーは、server.* プロパティによって制御されます。 Spring Boot は、ServletWebServerFactory インスタンスの 1 つを使用してサーブレット コンテナのインスタンスを作成します。これらのクラスは、server.* 属性を使用して、管理対象サーブレット コンテナ (Tomcat、Jetty など) を構成します。
アプリケーションが war ファイルにパッケージ化され、Tomcat インスタンスにデプロイされる場合、server.* 属性は使用できません。事前に作成されたサーブレット コンテナを利用できるため、これらは適用されません (サービスがリモートで実行されているため)。したがって、リモート Tomcat にデプロイすると、server.* プロパティが役に立たなくなります。
1. インターネット上の投稿に従って設定ファイルを次のように変更します (Jar で起動した場合に有効になります)。 : PT1H は、セッションの有効期限を設定する時間が 1 時間であることを意味します。
Extension:Duration
スプリングブート ソース コードを表示すると、setTimeouot メソッドが見つかります。ここでは、Duration のインスタンスを渡す必要があります。
server: servlet: session: timeout: PT1H # 1小时过期 cookie: max-age: PT1H # 1小时过期
Duration は新しいですJava8 では、主に日付の差分、期間の計算に使用され、最終的に宣言され、スレッドセーフです。
文字列を変換する場合、それは SimpleDateFormat
Duration の日付書式設定メソッドに似ています。文字列は、正と負の数値に似ています。デフォルトは正で、負の値から始まります。 「-」の後に「PT」、次の時間文字が続きます:
- 'D' - day
- 'H' -時
- 'M' - 分
- 'S' - 秒
- 各ユニットは次のことを行う必要があります。数字で始まり、時と分で始まります。秒の順序を間違えることはできません。たとえば、PT2H3M2S は -PT-2H-3M-2S と同じです。
2. tomcat のセッション タイムアウトを設定します
1) tomcat の conf ディレクトリで、servler.xml を変更します:
public void setTimeout(Duration timeout) { this.timeout = timeout; }
2) プロジェクト内の web.xml を変更します:
<Context path="/abtest" docBase="/abtest" defaultSessionTimeOut="3600" isWARExpanded="true" isWARValidated="false" isInvokerEnabled="true" isWorkDirPersistent="false"/>
3) プログラムの変更
<session-config> <session-timeout>20</session-timeout> </session-config>
同じ問題が発生した場合は、上の赤い文字を読んで、順番にトラブルシューティングを行ってください。
テスト コード:
session.setMaxInactiveInterval(30*60);
時間の同期外れによる Spring セッションの失敗を引き起こす大きな穴
Spring セッションの失敗を引き起こす大きな穴Linux サーバーの時刻が同期していないためビジネス上の必要により、元のスタンドアロン環境をクラスター環境に変換し、タスクを変更しないように Spring Session Redis を選択しましたセッション共有ソリューションとして。
技術的な解決策を確認した後、インターネットで春セッションに関する多くの情報を検索し、読んだ後、前の人の落とし穴が見つからなかったので、作業を開始しました。
redis のインストール プロセスは無視されます。情報に従って、段階的にプロジェクトに Spring セッションを追加します。単一ノード プロジェクトはエラーなしで正常に実行され、セッションは Redis に正常に書き込まれました。
次に、安全のため、コンピューターに nginx をインストールし、3 つの Tomcat をデプロイしました。すべてが完璧に見え、複数のノード間でセッション共有が完了しました。
ここまでで下準備はすべて完了し、あとは最後のステップを残すだけです。
悪夢の始まり...
すべてのノードをオンラインにデプロイし、ブラウザを開いてアプリケーションに正常にアクセスします。もちろん、ページが完成したので、何としてもやらなければなりません。ログインしてログインしてください...
その後...
ユーザー パスワードを何度も入力し、ログインは成功しましたが、最終結果は依然として拒否されました。o(╥﹏╥)o
次のステップは、無数の落とし穴を埋めることです
ログを見てください...
さまざまなリクエストリクエストを見てください...
春のセッションにバグがあるのではないかと思います... ...
リモート DEBUG モードのデバッグもオンにして、最終的に確認しましたユニバーサル DEBUG モードでは、スプリング セッションが getSession を取得するときに、セッションが取得された場合、
は最初にセッションが期限切れかどうかを判断し、比較します。方法も非常に簡単で、現在のシステム時刻を取得してそれと比較します。セッションの有効期限。現在時刻が有効期限よりも小さい場合、セッションの有効期限が切れていないことを示します。これを見て、私は一瞬にして悟りのような感覚を覚え、ついにここに小宇宙が勃発したのです。 Nima—>取得したセッションがすべて期限切れになってしまい…その後…もちろん慌ててサーバー時間を確認しに行ったので…泣いてしまいましたo(╥﹏╥)o 、それはニマだった 私を騙したのはあなただった...
この罠に横たわる旅を記念するために、この記事を投稿します
さらに, ちなみに、Linux サーバーの時刻同期を記録しますdate コマンド:
date : 現在時刻を表示すると、結果は次のようになります。火曜日 3 月 4 01:36:45 CST 2017
date -s 09:38:40 : 現在の時刻を設定します。結果は次のようになります: 火曜日 3 月 4 09:38:40 CST 2017
ntpdate コマンド:ntpdate -u ntp.api.bz :ネットワーク時刻同期コマンド
ntp よく使用されるサーバー:中国国家時刻サービスセンター: 210.72.145.44
NTP サーバー (上海): ntp.api.bz
以上がSpringboot2のセッションタイムアウト設定が無効になる問題の解決方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









1. Redis は分散ロックの原則を実装しており、分散ロックが必要な理由 分散ロックについて話す前に、分散ロックが必要な理由を説明する必要があります。分散ロックの反対はスタンドアロン ロックです。マルチスレッド プログラムを作成するとき、共有変数を同時に操作することによって引き起こされるデータの問題を回避します。通常、ロックを使用して共有変数を相互に除外し、データの正確性を確保します。共有変数の使用範囲は同じプロセス内です。共有リソースを同時に操作する必要があるプロセスが複数ある場合、どうすれば相互排他的になるのでしょうか?今日のビジネス アプリケーションは通常マイクロサービス アーキテクチャであり、これは 1 つのアプリケーションが複数のプロセスをデプロイすることも意味します。複数のプロセスが MySQL の同じレコード行を変更する必要がある場合、順序の乱れた操作によって引き起こされるダーティ データを避けるために、分散が必要です。今回導入するスタイルはロックされています。ポイントを獲得したい

セッション障害は通常、セッションの有効期間の期限切れまたはサーバーのシャットダウンによって発生します。解決策: 1. セッションの有効期間を延長する; 2. 永続ストレージを使用する; 3. Cookie を使用する; 4. セッションを非同期的に更新する; 5. セッション管理ミドルウェアを使用する。

Springboot はファイルを読み取りますが、jar パッケージにパッケージ化した後、最新の開発にアクセスできません。jar パッケージにパッケージ化した後、Springboot がファイルを読み取れない状況があります。その理由は、パッケージ化後、ファイルの仮想パスが変更されるためです。は無効であり、ストリーム経由でのみアクセスできます。読み取ります。ファイルはリソースの下にあります publicvoidtest(){Listnames=newArrayList();InputStreamReaderread=null;try{ClassPathResourceresource=newClassPathResource("name.txt");Input

PHPSession のクロスドメイン問題の解決策 フロントエンドとバックエンドの分離の開発では、クロスドメイン要求が標準になっています。クロスドメインの問題に対処するときは、通常、セッションの使用と管理が必要になります。ただし、ブラウザーのオリジンポリシーの制限により、デフォルトではセッションをドメイン間で共有できません。この問題を解決するには、いくつかの技術と方法を使用して、セッションのクロスドメイン共有を実現する必要があります。 1. ドメイン間でセッションを共有するための Cookie の最も一般的な使用法

SpringBoot と SpringMVC はどちらも Java 開発で一般的に使用されるフレームワークですが、それらの間には明らかな違いがいくつかあります。この記事では、これら 2 つのフレームワークの機能と使用法を調べ、その違いを比較します。まず、SpringBoot について学びましょう。 SpringBoot は、Spring フレームワークに基づいたアプリケーションの作成と展開を簡素化するために、Pivotal チームによって開発されました。スタンドアロンの実行可能ファイルを構築するための高速かつ軽量な方法を提供します。

1. RedisAPI のデフォルトのシリアル化メカニズムである RedisTemplate1.1 をカスタマイズします。API ベースの Redis キャッシュ実装では、データ キャッシュ操作に RedisTemplate テンプレートを使用します。ここで、RedisTemplate クラスを開いて、クラスのソース コード情報を表示します。publicclassRedisTemplateextendsRedisAccessorimplementsRedisOperations、BeanClassLoaderAware{//キーを宣言、値の各種シリアル化メソッド、初期値は空 @NullableprivateRedisSe

プロジェクトでは、構成情報が必要になることがよくありますが、この情報はテスト環境と本番環境で構成が異なる場合があり、実際のビジネス状況に基づいて後で変更する必要がある場合があります。これらの構成をコードにハードコーディングすることはできません。構成ファイルに記述することをお勧めします。たとえば、この情報を application.yml ファイルに書き込むことができます。では、コード内でこのアドレスを取得または使用するにはどうすればよいでしょうか?方法は2つあります。方法 1: @Value アノテーションが付けられた ${key} を介して、構成ファイル (application.yml) 内のキーに対応する値を取得できます。この方法は、マイクロサービスが比較的少ない状況に適しています。方法 2: 実際には、プロジェクト、業務が複雑な場合、ロジック

この記事では、dubbo+nacos+Spring Boot の実際の開発について詳しく説明する例を書きます。この記事では理論的な知識はあまり取り上げませんが、dubbo を nacos と統合して開発環境を迅速に構築する方法を説明する最も簡単な例を書きます。
