java - 处理两个或多个 noSQL 数据库事务的方法是什么?

标签 java spring elasticsearch cassandra nosql

我们有以下要求:

  1. 我们将数据存储在 Cassandra 中,然后我们将在 Elasticsearch 中对相同数据(或部分数据)建立索引。
  2. 问题是,如果在 Elastic Search 中插入时出现问题,则应回滚插入到 Cassandra 中的数据。

基本上,我们希望在多个 NoSQL 数据库上进行事务。有没有办法在Java(Spring)中做到这一点?

最佳答案

没有跨多个 NoSQL 数据库执行事务的标准方法,Spring 也不支持。

我想到了两种方法:

  1. 您应该仅使用一个数据库来实现这一目标。 例如,在您的情况下,您可以使用 Cassandra 在节点、数据中心或所有数据中心级别进行事务。 Cassandra事务成功后异步发送数据到Elastic Search

  2. 但如果你必须这样做,我建议使用Redis来获取全局分布式事务锁。请注意,这是一个非常昂贵的操作,您需要自行处理失败和回滚。

关于java - 处理两个或多个 noSQL 数据库事务的方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47152160/

相关文章:

java - 将 Spring xml 配置 Controller 更新为注释

elasticsearch - 将 ElasticSearch 传输客户端与 Amazon ElasticSearch Service (AES) 结合使用

java - 带有 tomcat 连接池和 oracle 数据源配置的 Spring Boot 2?

java - 使用 Spring 访问 XmlBeanFactory 的更好设计

java - primefaces 默认 css 主题被自定义模板覆盖

java - 配置 p2 存储库管理器以通过编程方式使用客户端证书连接到 HTTPS 存储库

java - LocaleChangeInterceptor.preHandle 中的对象处理程序有什么用

java - 在 Websphere App Server 和 Websphere MQ 之间配置 SSL

elasticsearch - Elasticsearch的不匹配指数

elasticsearch - logstash不将日志推送到AWS Elasticsearch