All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.quarkus.narayana.jta.runtime.TransactionManagerBuildTimeConfig Maven / Gradle / Ivy

There is a newer version: 3.17.0
Show newest version
package io.quarkus.narayana.jta.runtime;

import java.util.Optional;

import io.quarkus.runtime.annotations.ConfigItem;
import io.quarkus.runtime.annotations.ConfigPhase;
import io.quarkus.runtime.annotations.ConfigRoot;

@ConfigRoot(phase = ConfigPhase.BUILD_TIME)
public final class TransactionManagerBuildTimeConfig {
    /**
     * Define the behavior when using multiple XA unaware resources in the same transactional demarcation.
     * 

* Defaults to {@code fail}. * {@code warn-each}, {@code warn-first}, and {@code allow} are UNSAFE and should only be used for compatibility. * Either use XA for all resources if you want consistency, or split the code into separate * methods with separate transactions. *

* Note that using a single XA unaware resource together with XA aware resources, known as * the Last Resource Commit Optimization (LRCO), is different from using multiple XA unaware * resources. Although LRCO allows most transactions to complete normally, some errors can * cause an inconsistent transaction outcome. Using multiple XA unaware resources is not * recommended since the probability of inconsistent outcomes is significantly higher and * much harder to recover from than LRCO. For this reason, use LRCO as a last resort. *

* We do not recommend using this configuration property, and we plan to remove it in the future, * so you should plan fixing your application accordingly. * If you think your use case of this feature is valid and this option should be kept around, * open an issue in our tracker explaining why. * * @deprecated This property is planned for removal in a future version. */ @Deprecated(forRemoval = true) @ConfigItem(defaultValueDocumentation = "fail") public Optional unsafeMultipleLastResources; public enum UnsafeMultipleLastResourcesMode { /** * Allow using multiple XA unaware resources in the same transactional demarcation. *

* This will log a warning once on application startup, * but not on each use of multiple XA unaware resources in the same transactional demarcation. */ ALLOW, /** * Allow using multiple XA unaware resources in the same transactional demarcation, * but log a warning on the first occurrence. */ WARN_FIRST, /** * Allow using multiple XA unaware resources in the same transactional demarcation, * but log a warning on each occurrence. */ WARN_EACH, /** * Allow using multiple XA unaware resources in the same transactional demarcation, * but log a warning on each occurrence. */ FAIL; // The default is WARN_FIRST in Quarkus 3.8, FAIL in Quarkus 3.9+ // Make sure to update defaultValueDocumentation on unsafeMultipleLastResources when changing this. public static final UnsafeMultipleLastResourcesMode DEFAULT = FAIL; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy