JDBC 元数据存储
版本 5.0 引入了 JDBC MetadataStore
(参见 元数据存储)实现。
你可以使用 JdbcMetadataStore
在应用程序重启后维护元数据状态。
此 MetadataStore
实现可与以下适配器一起使用:
要配置这些适配器以使用 JdbcMetadataStore
,请使用 metadataStore
的 bean 名称声明一个 Spring bean。
Feed 入站通道适配器和 feed 入站通道适配器都会自动识别并使用声明的 JdbcMetadataStore
,如以下示例所示:
@Bean
public MetadataStore metadataStore(DataSource dataSource) {
return new JdbcMetadataStore(dataSource);
}
org.springframework.integration.jdbc
包中包含适用于多个 RDBMS 供应商的数据库 schema 脚本。
例如,以下清单显示了元数据表的 H2 DDL:
CREATE TABLE INT_METADATA_STORE (
METADATA_KEY VARCHAR(255) NOT NULL,
METADATA_VALUE VARCHAR(4000),
REGION VARCHAR(100) NOT NULL,
constraint INT_METADATA_STORE_PK primary key (METADATA_KEY, REGION)
);
你可以更改 INT_
前缀以匹配目标数据库设计要求。
你还可以配置 JdbcMetadataStore
以使用自定义前缀。
JdbcMetadataStore
实现了 ConcurrentMetadataStore
,使其能够可靠地在多个应用程序实例之间共享,其中只有一个实例可以存储或修改键的值。
由于事务保证,所有这些操作都是原子的。
事务管理必须使用 JdbcMetadataStore
。
在轮询器配置中,可以为入站通道适配器提供 TransactionManager
的引用。
与非事务性 MetadataStore
实现不同,使用 JdbcMetadataStore
时,条目仅在事务提交后才出现在目标表中。
当发生回滚时,INT_METADATA_STORE
表中不会添加任何条目。
自版本 5.0.7 起,你可以使用 RDBMS 供应商特定的 lockHint
选项配置 JdbcMetadataStore
,用于元数据存储条目上的基于锁的查询。
默认情况下,它是 FOR UPDATE
,如果目标数据库不支持行锁定功能,则可以配置为空字符串。
请咨询你的供应商,了解 SELECT
表达式中用于在更新前锁定行的特定和可能的提示。