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

io.shardingjdbc.transaction.api.config.SoftTransactionConfiguration Maven / Gradle / Ivy

/*
 * Copyright 1999-2015 dangdang.com.
 * 

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. *

*/ package io.shardingjdbc.transaction.api.config; import io.shardingjdbc.core.jdbc.core.datasource.ShardingDataSource; import io.shardingjdbc.core.constant.SQLType; import io.shardingjdbc.transaction.constants.TransactionLogDataSourceType; import io.shardingjdbc.transaction.datasource.TransactionLogDataSource; import io.shardingjdbc.transaction.datasource.impl.MemoryTransactionLogDataSource; import io.shardingjdbc.transaction.datasource.impl.RdbTransactionLogDataSource; import com.google.common.base.Optional; import lombok.AccessLevel; import lombok.Getter; import lombok.RequiredArgsConstructor; import lombok.Setter; import javax.sql.DataSource; import java.sql.Connection; import java.sql.SQLException; import static io.shardingjdbc.transaction.constants.TransactionLogDataSourceType.RDB; /** * B.A.S.E transaction configuration. * * @author zhangliang */ @RequiredArgsConstructor @Getter @Setter public class SoftTransactionConfiguration { /** * Data source for transaction manager. */ @Getter(AccessLevel.NONE) private final DataSource targetDataSource; /** * Max synchronized delivery try times. */ private int syncMaxDeliveryTryTimes = 3; /** * Transaction log storage type. */ private TransactionLogDataSourceType storageType = RDB; /** * Transaction log data source. */ private DataSource transactionLogDataSource; /** * Embed best efforts delivery B.A.S.E transaction asynchronized job configuration. */ private Optional bestEffortsDeliveryJobConfiguration = Optional.absent(); /** * Get connection for transaction manager. * * @param dataSourceName data source name for transaction manager * @return connection for transaction manager * @throws SQLException SQL exception */ public Connection getTargetConnection(final String dataSourceName) throws SQLException { if (!(targetDataSource instanceof ShardingDataSource)) { return targetDataSource.getConnection(); } return ((ShardingDataSource) targetDataSource).getConnection().getConnection(dataSourceName, SQLType.DQL); } /** * Build transaction log data source. * * @return transaction log data source */ public TransactionLogDataSource buildTransactionLogDataSource() { TransactionLogDataSource result; switch (storageType) { case MEMORY: result = new MemoryTransactionLogDataSource(); break; case RDB: result = new RdbTransactionLogDataSource(transactionLogDataSource); break; default: throw new UnsupportedOperationException(); } return result; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy