Musím zriadiť liquibase
pre dvoch datasources
v Spring
, momentálne sa zdá, že len jedna liquibase
nastavenie je možné a môžete vybrať, pre ktorý zdroj údajov.
odpovede:
12 pre odpoveď č. 1Ak používate jarné zavádzanie, je tu nastavenie, ktoré vám môže pomôcť:
Konfiguračná trieda:
@Configuration
public class DatasourceConfig {
@Primary
@Bean
@ConfigurationProperties(prefix = "datasource.primary")
public DataSource primaryDataSource() {
return DataSourceBuilder.create().build();
}
@Bean
@ConfigurationProperties(prefix = "datasource.primary.liquibase")
public LiquibaseProperties primaryLiquibaseProperties() {
return new LiquibaseProperties();
}
@Bean
public SpringLiquibase primaryLiquibase() {
return springLiquibase(primaryDataSource(), primaryLiquibaseProperties());
}
@Bean
@ConfigurationProperties(prefix = "datasource.secondary")
public DataSource secondaryDataSource() {
return DataSourceBuilder.create().build();
}
@Bean
@ConfigurationProperties(prefix = "datasource.secondary.liquibase")
public LiquibaseProperties secondaryLiquibaseProperties() {
return new LiquibaseProperties();
}
@Bean
public SpringLiquibase secondaryLiquibase() {
return springLiquibase(secondaryDataSource(), secondaryLiquibaseProperties());
}
private static SpringLiquibase springLiquibase(DataSource dataSource, LiquibaseProperties properties) {
SpringLiquibase liquibase = new SpringLiquibase();
liquibase.setDataSource(dataSource);
liquibase.setChangeLog(properties.getChangeLog());
liquibase.setContexts(properties.getContexts());
liquibase.setDefaultSchema(properties.getDefaultSchema());
liquibase.setDropFirst(properties.isDropFirst());
liquibase.setShouldRun(properties.isEnabled());
liquibase.setLabels(properties.getLabels());
liquibase.setChangeLogParameters(properties.getParameters());
liquibase.setRollbackFile(properties.getRollbackFile());
return liquibase;
}
...
}
properties.yml
datasource:
primary:
url: jdbc:mysql://localhost/primary
username: username
password: password
liquibase:
change-log: classpath:/db/changelog/db.primary.changelog-master.xml
secondary:
url: jdbc:mysql://localhost/secondary
username: username
password: password
liquibase:
change-log: classpath:/db/changelog/db.secondary.changelog-master.xml
0 pre odpoveď č. 2
Stačí mať 2 zdroje údajov a 2 fazuľa
<bean id="liquibase1" class="liquibase.integration.spring.SpringLiquibase">
<property name="dataSource" ref="dataSource1" />
<property name="changeLog" value="classpath:db1-changelog.xml" />
</bean>
<bean id="liquibase2" class="liquibase.integration.spring.SpringLiquibase">
<property name="dataSource" ref="dataSource2" />
<property name="changeLog" value="classpath:db2-changelog.xml" />
</bean>
0 pre odpoveď č. 3
Môžete tiež spustiť viacero inštancií kvapaliny (t. J. Nielen obmedziť na primárnu a sekundárnu).
napr. Vaša konfigurácia java môže mať:
@Bean
@ConfigurationProperties(prefix = "liquibase1")
...
@Bean
@ConfigurationProperties(prefix = "liquibase2")
...
@Bean
@ConfigurationProperties(prefix = "liquibase3")
Vaša aplikácia.property môže mať:
liquibase1.default-schema=schemaA
...
liquibase2.default-schema=schemaB
...
liquibase3.default-schema=schemaC
...
A (vzrušene), tieto inštancie springLiquibase môžu používať rovnaký zdroj údajov alebo rôzne zdroje dát ... ale máte radi to.
Prebiehajúca objednávka? Nepodarilo sa mi nájsť žiadny oficiálny dokument, z mojej pozorovateľnosti pri ladení, všetka migrácia v likvidácii prebieha podľa objednávky, ktorú píšete v application.properties.Tieto osoby, ktoré chcú spustiť migráciu do jedného zdroja údajov, potom prejdú na iný zdroj údajov a potom sa vrátia tento zdroj údajov a spustite niečo iné ,,, budete chcieť vyskúšať tento príklad viacerých príkladov kvapaliny.