/ / Ako nastaviť kvapalinu na jar pre viaceré zdroje údajov? - pružiny, pružiny, pružiny, kvapaliny

Ako nastaviť kvapalinu na jar pre viac zdrojov údajov? - pružiny, pružiny, pružiny, kvapaliny

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ď č. 1

Ak 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.