动态数据源玩起来
package com.xf.config; import java.sql.SQLException; import java.util.Map; import java.util.Set; import java.util.concurrent.ConcurrentHashMap; import javax.annotation.PostConstruct; import javax.sql.DataSource; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Configuration; import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource; import com.alibaba.druid.pool.DruidDataSource; import com.alibaba.druid.stat.DruidDataSourceStatManager; @Configuration public class DynamicDataSource extends AbstractRoutingDataSource { @Value("${spring.datasource.druid.url}") String jdbcurl; @Value("${spring.datasource.druid.username}") String username; @Value("${spring.datasource.druid.password}") String password; public Map<Object, Object> dataSources; /** * 每次请求动态请求哪一个数据源 * * @return */ @Override protected Object determineCurrentLookupKey() { return DataSourceHolder.getDataSource(); } /** * 配置文件yml中的默认数据源 * * @return */ // @Bean(name = "defaultDataSource") // @ConfigurationProperties(prefix = "spring.datasource") // public DataSource getDefaultDataSource() { // return DruidDataSourceBuilder.create().build(); // } // public DynamicDataSource() { // // } /** * 添加数据源到目标数据源map中 * * @param datasource */ public void addDataSource(String key, DruidDataSource datasource) { dataSources.put(key, datasource); super.setTargetDataSources(dataSources); super.afterPropertiesSet(); } // 删除数据源 public synchronized boolean delDatasources(String datasourceid) { if (dataSources.containsKey(datasourceid)) { Set<DruidDataSource> druidDataSourceInstances = DruidDataSourceStatManager.getDruidDataSourceInstances(); for (DruidDataSource l : druidDataSourceInstances) { if (datasourceid.equals(l.getName())) { dataSources.remove(datasourceid); DruidDataSourceStatManager.removeDataSource(l); // 将map赋值给父类的TargetDataSources setTargetDataSources(dataSources); // 将TargetDataSources中的连接信息放入resolvedDataSources管理 super.afterPropertiesSet(); return true; } } return false; } else { return false; } } /** * 此处数据库信配置,可以来源于redis等,然后再初始化所有数据源 重点说明:一个DruidDataSource数据源,它里面本身就是线程池了, * 所以我们不需要考虑线程池的问题 * * @param no * @return */ public DataSource druidDataSource() { DruidDataSource datasource = new DruidDataSource(); datasource.setUrl(jdbcurl); datasource.setUsername(username); datasource.setPassword(password); // datasource.setDriverClassName("com.mysql.cj.jdbc.Driver"); datasource.setInitialSize(5); datasource.setMinIdle(5); datasource.setMaxActive(100); // datasource.setDbType("com.alibaba.druid.pool.DruidDataSource"); datasource.setMaxWait(60000); datasource.setTimeBetweenEvictionRunsMillis(60000); datasource.setMinEvictableIdleTimeMillis(300000); datasource.setValidationQuery("SELECT 1 FROM DUAL"); datasource.setTestWhileIdle(true); datasource.setTestOnBorrow(false); datasource.setTestOnReturn(false); try { // datasource.setFilters("stat,wall,log4j"); datasource.setFilters("wall"); } catch (SQLException e) { e.printStackTrace(); } return datasource; } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
2015-12-08 记redis的一个测试