HibernateはJavaトランザクションの開始時に悲観的ロックを実装できますか、それともJavaレルムでのすべての作業が完了したときに適用される悲観的ロックに依存し、変更はデータベーストランザクションの一部としてデータベースに適用されますか? ?
リモートWebサービスへの呼び出しが行われる途中のJavaトランザクションがあるので、これは非トランザクションであるため、ロールバックできません。Hibernateが処理対象のデータに対して悲観的なロックを保持している場合、Hibernateは別のスレッドがそれらのデータにすでに動作していることを認識しているため、トランザクションの処理をブロックする必要があります。Hibernateがそのようなロック自体を追跡しない場合、Javaトランザクションは続行され、Webサービスが呼び出され、DBコミットがブロックされます。
私が本当にやりたいのは、Javaトランザクションを開始し、別のスレッドが別のトランザクションを開始しようとし、関連するデータに対してすでに進行中のトランザクションがあるため、ブロック/失敗することです。
HibernateがEHCacheを2LCとしてTerracottaと分散して使用する場合、ロック動作はどのように影響を受けますか?