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

x7.repository.dao.RcDataSourceUtil Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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 x7.repository.dao;

import x7.core.config.ConfigAdapter;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.TimeUnit;

/**
 * X7-repository defect design readable datasource 
* only read committed
* X7-repository doesn't suggest for system dependent on database tx
*/ public class RcDataSourceUtil { /** * */ private final static Map connectionMap = new ConcurrentHashMap(); /** * */ private final static Map keyMap = new ConcurrentHashMap<>(); public static Connection getConnection() { try{ return getConnection0(); }catch (Exception e) { throw new RuntimeException(e.getMessage()); } } private static Connection getConnection0() throws Exception { String key = getKey(); DataSource ds = getDataSourceReadable(); Connection conn = null; if (key == null) { conn = ds.getConnection(); if (conn == null) { try { TimeUnit.MICROSECONDS.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } conn = ds.getConnection(); } } else { conn = connectionMap.get(key); if (conn == null) { conn = ds.getConnection(); if (conn == null) { try { TimeUnit.MICROSECONDS.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } conn = ds.getConnection(); } connectionMap.put(key, conn); } } if (conn == null) { System.out.println("_______NO CONNECTION"); throw new RuntimeException("NO CONNECTION"); } return conn; } protected static void releaseConnection(Connection conn){ String key = getKey(); if (key == null) { try { if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException("RcDataSourceUtil.releaseConnection Exception: " + e.getMessage()); } return; } } public static void end(){ String key = getKey(); if (key == null) return; Connection conn = connectionMap.remove(key); if (conn != null){ try { conn.close(); }catch (Exception e) { e.printStackTrace(); } } String threadId = String.valueOf(Thread.currentThread().getId()); keyMap.remove(threadId); } private static String getKey() { String threadId = String.valueOf(Thread.currentThread().getId()); String key = keyMap.get(threadId); return key; } private static DataSource getDataSourceReadable(){ DataSource ds = DataSourceHolder.getReadableDataSource(); if (ds == null) { ds = DataSourceHolder.getDataSource(); }else{ if (ConfigAdapter.isIsShowSql()) System.out.println("Find By Read DataSource: " + ds ); } return ds; } public static void start(){ String threadId = String.valueOf(Thread.currentThread().getId()); String key = "rcTx."+threadId; keyMap.put(threadId,key); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy