hem*_*vsn 6 java spring hibernate spring-mvc spring-data-jpa
我正在使用SpringBoot,以及Hibernate作为持久性提供程序.对于我的应用程序,我需要在2个DB之间动态选择.
(For simplicity sake,
domain : localhost:8080 ---> hem1 DB
domain : 127.0.0.1:8080 ---> hem2 DB
)
Run Code Online (Sandbox Code Playgroud)
以下是AbstractRoutingDB的实现
public class MyRoutingDataSource extends AbstractRoutingDataSource{
@Override
protected Object determineCurrentLookupKey() {
/*
* this is derived from threadlocal set by filter for each web
* request
*/
return SessionUtil.getDB();
}
}
Run Code Online (Sandbox Code Playgroud)
以下是数据库配置:
package com.hemant.basic.dataSource;
import java.beans.PropertyVetoException;
import java.util.HashMap;
import java.util.Map;
import javax.naming.ConfigurationException;
import javax.sql.DataSource;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import com.mchange.v2.c3p0.ComboPooledDataSource;
@Configuration
public class DBConfig {
@Bean(name = "dataSource")
public DataSource dataSource() throws PropertyVetoException,
ConfigurationException {
MyRoutingDataSource routingDB = new MyRoutingDataSource();
Map<Object, Object> targetDataSources = datasourceList();
// hem1 is the default target DB
routingDB.setDefaultTargetDataSource(targetDataSources.get(1));
routingDB.setTargetDataSources(targetDataSources);
routingDB.afterPropertiesSet();
return routingDB;
}
private Map<Object, Object> datasourceList() throws PropertyVetoException,
ConfigurationException {
final Map<Object, Object> datasources = new HashMap<Object, Object>();
ComboPooledDataSource datasource = null;
for (int id = 1; id <= 2; id++) {
datasource = getDatasource(id);
datasources.put(id, datasource);
}
return datasources;
}
private ComboPooledDataSource getDatasource(int id)
throws PropertyVetoException, ConfigurationException {
ComboPooledDataSource datasource = new ComboPooledDataSource();
// set the connection pool properties
datasource.setJdbcUrl("jdbc:postgresql://localhost/hem" + id);
datasource.setUser("hemant");
datasource.setPassword("");
datasource.setDriverClass("org.postgresql.Driver");
datasource.setMaxPoolSize(30);
datasource.setInitialPoolSize(10);
datasource.setMinPoolSize(10);
return datasource;
}
}
Run Code Online (Sandbox Code Playgroud)
以下设置也在application.properties中,以便自动架构更新为ON.
# Hibernate ddl auto (create, create-drop, update)
spring.jpa.hibernate.ddl-auto = update
Run Code Online (Sandbox Code Playgroud)
问题:当我启动应用程序时,hbm2ddl架构更新仅在hem1(defaultTargetDb)上执行,但不在其他目标数据库上执行
以下是启动日志的一部分
[main] org.hibernate.tool.hbm2ddl.SchemaUpdate : HHH000228: Running hbm2ddl schema update
[main] org.hibernate.tool.hbm2ddl.SchemaUpdate : HHH000102: Fetching database metadata
[main] org.hibernate.tool.hbm2ddl.SchemaUpdate : HHH000396: Updating schema
[main] java.sql.DatabaseMetaData : HHH000262: Table not found: users
[main] java.sql.DatabaseMetaData : HHH000262: Table not found: users
[main] java.sql.DatabaseMetaData : HHH000262: Table not found: users
[main] org.hibernate.tool.hbm2ddl.SchemaUpdate : HHH000232: Schema update complete`enter code here`
Run Code Online (Sandbox Code Playgroud)
这仅适用于1 DB.
**稍后当我执行休息URL时说
GET localhost:8080/users - 为更新的DB hem1成功获取结果.
但是当访问GET 127.0.0.1:8080/users时,由于架构未更新/创建,因此IT导致SQL异常**
我们如何确保在AbstractRoutingDataSource的所有目标数据库上执行"hbm2ddl架构更新"
据我所知,您无法在多租户环境中设置架构导出。当您定义多租户环境时,默认情况下,它只会连接到默认数据库以获得连接。这就是为什么您只在一个数据库中创建的原因。它不会访问要创建的所有数据库/模式,因为它彼此不了解。
保存 SQL 数据库创建文件并在每次创建新租户时执行它。我认为您可以在需要时使用 Spring PersistenceContext 为您创建它。
| 归档时间: |
|
| 查看次数: |
931 次 |
| 最近记录: |