- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Cassandra 的新手 - 我一直在寻找与 Cassandra 中单个节点上的提交和崩溃恢复相关的信息。并且,希望有人能澄清细节。
我正在测试 Cassandra - 因此,将其设置在单个节点上。我在 datastax 上使用压力工具来插入数百万行。如果发生电气故障或系统关闭会怎样? Cassandra 重新启动后,Cassandra 内存中的所有数据是否都会写入磁盘(我猜 commitlog 充当中介)?这个过程需要多长时间?
谢谢!
最佳答案
Cassandra 的提交日志为 Cassandra 提供持久写入。当您写入 Cassandra 时,在向客户端确认写入之前,写入会附加到提交日志。这意味着客户端收到成功响应的每次写入都保证会写入提交日志。写入也会写入当前的 memtable,当它足够大时,它最终将作为 SSTable 写入磁盘。这可能是写入完成后的很长时间。
但是,出于性能原因,提交日志不会立即同步到磁盘。默认为周期模式(由 cassandra.yaml 中的 commitlog_sync 参数设置),周期为 10 秒(由 cassandra.yaml 中的 commitlog_sync_period_in_ms 设置)。这意味着提交日志每 10 秒同步到磁盘一次。使用此行为,如果服务器断电,您可能会丢失多达 10 秒的写入。如果集群中有多个节点并使用大于 1 的复制因子,则需要在 10 秒内为多个节点断电才能丢失任何数据。
如果此风险窗口 Not Acceptable ,您可以对提交日志使用批处理模式。在提交日志同步到磁盘之前,此模式不会确认对客户端的写入。时间窗口由 commitlog_sync_batch_window_in_ms 设置,默认为 50 ms。这将显着增加您的写入延迟并可能降低吞吐量,因此只有在丢失一些已确认写入的成本很高时才使用它。使用此模式时,将提交日志存储在单独的驱动器上尤为重要。
如果您的服务器断电,启动时 Cassandra 会重放提交日志以重建其内存表。在写入量很大的服务器上,此过程将需要几秒钟(可能几分钟)。
如果您想确保将内存表中的数据写入磁盘,您可以运行“nodetool flush”(这对每个节点进行操作)。这将创建一个新的 SSTable 并删除引用已刷新的 memtables 中的数据的提交日志。
关于crash - 单节点上的 Cassandra 提交和恢复,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16549833/
我是 Arduino 世界的新手。编写了以下代码 - 使用 DHT22 传感器。 12 小时后,当温度低于所需温度时,我的温室的加热器没有打开。 关闭电源并重新打开后,一切恢复正常。我知道这段代码很乱
我正在使用 CENTOS6 和 REDHAWK2.0 (RH2.0)。基于“VirtualBox 5.0.16 for Windows host”和“VirtualBox 5.0.17 r106140
在无渲染模式下使用 VMR-9 时如何解决 SelectAtPosition() 崩溃? 最佳答案 使用无渲染模式时的 SelectAtPosition() 崩溃问题可以通过在自定义分配器中实现 IV
这是我从 logcat 复制的错误。我不知道为什么在应用设置屏幕中清除数据后应用程序崩溃。 02-20 17:22:29.980 839-1094/? I/InputReader: Apps
我收到了来自 Apple 的应用提交反馈: Thank you for your resubmission. We were unable to review your app as it crash
我有一个 iPad 应用程序。使用 Fabric 收集崩溃信息。最近出现了一些像 webthread EXC_BREAKPOINT 这样的崩溃。跟踪堆栈上没有我的代码。所以我不知道为什么会发生崩溃。
我有一个在 ubuntu(EC2 实例,t2.small)上运行的简单 python web-scraper,到目前为止它只打印出一个 url 列表: from bs4 import Beautifu
注意:我的问题之前已关闭,我尝试了此处提到的解决方案 - unknown error: session deleted because of page crash from unknown error
我正在尝试从一个场景过渡到另一个场景,但是当我调用 presentScene 时发生崩溃!场景未存储在类中或被引用,它们直接加载到 presentScene 调用中。 Xcode 崩溃截图: 我的简单
我有点困惑,我的应用程序几乎没有崩溃,崩溃日志也有以下信息。 崩溃:com.twitter.crashlytics.ios.exception 这是否意味着它是 Fabric 库的崩溃还是有效的崩溃?
我尝试在我的 ubuntu 16.04 远程服务器上使用 selenium webdriver 和 python 3.5.2 连接到网页 from pyvirtualdisplay import Di
我正在使用使用 Python 和 Selenium 的 InstaPy。我按 Cron 启动脚本,有时它会崩溃。所以它真的很不规则,有时它会很好地贯穿始终。我也已经在 GitHub Repo 上发帖,
最近我换了电脑,从那以后我无法使用 selenium 启动 chrome。我也尝试过 Firefox,但浏览器实例无法启动。 from selenium import webdriver d = we
我正在使用 InstaPy,它使用 Python 和 Selenium。我按照 Cron 启动脚本,但有时它会崩溃。所以它确实不规则,有时它贯穿得很好。我已经在 GitHub Repo 上发布了,但没
我正在使用 InstaPy,它使用 Python 和 Selenium。我按照 Cron 启动脚本,但有时它会崩溃。所以它确实不规则,有时它贯穿得很好。我已经在 GitHub Repo 上发布了,但没
我正在使用使用 Python 和 Selenium 的 InstaPy。我按 Cron 启动脚本,有时它会崩溃。所以它真的很不规则,有时它会很好地贯穿始终。我也已经在 GitHub Repo 上发帖,
我正在尝试使用rook在kubernetes集群上配置ceph,我已经运行了以下命令: kubectl apply -f common.yaml kubectl apply -f operator.y
我有一个屏幕A,在执行了一些POST API任务后,我启用了一个按钮,然后单击按钮导航到屏幕B。当Reaction Native应用程序冻结并崩溃时,崩溃会随机发生。从其他屏幕导航到屏幕B也不是问题,
我想知道操作系统是否可能导致崩溃,例如我是否有代码,它是否有可能在Windows环境下崩溃而在Linux上却没有崩溃?还是这不可能? 最佳答案 最简单的示例是代码,您的意图是使其与平台兼容,但是您的代
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
我是一名优秀的程序员,十分优秀!