mit_6.824_2021_lab3B_kvraft_with_snapshots

mit_6.824_2021_lab3B_kvraft_with_snapshots

Part B: Key/value service with snapshots

紧接着 lab3A,将键值存储服务的快照功能加上,这里的代码量不多,主要是对lab3A,和 raft 一些细枝末节的改动,让整体代码更可读,但还是发现了一个 raft 初始化的 bug,导致自己卡了一会,不过也加深了自己对 persist 这一部分的理解

实验内容

首先要知道,重启的服务器会执行一次完整的Raft日志以恢复其状态,但是,raft 日志不可能永远增长(和 lab2D 一样);

使用Raft的Snapshot()和来自lab 2D的CondInstallSnapshot来节省空间

启动 server 时将maxraftstate传递给StartKVServer()maxraftstate表示允许的持久Raft状态的最大字节大小(包括raftState,但不包括快照)。使用maxraftstatepersister.Raftstatesize()做比较。

每当kv服务器检测到Raft状态大小接近这个阈值时,使用Snapshot()保存一个快照,而snapshot又使用persister.Saveraftstate()。如果maxraftstat

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
[0710/081418.767757] [INFO:main.cc(55)] A/B Update Engine starting [0710/081418.775873] [INFO:boot_control_android.cc(69)] Loaded boot control hidl hal. [0710/081418.844522] [ERROR:update_attempter_android.cc(936)] prefs_->GetInt64(kPrefsPreviousSlot, &previous_slot) failed. [0710/081418.850761] [INFO:update_attempter_android.cc(196)] OTAResult::NOT_ATTEMPTED [0710/081418.883202] [INFO:update_attempter_android.cc(1262)] Scheduling CleanupPreviousUpdateAction. [0710/081418.895190] [INFO:action_processor.cc(51)] ActionProcessor: starting CleanupPreviousUpdateAction [0710/081418.899394] [INFO:cleanup_previous_update_action.cc(149)] Starting/resuming CleanupPreviousUpdateAction [0710/081418.902350] [INFO:cleanup_previous_update_action.cc(124)] CleanupPreviousUpdateAction scheduled task ID 1 for WaitBootCompleted [0710/081420.904474] [INFO:cleanup_previous_update_action.cc(112)] Executing task 1 [0710/081420.906355] [INFO:cleanup_previous_update_action.cc(124)] CleanupPreviousUpdateAction scheduled task ID 3 for WaitBootCompleted [0710/081422.908519] [INFO:cleanup_previous_update_action.cc(112)] Executing task 3 [0710/081422.910627] [INFO:cleanup_previous_update_action.cc(124)] CleanupPreviousUpdateAction scheduled task ID 4 for WaitBootCompleted [0710/081424.915286] [INFO:cleanup_previous_update_action.cc(112)] Executing task 4 [0710/081424.919637] [INFO:cleanup_previous_update_action.cc(124)] CleanupPreviousUpdateAction scheduled task ID 5 for WaitBootCompleted [0710/081426.923179] [INFO:cleanup_previous_update_action.cc(112)] Executing task 5 [0710/081426.927580] [INFO:cleanup_previous_update_action.cc(124)] CleanupPreviousUpdateAction scheduled task ID 6 for WaitBootCompleted [0710/081428.930648] [INFO:cleanup_previous_update_action.cc(112)] Executing task 6 [0710/081428.936232] [INFO:cleanup_previous_update_action.cc(124)] CleanupPreviousUpdateAction scheduled task ID 7 for WaitBootCompleted [0710/081430.938563] [INFO:cleanup_previous_update_action.cc(112)] Executing task 7 [0710/081430.943791] [INFO:cleanup_previous_update_action.cc(189)] Boot completed, waiting on markBootSuccessful() [0710/081430.947213] [INFO:snapshot.cpp(3766)] EnsureMetadataMounted does nothing in Android mode. [0710/081430.950810] [INFO:snapshot_stats.cpp(37)] Read merge statistics file failed: No such file or directory [0710/081430.965136] [INFO:cleanup_previous_update_action.cc(261)] Waiting for any previous merge request to complete. This can take up to several minutes. [0710/081430.974341] [INFO:snapshot.cpp(1047)] CheckMergeState for snapshots returned: 0 [0710/081430.981751] [INFO:snapshot.cpp(1019)] ProcessUpdateState handling state: 0 [0710/081430.988898] [INFO:cleanup_previous_update_action.cc(297)] Can't find any snapshot to merge. [0710/081430.996749] [INFO:cleanup_previous_update_action.cc(130)] Stopping/suspending/completing CleanupPreviousUpdateAction [0710/081431.002327] [INFO:cleanup_previous_update_action.cc(479)] Not reporting merge stats because state is None [0710/081431.014705] [INFO:cleanup_previous_update_action.cc(130)] Stopping/suspending/completing CleanupPreviousUpdateAction [0710/081431.022443] [INFO:action_processor.cc(116)] ActionProcessor: finished last action CleanupPreviousUpdateAction with code ErrorCode::kSuccess [0710/081431.031005] [INFO:update_attempter_android.cc(570)] Processing Done. [0710/081431.038024] [INFO:update_attempter_android.cc(826)] Clearing update complete marker. [0710/081431.046821] [INFO:update_attempter_android.cc(722)] Terminating cleanup previous update. 什么意思?
07-11

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值