Changyu Bi
9882652b0e
Verify write batch checksum before WAL (#10114)
Summary:
Context: WriteBatch can have key-value checksums when it was created `with protection_bytes_per_key > 0`.
This PR added checksum verification for write batches before they are written to WAL.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/10114
Test Plan:
- Added new unit tests to db_kv_checksum_test.cc: `make check -j32`
- benchmark on performance regression: `./db_bench --benchmarks=fillrandom[-X20] -db=/dev/shm/test_rocksdb -write_batch_protection_bytes_per_key=8`
- Pre-PR:
`
fillrandom [AVG 20 runs] : 198875 (± 3006) ops/sec; 22.0 (± 0.3) MB/sec
`
- Post-PR:
`
fillrandom [AVG 20 runs] : 196487 (± 2279) ops/sec; 21.7 (± 0.3) MB/sec
`
Mean regressed about 1% (198875 -> 196487 ops/sec).
Reviewed By: ajkr
Differential Revision: D36917464
Pulled By: cbi42
fbshipit-source-id: 29beb74edf65f04b1a890b4f650d873dc7ed790d
2022-06-15 13:43:58 -07:00
..
2022-06-02 23:42:41 -07:00
2022-06-07 11:57:12 -07:00
2022-06-15 13:43:58 -07:00
2022-06-03 20:54:48 -07:00
2022-05-06 13:03:58 -07:00
2021-09-29 04:04:40 -07:00
2022-06-06 18:32:26 -07:00
2022-04-14 11:11:04 -07:00
2022-06-02 20:04:33 -07:00
2022-06-14 14:19:26 -07:00
2022-05-30 12:31:46 -07:00
2022-06-14 13:06:40 -07:00
2022-06-14 13:06:40 -07:00
2022-05-06 13:03:58 -07:00
2022-06-13 11:08:50 -07:00
2022-05-02 10:22:08 -07:00
2022-06-01 10:52:26 -07:00
2022-05-06 13:03:58 -07:00
2022-06-03 16:33:00 -07:00
2022-06-13 20:29:00 -07:00
2022-05-17 15:01:51 -07:00
2022-05-06 13:03:58 -07:00
2022-06-01 19:40:26 -07:00
2022-01-27 13:01:09 -08:00
2021-07-23 08:38:45 -07:00
2022-06-01 11:02:27 -07:00
2022-05-05 13:08:21 -07:00
2022-05-04 10:19:53 -07:00
2022-03-21 12:04:33 -07:00
2021-11-08 11:05:59 -08:00
2022-05-06 13:03:58 -07:00
2022-05-06 13:03:58 -07:00
2022-04-11 10:26:55 -07:00
2022-04-11 10:26:55 -07:00
2022-05-06 13:03:58 -07:00
2022-06-15 13:43:58 -07:00
2022-05-06 13:03:58 -07:00
2022-03-04 11:35:28 -08:00
2022-05-06 13:03:58 -07:00
2022-04-05 12:26:36 -07:00
2021-07-23 08:38:45 -07:00
2022-06-14 14:19:26 -07:00
2022-05-06 13:03:58 -07:00
2022-05-06 13:03:58 -07:00
2022-05-19 15:23:53 -07:00
2022-05-24 12:14:10 -07:00
2022-05-27 07:23:31 -07:00
2022-05-27 05:58:43 -07:00
2021-09-07 13:28:29 -07:00
2022-05-06 13:03:58 -07:00
2021-07-23 08:38:45 -07:00
2022-06-13 11:08:50 -07:00
2022-06-14 13:06:40 -07:00
2022-06-01 18:03:34 -07:00
2022-06-14 21:29:52 -07:00
2022-05-06 13:03:58 -07:00
2022-06-12 12:05:11 -07:00
2022-06-10 08:21:08 -07:00
2022-02-08 12:15:35 -08:00
2022-05-19 18:39:41 -07:00
2022-05-19 18:39:41 -07:00
2021-11-08 11:05:59 -08:00
2022-05-06 13:03:58 -07:00
2021-11-08 11:05:59 -08:00
2021-11-10 10:49:04 -08:00
2022-06-14 13:06:40 -07:00
2022-05-06 13:03:58 -07:00
2022-05-06 13:03:58 -07:00
2022-03-15 14:45:34 -07:00
2022-03-15 14:45:34 -07:00
2022-03-23 19:41:31 -07:00
2021-12-08 14:30:57 -08:00
2022-05-19 11:04:21 -07:00
2022-05-31 08:48:57 -07:00
2022-05-19 11:04:21 -07:00
2022-05-19 11:04:21 -07:00
2022-05-06 13:03:58 -07:00
2021-12-13 09:00:36 -08:00
2022-05-05 13:08:21 -07:00
2022-03-30 15:55:31 -07:00
2022-05-18 00:41:41 -07:00
2022-06-06 18:32:26 -07:00
2022-05-18 00:41:41 -07:00
2022-01-12 09:31:12 -08:00
2022-05-06 13:03:58 -07:00
2022-01-21 11:37:46 -08:00
2022-03-11 16:13:23 -08:00
2022-05-19 11:04:21 -07:00
2021-12-16 17:15:13 -08:00
2022-05-19 11:04:21 -07:00
2022-05-06 13:03:58 -07:00
2022-04-13 13:36:30 -07:00
2022-04-14 11:11:04 -07:00
2021-11-16 10:20:50 -08:00
2022-05-06 13:03:58 -07:00
2022-02-17 16:19:31 -08:00
2022-05-24 10:28:57 -07:00
2022-06-08 14:16:43 -07:00
2022-03-09 15:49:53 -08:00
2022-03-09 15:49:53 -08:00
2022-03-09 15:49:53 -08:00
2021-09-29 04:04:40 -07:00
2021-09-07 11:31:59 -07:00
2022-01-12 09:31:12 -08:00
2022-05-06 13:03:58 -07:00
2022-03-31 20:00:52 -07:00
2022-05-05 19:45:32 -07:00
2022-06-03 20:00:42 -07:00
2022-04-13 07:34:01 -07:00
2021-11-19 17:53:47 -08:00
2021-11-19 17:53:47 -08:00
2021-11-19 17:53:47 -08:00
2022-01-04 16:45:49 -08:00
2022-05-06 13:03:58 -07:00
2021-09-29 04:04:40 -07:00
2021-09-29 04:04:40 -07:00
2022-05-06 13:03:58 -07:00
2021-07-23 08:38:45 -07:00
2022-03-12 11:45:56 -08:00
2022-03-12 11:45:56 -08:00
2021-09-07 11:31:59 -07:00
2022-05-06 13:03:58 -07:00
2022-06-10 16:07:03 -07:00
2021-09-10 10:00:26 -07:00
2022-05-06 13:03:58 -07:00
2021-10-06 07:48:31 -07:00
2021-10-06 07:48:31 -07:00
2021-10-06 07:48:31 -07:00
2021-09-10 10:00:26 -07:00
2022-05-24 09:00:06 -07:00
2022-05-24 10:28:57 -07:00
2022-05-17 09:39:22 -07:00
2022-06-10 16:07:03 -07:00
2022-05-19 15:36:27 -07:00
2022-05-20 12:38:21 -07:00
2022-05-19 15:36:27 -07:00
2021-11-18 11:43:44 -08:00
2021-11-19 11:37:06 -08:00
2022-05-24 10:28:57 -07:00
2022-04-14 17:12:16 -07:00
2022-05-19 11:04:21 -07:00
2022-06-14 13:06:40 -07:00
2022-06-14 13:06:40 -07:00
2022-03-23 19:41:31 -07:00
2022-05-19 11:04:21 -07:00
2022-05-19 11:04:21 -07:00
2022-06-14 13:06:40 -07:00
2022-05-19 15:36:27 -07:00
2022-06-14 13:06:40 -07:00
2022-06-14 13:06:40 -07:00
2022-06-14 13:06:40 -07:00
2022-03-18 16:35:51 -07:00
2022-05-05 13:08:21 -07:00
2022-05-06 13:03:58 -07:00
2022-06-08 14:16:43 -07:00
2022-06-08 14:16:43 -07:00
2022-06-15 13:43:58 -07:00
2022-05-06 13:03:58 -07:00
2022-06-15 13:43:58 -07:00
2022-05-18 00:41:41 -07:00
2022-06-15 13:43:58 -07:00
2022-06-10 16:07:03 -07:00