rocksdb-native 2.6.2 → 2.6.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CMakeLists.txt +29 -17
- package/binding.js +1 -1
- package/package.json +7 -4
- package/prebuilds/darwin-arm64/rocksdb-native.bare +0 -0
- package/prebuilds/darwin-arm64/rocksdb-native.node +0 -0
- package/prebuilds/darwin-x64/rocksdb-native.bare +0 -0
- package/prebuilds/darwin-x64/rocksdb-native.node +0 -0
- package/prebuilds/ios-arm64/rocksdb-native.bare +0 -0
- package/prebuilds/ios-arm64-simulator/rocksdb-native.bare +0 -0
- package/prebuilds/ios-x64-simulator/rocksdb-native.bare +0 -0
- package/prebuilds/linux-arm64/rocksdb-native.bare +0 -0
- package/prebuilds/linux-arm64/rocksdb-native.node +0 -0
- package/prebuilds/linux-x64/rocksdb-native.bare +0 -0
- package/prebuilds/linux-x64/rocksdb-native.node +0 -0
- package/prebuilds/win32-arm64/rocksdb-native.bare +0 -0
- package/prebuilds/win32-arm64/rocksdb-native.node +0 -0
- package/prebuilds/win32-x64/rocksdb-native.bare +0 -0
- package/prebuilds/win32-x64/rocksdb-native.node +0 -0
- package/vendor/librocksdb/CMakeLists.txt +0 -94
- package/vendor/librocksdb/LICENSE +0 -201
- package/vendor/librocksdb/NOTICE +0 -13
- package/vendor/librocksdb/README.md +0 -11
- package/vendor/librocksdb/include/rocksdb.h +0 -294
- package/vendor/librocksdb/src/rocksdb.cc +0 -714
- package/vendor/librocksdb/vendor/rocksdb/CMakeLists.txt +0 -1642
- package/vendor/librocksdb/vendor/rocksdb/cache/cache.cc +0 -193
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_bench.cc +0 -20
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_bench_tool.cc +0 -1177
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_entry_roles.cc +0 -104
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_entry_roles.h +0 -20
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_entry_stats.h +0 -182
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_helpers.cc +0 -41
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_helpers.h +0 -139
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_key.cc +0 -364
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_key.h +0 -143
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_reservation_manager.cc +0 -184
- package/vendor/librocksdb/vendor/rocksdb/cache/cache_reservation_manager.h +0 -318
- package/vendor/librocksdb/vendor/rocksdb/cache/charged_cache.cc +0 -111
- package/vendor/librocksdb/vendor/rocksdb/cache/charged_cache.h +0 -61
- package/vendor/librocksdb/vendor/rocksdb/cache/clock_cache.cc +0 -3657
- package/vendor/librocksdb/vendor/rocksdb/cache/clock_cache.h +0 -1165
- package/vendor/librocksdb/vendor/rocksdb/cache/compressed_secondary_cache.cc +0 -414
- package/vendor/librocksdb/vendor/rocksdb/cache/compressed_secondary_cache.h +0 -151
- package/vendor/librocksdb/vendor/rocksdb/cache/lru_cache.cc +0 -726
- package/vendor/librocksdb/vendor/rocksdb/cache/lru_cache.h +0 -467
- package/vendor/librocksdb/vendor/rocksdb/cache/secondary_cache.cc +0 -12
- package/vendor/librocksdb/vendor/rocksdb/cache/secondary_cache_adapter.cc +0 -743
- package/vendor/librocksdb/vendor/rocksdb/cache/secondary_cache_adapter.h +0 -103
- package/vendor/librocksdb/vendor/rocksdb/cache/sharded_cache.cc +0 -147
- package/vendor/librocksdb/vendor/rocksdb/cache/sharded_cache.h +0 -322
- package/vendor/librocksdb/vendor/rocksdb/cache/tiered_secondary_cache.cc +0 -125
- package/vendor/librocksdb/vendor/rocksdb/cache/tiered_secondary_cache.h +0 -158
- package/vendor/librocksdb/vendor/rocksdb/cache/typed_cache.h +0 -380
- package/vendor/librocksdb/vendor/rocksdb/cmake/RocksDBConfig.cmake.in +0 -54
- package/vendor/librocksdb/vendor/rocksdb/db/arena_wrapped_db_iter.cc +0 -182
- package/vendor/librocksdb/vendor/rocksdb/db/arena_wrapped_db_iter.h +0 -128
- package/vendor/librocksdb/vendor/rocksdb/db/attribute_group_iterator_impl.cc +0 -20
- package/vendor/librocksdb/vendor/rocksdb/db/attribute_group_iterator_impl.h +0 -83
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_constants.h +0 -16
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_contents.cc +0 -42
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_contents.h +0 -60
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_counting_iterator.h +0 -150
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_fetcher.cc +0 -34
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_fetcher.h +0 -37
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_addition.cc +0 -156
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_addition.h +0 -67
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_builder.cc +0 -429
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_builder.h +0 -113
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_cache.cc +0 -101
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_cache.h +0 -56
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_completion_callback.h +0 -84
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_garbage.cc +0 -134
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_garbage.h +0 -57
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_meta.cc +0 -62
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_meta.h +0 -170
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_reader.cc +0 -622
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_file_reader.h +0 -111
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_garbage_meter.cc +0 -100
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_garbage_meter.h +0 -102
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_index.h +0 -187
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_log_format.cc +0 -143
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_log_format.h +0 -164
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_log_sequential_reader.cc +0 -133
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_log_sequential_reader.h +0 -83
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_log_writer.cc +0 -207
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_log_writer.h +0 -87
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_read_request.h +0 -58
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_source.cc +0 -459
- package/vendor/librocksdb/vendor/rocksdb/db/blob/blob_source.h +0 -161
- package/vendor/librocksdb/vendor/rocksdb/db/blob/prefetch_buffer_collection.cc +0 -23
- package/vendor/librocksdb/vendor/rocksdb/db/blob/prefetch_buffer_collection.h +0 -38
- package/vendor/librocksdb/vendor/rocksdb/db/builder.cc +0 -517
- package/vendor/librocksdb/vendor/rocksdb/db/builder.h +0 -76
- package/vendor/librocksdb/vendor/rocksdb/db/c.cc +0 -7133
- package/vendor/librocksdb/vendor/rocksdb/db/c_test.c +0 -4052
- package/vendor/librocksdb/vendor/rocksdb/db/coalescing_iterator.cc +0 -47
- package/vendor/librocksdb/vendor/rocksdb/db/coalescing_iterator.h +0 -79
- package/vendor/librocksdb/vendor/rocksdb/db/column_family.cc +0 -1859
- package/vendor/librocksdb/vendor/rocksdb/db/column_family.h +0 -918
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/clipping_iterator.h +0 -281
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction.cc +0 -995
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction.h +0 -602
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_iteration_stats.h +0 -56
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_iterator.cc +0 -1523
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_iterator.h +0 -557
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_job.cc +0 -2155
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_job.h +0 -520
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_outputs.cc +0 -802
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_outputs.h +0 -411
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_picker.cc +0 -1245
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_picker.h +0 -322
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_picker_fifo.cc +0 -478
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_picker_fifo.h +0 -61
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_picker_level.cc +0 -977
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_picker_level.h +0 -32
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_picker_universal.cc +0 -1578
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_picker_universal.h +0 -29
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_service_job.cc +0 -835
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_state.cc +0 -46
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/compaction_state.h +0 -42
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/file_pri.h +0 -94
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/sst_partitioner.cc +0 -83
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/subcompaction_state.cc +0 -106
- package/vendor/librocksdb/vendor/rocksdb/db/compaction/subcompaction_state.h +0 -220
- package/vendor/librocksdb/vendor/rocksdb/db/convenience.cc +0 -101
- package/vendor/librocksdb/vendor/rocksdb/db/convenience_impl.h +0 -15
- package/vendor/librocksdb/vendor/rocksdb/db/db_filesnapshot.cc +0 -506
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/compacted_db_impl.cc +0 -275
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/compacted_db_impl.h +0 -147
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl.cc +0 -6767
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl.h +0 -3056
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_compaction_flush.cc +0 -4390
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_debug.cc +0 -327
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_experimental.cc +0 -164
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_files.cc +0 -1032
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_follower.cc +0 -348
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_follower.h +0 -54
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_open.cc +0 -2325
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_readonly.cc +0 -376
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_readonly.h +0 -179
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_secondary.cc +0 -1025
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_secondary.h +0 -322
- package/vendor/librocksdb/vendor/rocksdb/db/db_impl/db_impl_write.cc +0 -2624
- package/vendor/librocksdb/vendor/rocksdb/db/db_info_dumper.cc +0 -165
- package/vendor/librocksdb/vendor/rocksdb/db/db_info_dumper.h +0 -15
- package/vendor/librocksdb/vendor/rocksdb/db/db_iter.cc +0 -1774
- package/vendor/librocksdb/vendor/rocksdb/db/db_iter.h +0 -444
- package/vendor/librocksdb/vendor/rocksdb/db/db_test2.cc +0 -7839
- package/vendor/librocksdb/vendor/rocksdb/db/db_test_util.cc +0 -1800
- package/vendor/librocksdb/vendor/rocksdb/db/db_test_util.h +0 -1427
- package/vendor/librocksdb/vendor/rocksdb/db/db_with_timestamp_test_util.cc +0 -96
- package/vendor/librocksdb/vendor/rocksdb/db/db_with_timestamp_test_util.h +0 -126
- package/vendor/librocksdb/vendor/rocksdb/db/dbformat.cc +0 -282
- package/vendor/librocksdb/vendor/rocksdb/db/dbformat.h +0 -1101
- package/vendor/librocksdb/vendor/rocksdb/db/error_handler.cc +0 -806
- package/vendor/librocksdb/vendor/rocksdb/db/error_handler.h +0 -149
- package/vendor/librocksdb/vendor/rocksdb/db/event_helpers.cc +0 -332
- package/vendor/librocksdb/vendor/rocksdb/db/event_helpers.h +0 -78
- package/vendor/librocksdb/vendor/rocksdb/db/experimental.cc +0 -1212
- package/vendor/librocksdb/vendor/rocksdb/db/external_sst_file_ingestion_job.cc +0 -1249
- package/vendor/librocksdb/vendor/rocksdb/db/external_sst_file_ingestion_job.h +0 -268
- package/vendor/librocksdb/vendor/rocksdb/db/file_indexer.cc +0 -216
- package/vendor/librocksdb/vendor/rocksdb/db/file_indexer.h +0 -140
- package/vendor/librocksdb/vendor/rocksdb/db/flush_job.cc +0 -1217
- package/vendor/librocksdb/vendor/rocksdb/db/flush_job.h +0 -240
- package/vendor/librocksdb/vendor/rocksdb/db/flush_scheduler.cc +0 -86
- package/vendor/librocksdb/vendor/rocksdb/db/flush_scheduler.h +0 -55
- package/vendor/librocksdb/vendor/rocksdb/db/forward_iterator.cc +0 -1082
- package/vendor/librocksdb/vendor/rocksdb/db/forward_iterator.h +0 -166
- package/vendor/librocksdb/vendor/rocksdb/db/forward_iterator_bench.cc +0 -378
- package/vendor/librocksdb/vendor/rocksdb/db/history_trimming_iterator.h +0 -95
- package/vendor/librocksdb/vendor/rocksdb/db/import_column_family_job.cc +0 -463
- package/vendor/librocksdb/vendor/rocksdb/db/import_column_family_job.h +0 -91
- package/vendor/librocksdb/vendor/rocksdb/db/internal_stats.cc +0 -2198
- package/vendor/librocksdb/vendor/rocksdb/db/internal_stats.h +0 -896
- package/vendor/librocksdb/vendor/rocksdb/db/job_context.h +0 -254
- package/vendor/librocksdb/vendor/rocksdb/db/kv_checksum.h +0 -484
- package/vendor/librocksdb/vendor/rocksdb/db/log_format.h +0 -55
- package/vendor/librocksdb/vendor/rocksdb/db/log_reader.cc +0 -958
- package/vendor/librocksdb/vendor/rocksdb/db/log_reader.h +0 -245
- package/vendor/librocksdb/vendor/rocksdb/db/log_writer.cc +0 -355
- package/vendor/librocksdb/vendor/rocksdb/db/log_writer.h +0 -151
- package/vendor/librocksdb/vendor/rocksdb/db/logs_with_prep_tracker.cc +0 -67
- package/vendor/librocksdb/vendor/rocksdb/db/logs_with_prep_tracker.h +0 -62
- package/vendor/librocksdb/vendor/rocksdb/db/lookup_key.h +0 -68
- package/vendor/librocksdb/vendor/rocksdb/db/malloc_stats.cc +0 -52
- package/vendor/librocksdb/vendor/rocksdb/db/malloc_stats.h +0 -22
- package/vendor/librocksdb/vendor/rocksdb/db/memtable.cc +0 -1684
- package/vendor/librocksdb/vendor/rocksdb/db/memtable.h +0 -712
- package/vendor/librocksdb/vendor/rocksdb/db/memtable_list.cc +0 -1028
- package/vendor/librocksdb/vendor/rocksdb/db/memtable_list.h +0 -514
- package/vendor/librocksdb/vendor/rocksdb/db/merge_context.h +0 -150
- package/vendor/librocksdb/vendor/rocksdb/db/merge_helper.cc +0 -699
- package/vendor/librocksdb/vendor/rocksdb/db/merge_helper.h +0 -318
- package/vendor/librocksdb/vendor/rocksdb/db/merge_operator.cc +0 -167
- package/vendor/librocksdb/vendor/rocksdb/db/multi_cf_iterator_impl.h +0 -296
- package/vendor/librocksdb/vendor/rocksdb/db/output_validator.cc +0 -29
- package/vendor/librocksdb/vendor/rocksdb/db/output_validator.h +0 -45
- package/vendor/librocksdb/vendor/rocksdb/db/periodic_task_scheduler.cc +0 -110
- package/vendor/librocksdb/vendor/rocksdb/db/periodic_task_scheduler.h +0 -108
- package/vendor/librocksdb/vendor/rocksdb/db/pinned_iterators_manager.h +0 -92
- package/vendor/librocksdb/vendor/rocksdb/db/post_memtable_callback.h +0 -25
- package/vendor/librocksdb/vendor/rocksdb/db/pre_release_callback.h +0 -37
- package/vendor/librocksdb/vendor/rocksdb/db/range_del_aggregator.cc +0 -553
- package/vendor/librocksdb/vendor/rocksdb/db/range_del_aggregator.h +0 -481
- package/vendor/librocksdb/vendor/rocksdb/db/range_del_aggregator_bench.cc +0 -280
- package/vendor/librocksdb/vendor/rocksdb/db/range_tombstone_fragmenter.cc +0 -515
- package/vendor/librocksdb/vendor/rocksdb/db/range_tombstone_fragmenter.h +0 -361
- package/vendor/librocksdb/vendor/rocksdb/db/read_callback.h +0 -54
- package/vendor/librocksdb/vendor/rocksdb/db/repair.cc +0 -864
- package/vendor/librocksdb/vendor/rocksdb/db/seqno_to_time_mapping.cc +0 -573
- package/vendor/librocksdb/vendor/rocksdb/db/seqno_to_time_mapping.h +0 -307
- package/vendor/librocksdb/vendor/rocksdb/db/snapshot_checker.h +0 -58
- package/vendor/librocksdb/vendor/rocksdb/db/snapshot_impl.cc +0 -25
- package/vendor/librocksdb/vendor/rocksdb/db/snapshot_impl.h +0 -239
- package/vendor/librocksdb/vendor/rocksdb/db/table_cache.cc +0 -745
- package/vendor/librocksdb/vendor/rocksdb/db/table_cache.h +0 -298
- package/vendor/librocksdb/vendor/rocksdb/db/table_cache_sync_and_async.h +0 -135
- package/vendor/librocksdb/vendor/rocksdb/db/table_properties_collector.cc +0 -74
- package/vendor/librocksdb/vendor/rocksdb/db/table_properties_collector.h +0 -185
- package/vendor/librocksdb/vendor/rocksdb/db/transaction_log_impl.cc +0 -296
- package/vendor/librocksdb/vendor/rocksdb/db/transaction_log_impl.h +0 -128
- package/vendor/librocksdb/vendor/rocksdb/db/trim_history_scheduler.cc +0 -54
- package/vendor/librocksdb/vendor/rocksdb/db/trim_history_scheduler.h +0 -46
- package/vendor/librocksdb/vendor/rocksdb/db/version_builder.cc +0 -1431
- package/vendor/librocksdb/vendor/rocksdb/db/version_builder.h +0 -93
- package/vendor/librocksdb/vendor/rocksdb/db/version_edit.cc +0 -1119
- package/vendor/librocksdb/vendor/rocksdb/db/version_edit.h +0 -769
- package/vendor/librocksdb/vendor/rocksdb/db/version_edit_handler.cc +0 -1264
- package/vendor/librocksdb/vendor/rocksdb/db/version_edit_handler.h +0 -390
- package/vendor/librocksdb/vendor/rocksdb/db/version_set.cc +0 -7562
- package/vendor/librocksdb/vendor/rocksdb/db/version_set.h +0 -1799
- package/vendor/librocksdb/vendor/rocksdb/db/version_set_sync_and_async.h +0 -169
- package/vendor/librocksdb/vendor/rocksdb/db/version_util.h +0 -77
- package/vendor/librocksdb/vendor/rocksdb/db/wal_edit.cc +0 -211
- package/vendor/librocksdb/vendor/rocksdb/db/wal_edit.h +0 -177
- package/vendor/librocksdb/vendor/rocksdb/db/wal_manager.cc +0 -539
- package/vendor/librocksdb/vendor/rocksdb/db/wal_manager.h +0 -138
- package/vendor/librocksdb/vendor/rocksdb/db/wide/wide_column_serialization.cc +0 -166
- package/vendor/librocksdb/vendor/rocksdb/db/wide/wide_column_serialization.h +0 -57
- package/vendor/librocksdb/vendor/rocksdb/db/wide/wide_columns.cc +0 -22
- package/vendor/librocksdb/vendor/rocksdb/db/wide/wide_columns_helper.cc +0 -52
- package/vendor/librocksdb/vendor/rocksdb/db/wide/wide_columns_helper.h +0 -40
- package/vendor/librocksdb/vendor/rocksdb/db/write_batch.cc +0 -3394
- package/vendor/librocksdb/vendor/rocksdb/db/write_batch_base.cc +0 -94
- package/vendor/librocksdb/vendor/rocksdb/db/write_batch_internal.h +0 -408
- package/vendor/librocksdb/vendor/rocksdb/db/write_callback.h +0 -27
- package/vendor/librocksdb/vendor/rocksdb/db/write_controller.cc +0 -121
- package/vendor/librocksdb/vendor/rocksdb/db/write_controller.h +0 -148
- package/vendor/librocksdb/vendor/rocksdb/db/write_stall_stats.cc +0 -179
- package/vendor/librocksdb/vendor/rocksdb/db/write_stall_stats.h +0 -47
- package/vendor/librocksdb/vendor/rocksdb/db/write_thread.cc +0 -931
- package/vendor/librocksdb/vendor/rocksdb/db/write_thread.h +0 -498
- package/vendor/librocksdb/vendor/rocksdb/env/composite_env.cc +0 -534
- package/vendor/librocksdb/vendor/rocksdb/env/composite_env_wrapper.h +0 -399
- package/vendor/librocksdb/vendor/rocksdb/env/emulated_clock.h +0 -114
- package/vendor/librocksdb/vendor/rocksdb/env/env.cc +0 -1253
- package/vendor/librocksdb/vendor/rocksdb/env/env_chroot.cc +0 -149
- package/vendor/librocksdb/vendor/rocksdb/env/env_chroot.h +0 -55
- package/vendor/librocksdb/vendor/rocksdb/env/env_encryption.cc +0 -1192
- package/vendor/librocksdb/vendor/rocksdb/env/env_encryption_ctr.h +0 -97
- package/vendor/librocksdb/vendor/rocksdb/env/env_posix.cc +0 -530
- package/vendor/librocksdb/vendor/rocksdb/env/file_system.cc +0 -278
- package/vendor/librocksdb/vendor/rocksdb/env/file_system_tracer.cc +0 -564
- package/vendor/librocksdb/vendor/rocksdb/env/file_system_tracer.h +0 -461
- package/vendor/librocksdb/vendor/rocksdb/env/fs_on_demand.cc +0 -331
- package/vendor/librocksdb/vendor/rocksdb/env/fs_on_demand.h +0 -139
- package/vendor/librocksdb/vendor/rocksdb/env/fs_posix.cc +0 -1285
- package/vendor/librocksdb/vendor/rocksdb/env/fs_readonly.h +0 -105
- package/vendor/librocksdb/vendor/rocksdb/env/fs_remap.cc +0 -341
- package/vendor/librocksdb/vendor/rocksdb/env/fs_remap.h +0 -137
- package/vendor/librocksdb/vendor/rocksdb/env/io_posix.cc +0 -1738
- package/vendor/librocksdb/vendor/rocksdb/env/io_posix.h +0 -517
- package/vendor/librocksdb/vendor/rocksdb/env/mock_env.cc +0 -1058
- package/vendor/librocksdb/vendor/rocksdb/env/mock_env.h +0 -144
- package/vendor/librocksdb/vendor/rocksdb/env/unique_id_gen.cc +0 -243
- package/vendor/librocksdb/vendor/rocksdb/env/unique_id_gen.h +0 -119
- package/vendor/librocksdb/vendor/rocksdb/file/delete_scheduler.cc +0 -513
- package/vendor/librocksdb/vendor/rocksdb/file/delete_scheduler.h +0 -200
- package/vendor/librocksdb/vendor/rocksdb/file/file_prefetch_buffer.cc +0 -992
- package/vendor/librocksdb/vendor/rocksdb/file/file_prefetch_buffer.h +0 -629
- package/vendor/librocksdb/vendor/rocksdb/file/file_util.cc +0 -308
- package/vendor/librocksdb/vendor/rocksdb/file/file_util.h +0 -123
- package/vendor/librocksdb/vendor/rocksdb/file/filename.cc +0 -538
- package/vendor/librocksdb/vendor/rocksdb/file/filename.h +0 -186
- package/vendor/librocksdb/vendor/rocksdb/file/line_file_reader.cc +0 -73
- package/vendor/librocksdb/vendor/rocksdb/file/line_file_reader.h +0 -60
- package/vendor/librocksdb/vendor/rocksdb/file/random_access_file_reader.cc +0 -639
- package/vendor/librocksdb/vendor/rocksdb/file/random_access_file_reader.h +0 -197
- package/vendor/librocksdb/vendor/rocksdb/file/read_write_util.cc +0 -33
- package/vendor/librocksdb/vendor/rocksdb/file/read_write_util.h +0 -31
- package/vendor/librocksdb/vendor/rocksdb/file/readahead_file_info.h +0 -33
- package/vendor/librocksdb/vendor/rocksdb/file/readahead_raf.cc +0 -169
- package/vendor/librocksdb/vendor/rocksdb/file/readahead_raf.h +0 -29
- package/vendor/librocksdb/vendor/rocksdb/file/sequence_file_reader.cc +0 -324
- package/vendor/librocksdb/vendor/rocksdb/file/sequence_file_reader.h +0 -127
- package/vendor/librocksdb/vendor/rocksdb/file/sst_file_manager_impl.cc +0 -525
- package/vendor/librocksdb/vendor/rocksdb/file/sst_file_manager_impl.h +0 -220
- package/vendor/librocksdb/vendor/rocksdb/file/writable_file_writer.cc +0 -1007
- package/vendor/librocksdb/vendor/rocksdb/file/writable_file_writer.h +0 -370
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/advanced_cache.h +0 -665
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/advanced_options.h +0 -1101
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/attribute_groups.h +0 -114
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/block_cache_trace_writer.h +0 -149
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/c.h +0 -3122
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/cache.h +0 -579
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/cache_bench_tool.h +0 -14
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/cleanable.h +0 -128
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/compaction_filter.h +0 -374
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/compaction_job_stats.h +0 -112
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/comparator.h +0 -231
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/compression_type.h +0 -186
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/concurrent_task_limiter.h +0 -51
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/configurable.h +0 -390
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/convenience.h +0 -466
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/customizable.h +0 -229
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/data_structure.h +0 -186
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/db.h +0 -2174
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/db_bench_tool.h +0 -11
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/db_dump_tool.h +0 -43
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/db_stress_tool.h +0 -11
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/env.h +0 -1920
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/env_encryption.h +0 -363
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/experimental.h +0 -492
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/file_checksum.h +0 -146
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/file_system.h +0 -1961
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/filter_policy.h +0 -211
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/flush_block_policy.h +0 -75
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/functor_wrapper.h +0 -56
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/io_status.h +0 -244
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/iostats_context.h +0 -98
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/iterator.h +0 -104
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/iterator_base.h +0 -90
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/ldb_tool.h +0 -42
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/listener.h +0 -869
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/memory_allocator.h +0 -87
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/memtablerep.h +0 -421
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/merge_operator.h +0 -337
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/metadata.h +0 -258
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/options.h +0 -2339
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/perf_context.h +0 -319
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/perf_level.h +0 -39
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/persistent_cache.h +0 -74
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/port_defs.h +0 -26
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/rate_limiter.h +0 -172
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/rocksdb_namespace.h +0 -16
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/secondary_cache.h +0 -220
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/slice.h +0 -264
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/slice_transform.h +0 -135
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/snapshot.h +0 -53
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/sst_dump_tool.h +0 -17
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/sst_file_manager.h +0 -139
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/sst_file_reader.h +0 -61
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/sst_file_writer.h +0 -203
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/sst_partitioner.h +0 -142
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/statistics.h +0 -794
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/stats_history.h +0 -70
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/status.h +0 -609
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/system_clock.h +0 -129
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/table.h +0 -938
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/table_properties.h +0 -380
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/table_reader_caller.h +0 -41
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/thread_status.h +0 -197
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/threadpool.h +0 -67
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/trace_reader_writer.h +0 -52
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/trace_record.h +0 -248
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/trace_record_result.h +0 -187
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/transaction_log.h +0 -128
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/types.h +0 -113
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/unique_id.h +0 -55
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/universal_compaction.h +0 -127
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/user_write_callback.h +0 -29
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/agg_merge.h +0 -138
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/backup_engine.h +0 -689
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/cache_dump_load.h +0 -144
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/checkpoint.h +0 -65
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/convenience.h +0 -10
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/customizable_util.h +0 -321
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/db_ttl.h +0 -70
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/debug.h +0 -46
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/env_mirror.h +0 -179
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/info_log_finder.h +0 -19
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/ldb_cmd.h +0 -338
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/ldb_cmd_execute_result.h +0 -75
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/leveldb_options.h +0 -145
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/lua/rocks_lua_custom_library.h +0 -43
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/lua/rocks_lua_util.h +0 -55
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/memory_util.h +0 -48
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/object_registry.h +0 -583
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/optimistic_transaction_db.h +0 -129
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/option_change_migration.h +0 -24
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/options_type.h +0 -1222
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/options_util.h +0 -105
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/replayer.h +0 -85
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/sim_cache.h +0 -92
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/stackable_db.h +0 -593
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/table_properties_collectors.h +0 -133
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/transaction.h +0 -765
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/transaction_db.h +0 -510
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/transaction_db_mutex.h +0 -89
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/types_util.h +0 -36
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/utilities/write_batch_with_index.h +0 -402
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/version.h +0 -43
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/wal_filter.h +0 -111
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/wide_columns.h +0 -303
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/write_batch.h +0 -518
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/write_batch_base.h +0 -165
- package/vendor/librocksdb/vendor/rocksdb/include/rocksdb/write_buffer_manager.h +0 -183
- package/vendor/librocksdb/vendor/rocksdb/logging/auto_roll_logger.cc +0 -366
- package/vendor/librocksdb/vendor/rocksdb/logging/auto_roll_logger.h +0 -165
- package/vendor/librocksdb/vendor/rocksdb/logging/env_logger.h +0 -195
- package/vendor/librocksdb/vendor/rocksdb/logging/event_logger.cc +0 -68
- package/vendor/librocksdb/vendor/rocksdb/logging/event_logger.h +0 -202
- package/vendor/librocksdb/vendor/rocksdb/logging/log_buffer.cc +0 -91
- package/vendor/librocksdb/vendor/rocksdb/logging/log_buffer.h +0 -57
- package/vendor/librocksdb/vendor/rocksdb/logging/logging.h +0 -62
- package/vendor/librocksdb/vendor/rocksdb/memory/allocator.h +0 -58
- package/vendor/librocksdb/vendor/rocksdb/memory/arena.cc +0 -170
- package/vendor/librocksdb/vendor/rocksdb/memory/arena.h +0 -146
- package/vendor/librocksdb/vendor/rocksdb/memory/concurrent_arena.cc +0 -45
- package/vendor/librocksdb/vendor/rocksdb/memory/concurrent_arena.h +0 -215
- package/vendor/librocksdb/vendor/rocksdb/memory/jemalloc_nodump_allocator.cc +0 -304
- package/vendor/librocksdb/vendor/rocksdb/memory/jemalloc_nodump_allocator.h +0 -99
- package/vendor/librocksdb/vendor/rocksdb/memory/memkind_kmem_allocator.cc +0 -44
- package/vendor/librocksdb/vendor/rocksdb/memory/memkind_kmem_allocator.h +0 -43
- package/vendor/librocksdb/vendor/rocksdb/memory/memory_allocator.cc +0 -81
- package/vendor/librocksdb/vendor/rocksdb/memory/memory_allocator_impl.h +0 -47
- package/vendor/librocksdb/vendor/rocksdb/memory/memory_usage.h +0 -38
- package/vendor/librocksdb/vendor/rocksdb/memtable/alloc_tracker.cc +0 -63
- package/vendor/librocksdb/vendor/rocksdb/memtable/hash_linklist_rep.cc +0 -925
- package/vendor/librocksdb/vendor/rocksdb/memtable/hash_skiplist_rep.cc +0 -392
- package/vendor/librocksdb/vendor/rocksdb/memtable/inlineskiplist.h +0 -1051
- package/vendor/librocksdb/vendor/rocksdb/memtable/memtablerep_bench.cc +0 -687
- package/vendor/librocksdb/vendor/rocksdb/memtable/skiplist.h +0 -498
- package/vendor/librocksdb/vendor/rocksdb/memtable/skiplistrep.cc +0 -368
- package/vendor/librocksdb/vendor/rocksdb/memtable/stl_wrappers.h +0 -33
- package/vendor/librocksdb/vendor/rocksdb/memtable/vectorrep.cc +0 -307
- package/vendor/librocksdb/vendor/rocksdb/memtable/write_buffer_manager.cc +0 -185
- package/vendor/librocksdb/vendor/rocksdb/monitoring/file_read_sample.h +0 -23
- package/vendor/librocksdb/vendor/rocksdb/monitoring/histogram.cc +0 -280
- package/vendor/librocksdb/vendor/rocksdb/monitoring/histogram.h +0 -143
- package/vendor/librocksdb/vendor/rocksdb/monitoring/histogram_windowing.cc +0 -198
- package/vendor/librocksdb/vendor/rocksdb/monitoring/histogram_windowing.h +0 -84
- package/vendor/librocksdb/vendor/rocksdb/monitoring/in_memory_stats_history.cc +0 -50
- package/vendor/librocksdb/vendor/rocksdb/monitoring/in_memory_stats_history.h +0 -74
- package/vendor/librocksdb/vendor/rocksdb/monitoring/instrumented_mutex.cc +0 -90
- package/vendor/librocksdb/vendor/rocksdb/monitoring/instrumented_mutex.h +0 -126
- package/vendor/librocksdb/vendor/rocksdb/monitoring/iostats_context.cc +0 -78
- package/vendor/librocksdb/vendor/rocksdb/monitoring/iostats_context_imp.h +0 -62
- package/vendor/librocksdb/vendor/rocksdb/monitoring/perf_context.cc +0 -317
- package/vendor/librocksdb/vendor/rocksdb/monitoring/perf_context_imp.h +0 -103
- package/vendor/librocksdb/vendor/rocksdb/monitoring/perf_level.cc +0 -23
- package/vendor/librocksdb/vendor/rocksdb/monitoring/perf_level_imp.h +0 -14
- package/vendor/librocksdb/vendor/rocksdb/monitoring/perf_step_timer.h +0 -77
- package/vendor/librocksdb/vendor/rocksdb/monitoring/persistent_stats_history.cc +0 -173
- package/vendor/librocksdb/vendor/rocksdb/monitoring/persistent_stats_history.h +0 -83
- package/vendor/librocksdb/vendor/rocksdb/monitoring/statistics.cc +0 -561
- package/vendor/librocksdb/vendor/rocksdb/monitoring/statistics_impl.h +0 -143
- package/vendor/librocksdb/vendor/rocksdb/monitoring/thread_status_impl.cc +0 -163
- package/vendor/librocksdb/vendor/rocksdb/monitoring/thread_status_updater.cc +0 -328
- package/vendor/librocksdb/vendor/rocksdb/monitoring/thread_status_updater.h +0 -226
- package/vendor/librocksdb/vendor/rocksdb/monitoring/thread_status_updater_debug.cc +0 -43
- package/vendor/librocksdb/vendor/rocksdb/monitoring/thread_status_util.cc +0 -214
- package/vendor/librocksdb/vendor/rocksdb/monitoring/thread_status_util.h +0 -139
- package/vendor/librocksdb/vendor/rocksdb/monitoring/thread_status_util_debug.cc +0 -60
- package/vendor/librocksdb/vendor/rocksdb/options/cf_options.cc +0 -1218
- package/vendor/librocksdb/vendor/rocksdb/options/cf_options.h +0 -352
- package/vendor/librocksdb/vendor/rocksdb/options/configurable.cc +0 -720
- package/vendor/librocksdb/vendor/rocksdb/options/configurable_helper.h +0 -185
- package/vendor/librocksdb/vendor/rocksdb/options/configurable_test.h +0 -116
- package/vendor/librocksdb/vendor/rocksdb/options/customizable.cc +0 -133
- package/vendor/librocksdb/vendor/rocksdb/options/db_options.cc +0 -1113
- package/vendor/librocksdb/vendor/rocksdb/options/db_options.h +0 -160
- package/vendor/librocksdb/vendor/rocksdb/options/offpeak_time_info.cc +0 -59
- package/vendor/librocksdb/vendor/rocksdb/options/offpeak_time_info.h +0 -37
- package/vendor/librocksdb/vendor/rocksdb/options/options.cc +0 -717
- package/vendor/librocksdb/vendor/rocksdb/options/options_helper.cc +0 -1438
- package/vendor/librocksdb/vendor/rocksdb/options/options_helper.h +0 -115
- package/vendor/librocksdb/vendor/rocksdb/options/options_parser.cc +0 -745
- package/vendor/librocksdb/vendor/rocksdb/options/options_parser.h +0 -151
- package/vendor/librocksdb/vendor/rocksdb/port/jemalloc_helper.h +0 -107
- package/vendor/librocksdb/vendor/rocksdb/port/lang.h +0 -97
- package/vendor/librocksdb/vendor/rocksdb/port/likely.h +0 -18
- package/vendor/librocksdb/vendor/rocksdb/port/malloc.h +0 -17
- package/vendor/librocksdb/vendor/rocksdb/port/mmap.cc +0 -98
- package/vendor/librocksdb/vendor/rocksdb/port/mmap.h +0 -90
- package/vendor/librocksdb/vendor/rocksdb/port/port.h +0 -21
- package/vendor/librocksdb/vendor/rocksdb/port/port_dirent.h +0 -44
- package/vendor/librocksdb/vendor/rocksdb/port/port_example.h +0 -101
- package/vendor/librocksdb/vendor/rocksdb/port/port_posix.cc +0 -300
- package/vendor/librocksdb/vendor/rocksdb/port/port_posix.h +0 -246
- package/vendor/librocksdb/vendor/rocksdb/port/stack_trace.cc +0 -418
- package/vendor/librocksdb/vendor/rocksdb/port/stack_trace.h +0 -31
- package/vendor/librocksdb/vendor/rocksdb/port/sys_time.h +0 -63
- package/vendor/librocksdb/vendor/rocksdb/port/util_logger.h +0 -18
- package/vendor/librocksdb/vendor/rocksdb/port/win/env_default.cc +0 -45
- package/vendor/librocksdb/vendor/rocksdb/port/win/env_win.cc +0 -1436
- package/vendor/librocksdb/vendor/rocksdb/port/win/env_win.h +0 -305
- package/vendor/librocksdb/vendor/rocksdb/port/win/io_win.cc +0 -1101
- package/vendor/librocksdb/vendor/rocksdb/port/win/io_win.h +0 -504
- package/vendor/librocksdb/vendor/rocksdb/port/win/port_win.cc +0 -305
- package/vendor/librocksdb/vendor/rocksdb/port/win/port_win.h +0 -382
- package/vendor/librocksdb/vendor/rocksdb/port/win/win_jemalloc.cc +0 -80
- package/vendor/librocksdb/vendor/rocksdb/port/win/win_logger.cc +0 -192
- package/vendor/librocksdb/vendor/rocksdb/port/win/win_logger.h +0 -64
- package/vendor/librocksdb/vendor/rocksdb/port/win/win_thread.cc +0 -170
- package/vendor/librocksdb/vendor/rocksdb/port/win/win_thread.h +0 -117
- package/vendor/librocksdb/vendor/rocksdb/port/win/xpress_win.cc +0 -210
- package/vendor/librocksdb/vendor/rocksdb/port/win/xpress_win.h +0 -26
- package/vendor/librocksdb/vendor/rocksdb/port/xpress.h +0 -17
- package/vendor/librocksdb/vendor/rocksdb/rocksdb.pc.in +0 -10
- package/vendor/librocksdb/vendor/rocksdb/table/adaptive/adaptive_table_factory.cc +0 -119
- package/vendor/librocksdb/vendor/rocksdb/table/adaptive/adaptive_table_factory.h +0 -56
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/binary_search_index_reader.cc +0 -73
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/binary_search_index_reader.h +0 -48
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block.cc +0 -1341
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block.h +0 -969
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_builder.cc +0 -2148
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_builder.h +0 -208
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_factory.cc +0 -980
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_factory.h +0 -102
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_iterator.cc +0 -893
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_iterator.h +0 -445
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_reader.cc +0 -3296
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_reader.h +0 -785
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_reader_impl.h +0 -205
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_based_table_reader_sync_and_async.h +0 -819
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_builder.cc +0 -266
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_builder.h +0 -128
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_cache.cc +0 -108
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_cache.h +0 -190
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_prefetcher.cc +0 -158
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_prefetcher.h +0 -74
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_prefix_index.cc +0 -226
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_prefix_index.h +0 -70
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/block_type.h +0 -34
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/cachable_entry.h +0 -249
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/data_block_footer.cc +0 -59
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/data_block_footer.h +0 -25
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/data_block_hash_index.cc +0 -94
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/data_block_hash_index.h +0 -137
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/filter_block.h +0 -189
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/filter_block_reader_common.cc +0 -169
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/filter_block_reader_common.h +0 -79
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/filter_policy.cc +0 -1989
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/filter_policy_internal.h +0 -341
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/flush_block_policy.cc +0 -132
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/flush_block_policy_impl.h +0 -40
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/full_filter_block.cc +0 -297
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/full_filter_block.h +0 -142
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/hash_index_reader.cc +0 -146
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/hash_index_reader.h +0 -49
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/index_builder.cc +0 -305
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/index_builder.h +0 -534
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/index_reader_common.cc +0 -62
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/index_reader_common.h +0 -94
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/mock_block_based_table.h +0 -62
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/parsed_full_filter_block.cc +0 -23
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/parsed_full_filter_block.h +0 -47
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/partitioned_filter_block.cc +0 -610
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/partitioned_filter_block.h +0 -188
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/partitioned_index_iterator.cc +0 -164
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/partitioned_index_iterator.h +0 -160
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/partitioned_index_reader.cc +0 -264
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/partitioned_index_reader.h +0 -58
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/reader_common.cc +0 -64
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/reader_common.h +0 -36
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/uncompression_dict_reader.cc +0 -118
- package/vendor/librocksdb/vendor/rocksdb/table/block_based/uncompression_dict_reader.h +0 -60
- package/vendor/librocksdb/vendor/rocksdb/table/block_fetcher.cc +0 -458
- package/vendor/librocksdb/vendor/rocksdb/table/block_fetcher.h +0 -168
- package/vendor/librocksdb/vendor/rocksdb/table/compaction_merging_iterator.cc +0 -370
- package/vendor/librocksdb/vendor/rocksdb/table/compaction_merging_iterator.h +0 -45
- package/vendor/librocksdb/vendor/rocksdb/table/cuckoo/cuckoo_table_builder.cc +0 -555
- package/vendor/librocksdb/vendor/rocksdb/table/cuckoo/cuckoo_table_builder.h +0 -136
- package/vendor/librocksdb/vendor/rocksdb/table/cuckoo/cuckoo_table_factory.cc +0 -100
- package/vendor/librocksdb/vendor/rocksdb/table/cuckoo/cuckoo_table_factory.h +0 -80
- package/vendor/librocksdb/vendor/rocksdb/table/cuckoo/cuckoo_table_reader.cc +0 -416
- package/vendor/librocksdb/vendor/rocksdb/table/cuckoo/cuckoo_table_reader.h +0 -100
- package/vendor/librocksdb/vendor/rocksdb/table/format.cc +0 -708
- package/vendor/librocksdb/vendor/rocksdb/table/format.h +0 -439
- package/vendor/librocksdb/vendor/rocksdb/table/get_context.cc +0 -622
- package/vendor/librocksdb/vendor/rocksdb/table/get_context.h +0 -259
- package/vendor/librocksdb/vendor/rocksdb/table/internal_iterator.h +0 -242
- package/vendor/librocksdb/vendor/rocksdb/table/iter_heap.h +0 -44
- package/vendor/librocksdb/vendor/rocksdb/table/iterator.cc +0 -134
- package/vendor/librocksdb/vendor/rocksdb/table/iterator_wrapper.h +0 -225
- package/vendor/librocksdb/vendor/rocksdb/table/merging_iterator.cc +0 -1755
- package/vendor/librocksdb/vendor/rocksdb/table/merging_iterator.h +0 -100
- package/vendor/librocksdb/vendor/rocksdb/table/meta_blocks.cc +0 -590
- package/vendor/librocksdb/vendor/rocksdb/table/meta_blocks.h +0 -181
- package/vendor/librocksdb/vendor/rocksdb/table/mock_table.cc +0 -355
- package/vendor/librocksdb/vendor/rocksdb/table/mock_table.h +0 -92
- package/vendor/librocksdb/vendor/rocksdb/table/multiget_context.h +0 -405
- package/vendor/librocksdb/vendor/rocksdb/table/persistent_cache_helper.cc +0 -110
- package/vendor/librocksdb/vendor/rocksdb/table/persistent_cache_helper.h +0 -46
- package/vendor/librocksdb/vendor/rocksdb/table/persistent_cache_options.h +0 -34
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_bloom.cc +0 -78
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_bloom.h +0 -132
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_builder.cc +0 -348
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_builder.h +0 -151
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_factory.cc +0 -295
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_factory.h +0 -180
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_index.cc +0 -211
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_index.h +0 -246
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_key_coding.cc +0 -508
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_key_coding.h +0 -199
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_reader.cc +0 -778
- package/vendor/librocksdb/vendor/rocksdb/table/plain/plain_table_reader.h +0 -243
- package/vendor/librocksdb/vendor/rocksdb/table/sst_file_dumper.cc +0 -601
- package/vendor/librocksdb/vendor/rocksdb/table/sst_file_dumper.h +0 -104
- package/vendor/librocksdb/vendor/rocksdb/table/sst_file_reader.cc +0 -166
- package/vendor/librocksdb/vendor/rocksdb/table/sst_file_writer.cc +0 -536
- package/vendor/librocksdb/vendor/rocksdb/table/sst_file_writer_collectors.h +0 -97
- package/vendor/librocksdb/vendor/rocksdb/table/table_builder.h +0 -239
- package/vendor/librocksdb/vendor/rocksdb/table/table_factory.cc +0 -52
- package/vendor/librocksdb/vendor/rocksdb/table/table_iterator.h +0 -69
- package/vendor/librocksdb/vendor/rocksdb/table/table_properties.cc +0 -357
- package/vendor/librocksdb/vendor/rocksdb/table/table_properties_internal.h +0 -14
- package/vendor/librocksdb/vendor/rocksdb/table/table_reader.h +0 -202
- package/vendor/librocksdb/vendor/rocksdb/table/table_reader_bench.cc +0 -341
- package/vendor/librocksdb/vendor/rocksdb/table/two_level_iterator.cc +0 -222
- package/vendor/librocksdb/vendor/rocksdb/table/two_level_iterator.h +0 -43
- package/vendor/librocksdb/vendor/rocksdb/table/unique_id.cc +0 -223
- package/vendor/librocksdb/vendor/rocksdb/table/unique_id_impl.h +0 -93
- package/vendor/librocksdb/vendor/rocksdb/test_util/mock_time_env.cc +0 -38
- package/vendor/librocksdb/vendor/rocksdb/test_util/mock_time_env.h +0 -109
- package/vendor/librocksdb/vendor/rocksdb/test_util/secondary_cache_test_util.cc +0 -93
- package/vendor/librocksdb/vendor/rocksdb/test_util/secondary_cache_test_util.h +0 -131
- package/vendor/librocksdb/vendor/rocksdb/test_util/sync_point.cc +0 -82
- package/vendor/librocksdb/vendor/rocksdb/test_util/sync_point.h +0 -182
- package/vendor/librocksdb/vendor/rocksdb/test_util/sync_point_impl.cc +0 -152
- package/vendor/librocksdb/vendor/rocksdb/test_util/sync_point_impl.h +0 -96
- package/vendor/librocksdb/vendor/rocksdb/test_util/testharness.cc +0 -105
- package/vendor/librocksdb/vendor/rocksdb/test_util/testharness.h +0 -124
- package/vendor/librocksdb/vendor/rocksdb/test_util/testutil.cc +0 -776
- package/vendor/librocksdb/vendor/rocksdb/test_util/testutil.h +0 -908
- package/vendor/librocksdb/vendor/rocksdb/test_util/transaction_test_util.cc +0 -400
- package/vendor/librocksdb/vendor/rocksdb/test_util/transaction_test_util.h +0 -147
- package/vendor/librocksdb/vendor/rocksdb/tools/CMakeLists.txt +0 -30
- package/vendor/librocksdb/vendor/rocksdb/tools/blob_dump.cc +0 -103
- package/vendor/librocksdb/vendor/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer.cc +0 -2331
- package/vendor/librocksdb/vendor/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer.h +0 -398
- package/vendor/librocksdb/vendor/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer_tool.cc +0 -17
- package/vendor/librocksdb/vendor/rocksdb/tools/db_bench.cc +0 -21
- package/vendor/librocksdb/vendor/rocksdb/tools/db_bench_tool.cc +0 -8743
- package/vendor/librocksdb/vendor/rocksdb/tools/db_repl_stress.cc +0 -132
- package/vendor/librocksdb/vendor/rocksdb/tools/dump/db_dump_tool.cc +0 -264
- package/vendor/librocksdb/vendor/rocksdb/tools/dump/rocksdb_dump.cc +0 -60
- package/vendor/librocksdb/vendor/rocksdb/tools/dump/rocksdb_undump.cc +0 -59
- package/vendor/librocksdb/vendor/rocksdb/tools/io_tracer_parser.cc +0 -17
- package/vendor/librocksdb/vendor/rocksdb/tools/io_tracer_parser_tool.cc +0 -142
- package/vendor/librocksdb/vendor/rocksdb/tools/io_tracer_parser_tool.h +0 -38
- package/vendor/librocksdb/vendor/rocksdb/tools/ldb.cc +0 -13
- package/vendor/librocksdb/vendor/rocksdb/tools/ldb_cmd.cc +0 -5044
- package/vendor/librocksdb/vendor/rocksdb/tools/ldb_cmd_impl.h +0 -814
- package/vendor/librocksdb/vendor/rocksdb/tools/ldb_tool.cc +0 -192
- package/vendor/librocksdb/vendor/rocksdb/tools/simulated_hybrid_file_system.cc +0 -244
- package/vendor/librocksdb/vendor/rocksdb/tools/simulated_hybrid_file_system.h +0 -124
- package/vendor/librocksdb/vendor/rocksdb/tools/sst_dump.cc +0 -12
- package/vendor/librocksdb/vendor/rocksdb/tools/sst_dump_tool.cc +0 -588
- package/vendor/librocksdb/vendor/rocksdb/tools/trace_analyzer.cc +0 -17
- package/vendor/librocksdb/vendor/rocksdb/tools/trace_analyzer_tool.cc +0 -1935
- package/vendor/librocksdb/vendor/rocksdb/tools/trace_analyzer_tool.h +0 -329
- package/vendor/librocksdb/vendor/rocksdb/tools/write_stress.cc +0 -305
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/block_cache_tracer.cc +0 -509
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/block_cache_tracer.h +0 -239
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/io_tracer.cc +0 -303
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/io_tracer.h +0 -185
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/trace_record.cc +0 -206
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/trace_record_handler.cc +0 -190
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/trace_record_handler.h +0 -46
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/trace_record_result.cc +0 -146
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/trace_replay.cc +0 -632
- package/vendor/librocksdb/vendor/rocksdb/trace_replay/trace_replay.h +0 -184
- package/vendor/librocksdb/vendor/rocksdb/util/aligned_buffer.h +0 -235
- package/vendor/librocksdb/vendor/rocksdb/util/aligned_storage.h +0 -24
- package/vendor/librocksdb/vendor/rocksdb/util/async_file_reader.cc +0 -84
- package/vendor/librocksdb/vendor/rocksdb/util/async_file_reader.h +0 -144
- package/vendor/librocksdb/vendor/rocksdb/util/atomic.h +0 -111
- package/vendor/librocksdb/vendor/rocksdb/util/autovector.h +0 -397
- package/vendor/librocksdb/vendor/rocksdb/util/bloom_impl.h +0 -489
- package/vendor/librocksdb/vendor/rocksdb/util/build_version.cc.in +0 -79
- package/vendor/librocksdb/vendor/rocksdb/util/cast_util.h +0 -88
- package/vendor/librocksdb/vendor/rocksdb/util/channel.h +0 -69
- package/vendor/librocksdb/vendor/rocksdb/util/cleanable.cc +0 -181
- package/vendor/librocksdb/vendor/rocksdb/util/coding.cc +0 -90
- package/vendor/librocksdb/vendor/rocksdb/util/coding.h +0 -385
- package/vendor/librocksdb/vendor/rocksdb/util/coding_lean.h +0 -101
- package/vendor/librocksdb/vendor/rocksdb/util/compaction_job_stats_impl.cc +0 -94
- package/vendor/librocksdb/vendor/rocksdb/util/comparator.cc +0 -443
- package/vendor/librocksdb/vendor/rocksdb/util/compression.cc +0 -122
- package/vendor/librocksdb/vendor/rocksdb/util/compression.h +0 -1879
- package/vendor/librocksdb/vendor/rocksdb/util/compression_context_cache.cc +0 -106
- package/vendor/librocksdb/vendor/rocksdb/util/compression_context_cache.h +0 -47
- package/vendor/librocksdb/vendor/rocksdb/util/concurrent_task_limiter_impl.cc +0 -64
- package/vendor/librocksdb/vendor/rocksdb/util/concurrent_task_limiter_impl.h +0 -67
- package/vendor/librocksdb/vendor/rocksdb/util/core_local.h +0 -85
- package/vendor/librocksdb/vendor/rocksdb/util/coro_utils.h +0 -112
- package/vendor/librocksdb/vendor/rocksdb/util/crc32c.cc +0 -1295
- package/vendor/librocksdb/vendor/rocksdb/util/crc32c.h +0 -56
- package/vendor/librocksdb/vendor/rocksdb/util/crc32c_arm64.cc +0 -213
- package/vendor/librocksdb/vendor/rocksdb/util/crc32c_arm64.h +0 -51
- package/vendor/librocksdb/vendor/rocksdb/util/crc32c_ppc.c +0 -94
- package/vendor/librocksdb/vendor/rocksdb/util/crc32c_ppc.h +0 -21
- package/vendor/librocksdb/vendor/rocksdb/util/crc32c_ppc_asm.S +0 -756
- package/vendor/librocksdb/vendor/rocksdb/util/crc32c_ppc_constants.h +0 -900
- package/vendor/librocksdb/vendor/rocksdb/util/data_structure.cc +0 -16
- package/vendor/librocksdb/vendor/rocksdb/util/defer.h +0 -82
- package/vendor/librocksdb/vendor/rocksdb/util/distributed_mutex.h +0 -50
- package/vendor/librocksdb/vendor/rocksdb/util/duplicate_detector.h +0 -69
- package/vendor/librocksdb/vendor/rocksdb/util/dynamic_bloom.cc +0 -70
- package/vendor/librocksdb/vendor/rocksdb/util/dynamic_bloom.h +0 -214
- package/vendor/librocksdb/vendor/rocksdb/util/fastrange.h +0 -114
- package/vendor/librocksdb/vendor/rocksdb/util/file_checksum_helper.cc +0 -170
- package/vendor/librocksdb/vendor/rocksdb/util/file_checksum_helper.h +0 -101
- package/vendor/librocksdb/vendor/rocksdb/util/filter_bench.cc +0 -840
- package/vendor/librocksdb/vendor/rocksdb/util/gflags_compat.h +0 -29
- package/vendor/librocksdb/vendor/rocksdb/util/hash.cc +0 -201
- package/vendor/librocksdb/vendor/rocksdb/util/hash.h +0 -141
- package/vendor/librocksdb/vendor/rocksdb/util/hash128.h +0 -26
- package/vendor/librocksdb/vendor/rocksdb/util/hash_containers.h +0 -51
- package/vendor/librocksdb/vendor/rocksdb/util/hash_map.h +0 -67
- package/vendor/librocksdb/vendor/rocksdb/util/heap.h +0 -174
- package/vendor/librocksdb/vendor/rocksdb/util/kv_map.h +0 -33
- package/vendor/librocksdb/vendor/rocksdb/util/log_write_bench.cc +0 -88
- package/vendor/librocksdb/vendor/rocksdb/util/math.h +0 -351
- package/vendor/librocksdb/vendor/rocksdb/util/math128.h +0 -338
- package/vendor/librocksdb/vendor/rocksdb/util/murmurhash.cc +0 -196
- package/vendor/librocksdb/vendor/rocksdb/util/murmurhash.h +0 -43
- package/vendor/librocksdb/vendor/rocksdb/util/mutexlock.h +0 -189
- package/vendor/librocksdb/vendor/rocksdb/util/overload.h +0 -23
- package/vendor/librocksdb/vendor/rocksdb/util/ppc-opcode.h +0 -27
- package/vendor/librocksdb/vendor/rocksdb/util/random.cc +0 -63
- package/vendor/librocksdb/vendor/rocksdb/util/random.h +0 -190
- package/vendor/librocksdb/vendor/rocksdb/util/rate_limiter.cc +0 -391
- package/vendor/librocksdb/vendor/rocksdb/util/rate_limiter_impl.h +0 -156
- package/vendor/librocksdb/vendor/rocksdb/util/repeatable_thread.h +0 -149
- package/vendor/librocksdb/vendor/rocksdb/util/ribbon_alg.h +0 -1225
- package/vendor/librocksdb/vendor/rocksdb/util/ribbon_config.cc +0 -498
- package/vendor/librocksdb/vendor/rocksdb/util/ribbon_config.h +0 -182
- package/vendor/librocksdb/vendor/rocksdb/util/ribbon_impl.h +0 -1137
- package/vendor/librocksdb/vendor/rocksdb/util/set_comparator.h +0 -24
- package/vendor/librocksdb/vendor/rocksdb/util/single_thread_executor.h +0 -57
- package/vendor/librocksdb/vendor/rocksdb/util/slice.cc +0 -366
- package/vendor/librocksdb/vendor/rocksdb/util/status.cc +0 -163
- package/vendor/librocksdb/vendor/rocksdb/util/stderr_logger.cc +0 -62
- package/vendor/librocksdb/vendor/rocksdb/util/stderr_logger.h +0 -41
- package/vendor/librocksdb/vendor/rocksdb/util/stop_watch.h +0 -136
- package/vendor/librocksdb/vendor/rocksdb/util/string_util.cc +0 -554
- package/vendor/librocksdb/vendor/rocksdb/util/string_util.h +0 -185
- package/vendor/librocksdb/vendor/rocksdb/util/thread_guard.h +0 -41
- package/vendor/librocksdb/vendor/rocksdb/util/thread_local.cc +0 -521
- package/vendor/librocksdb/vendor/rocksdb/util/thread_local.h +0 -100
- package/vendor/librocksdb/vendor/rocksdb/util/thread_operation.h +0 -122
- package/vendor/librocksdb/vendor/rocksdb/util/threadpool_imp.cc +0 -550
- package/vendor/librocksdb/vendor/rocksdb/util/threadpool_imp.h +0 -120
- package/vendor/librocksdb/vendor/rocksdb/util/timer.h +0 -340
- package/vendor/librocksdb/vendor/rocksdb/util/timer_queue.h +0 -231
- package/vendor/librocksdb/vendor/rocksdb/util/udt_util.cc +0 -418
- package/vendor/librocksdb/vendor/rocksdb/util/udt_util.h +0 -275
- package/vendor/librocksdb/vendor/rocksdb/util/user_comparator_wrapper.h +0 -64
- package/vendor/librocksdb/vendor/rocksdb/util/vector_iterator.h +0 -114
- package/vendor/librocksdb/vendor/rocksdb/util/work_queue.h +0 -150
- package/vendor/librocksdb/vendor/rocksdb/util/write_batch_util.cc +0 -25
- package/vendor/librocksdb/vendor/rocksdb/util/write_batch_util.h +0 -90
- package/vendor/librocksdb/vendor/rocksdb/util/xxhash.cc +0 -48
- package/vendor/librocksdb/vendor/rocksdb/util/xxhash.h +0 -6364
- package/vendor/librocksdb/vendor/rocksdb/util/xxph3.h +0 -1760
- package/vendor/librocksdb/vendor/rocksdb/utilities/agg_merge/agg_merge.cc +0 -237
- package/vendor/librocksdb/vendor/rocksdb/utilities/agg_merge/agg_merge_impl.h +0 -49
- package/vendor/librocksdb/vendor/rocksdb/utilities/agg_merge/test_agg_merge.cc +0 -103
- package/vendor/librocksdb/vendor/rocksdb/utilities/agg_merge/test_agg_merge.h +0 -47
- package/vendor/librocksdb/vendor/rocksdb/utilities/backup/backup_engine.cc +0 -3357
- package/vendor/librocksdb/vendor/rocksdb/utilities/backup/backup_engine_impl.h +0 -34
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_compaction_filter.cc +0 -490
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_compaction_filter.h +0 -202
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_db.cc +0 -109
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_db.h +0 -231
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_db_gc_stats.h +0 -54
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_db_impl.cc +0 -2269
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_db_impl.h +0 -514
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_db_impl_filesnapshot.cc +0 -127
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_db_iterator.h +0 -148
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_db_listener.h +0 -71
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_dump_tool.cc +0 -276
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_dump_tool.h +0 -56
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_file.cc +0 -311
- package/vendor/librocksdb/vendor/rocksdb/utilities/blob_db/blob_file.h +0 -245
- package/vendor/librocksdb/vendor/rocksdb/utilities/cache_dump_load.cc +0 -67
- package/vendor/librocksdb/vendor/rocksdb/utilities/cache_dump_load_impl.cc +0 -389
- package/vendor/librocksdb/vendor/rocksdb/utilities/cache_dump_load_impl.h +0 -368
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/cassandra_compaction_filter.cc +0 -104
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/cassandra_compaction_filter.h +0 -57
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/cassandra_options.h +0 -41
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/format.cc +0 -365
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/format.h +0 -183
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/merge_operator.cc +0 -76
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/merge_operator.h +0 -43
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/serialize.h +0 -81
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/test_utils.cc +0 -67
- package/vendor/librocksdb/vendor/rocksdb/utilities/cassandra/test_utils.h +0 -42
- package/vendor/librocksdb/vendor/rocksdb/utilities/checkpoint/checkpoint_impl.cc +0 -472
- package/vendor/librocksdb/vendor/rocksdb/utilities/checkpoint/checkpoint_impl.h +0 -64
- package/vendor/librocksdb/vendor/rocksdb/utilities/compaction_filters/layered_compaction_filter_base.h +0 -41
- package/vendor/librocksdb/vendor/rocksdb/utilities/compaction_filters/remove_emptyvalue_compactionfilter.cc +0 -24
- package/vendor/librocksdb/vendor/rocksdb/utilities/compaction_filters/remove_emptyvalue_compactionfilter.h +0 -26
- package/vendor/librocksdb/vendor/rocksdb/utilities/compaction_filters.cc +0 -52
- package/vendor/librocksdb/vendor/rocksdb/utilities/convenience/info_log_finder.cc +0 -26
- package/vendor/librocksdb/vendor/rocksdb/utilities/counted_fs.cc +0 -379
- package/vendor/librocksdb/vendor/rocksdb/utilities/counted_fs.h +0 -158
- package/vendor/librocksdb/vendor/rocksdb/utilities/debug.cc +0 -134
- package/vendor/librocksdb/vendor/rocksdb/utilities/env_mirror.cc +0 -280
- package/vendor/librocksdb/vendor/rocksdb/utilities/env_timed.cc +0 -181
- package/vendor/librocksdb/vendor/rocksdb/utilities/env_timed.h +0 -95
- package/vendor/librocksdb/vendor/rocksdb/utilities/fault_injection_env.cc +0 -555
- package/vendor/librocksdb/vendor/rocksdb/utilities/fault_injection_env.h +0 -252
- package/vendor/librocksdb/vendor/rocksdb/utilities/fault_injection_fs.cc +0 -1507
- package/vendor/librocksdb/vendor/rocksdb/utilities/fault_injection_fs.h +0 -760
- package/vendor/librocksdb/vendor/rocksdb/utilities/fault_injection_secondary_cache.cc +0 -138
- package/vendor/librocksdb/vendor/rocksdb/utilities/fault_injection_secondary_cache.h +0 -115
- package/vendor/librocksdb/vendor/rocksdb/utilities/leveldb_options/leveldb_options.cc +0 -57
- package/vendor/librocksdb/vendor/rocksdb/utilities/memory/memory_util.cc +0 -50
- package/vendor/librocksdb/vendor/rocksdb/utilities/memory_allocators.h +0 -103
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/bytesxor.cc +0 -57
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/bytesxor.h +0 -39
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/max.cc +0 -64
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/max_operator.h +0 -35
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/put.cc +0 -74
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/put_operator.h +0 -56
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/sortlist.cc +0 -97
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/sortlist.h +0 -42
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/string_append/stringappend.cc +0 -76
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/string_append/stringappend.h +0 -32
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/string_append/stringappend2.cc +0 -129
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/string_append/stringappend2.h +0 -51
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/uint64add.cc +0 -56
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators/uint64add.h +0 -35
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators.cc +0 -115
- package/vendor/librocksdb/vendor/rocksdb/utilities/merge_operators.h +0 -36
- package/vendor/librocksdb/vendor/rocksdb/utilities/object_registry.cc +0 -381
- package/vendor/librocksdb/vendor/rocksdb/utilities/option_change_migration/option_change_migration.cc +0 -169
- package/vendor/librocksdb/vendor/rocksdb/utilities/options/options_util.cc +0 -117
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/block_cache_tier.cc +0 -420
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/block_cache_tier.h +0 -154
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/block_cache_tier_file.cc +0 -607
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/block_cache_tier_file.h +0 -291
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/block_cache_tier_file_buffer.h +0 -127
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/block_cache_tier_metadata.cc +0 -84
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/block_cache_tier_metadata.h +0 -122
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/hash_table.h +0 -237
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/hash_table_bench.cc +0 -310
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/hash_table_evictable.h +0 -166
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/lrulist.h +0 -172
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/persistent_cache_bench.cc +0 -355
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/persistent_cache_test.h +0 -284
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/persistent_cache_tier.cc +0 -165
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/persistent_cache_tier.h +0 -340
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/persistent_cache_util.h +0 -67
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/volatile_tier_impl.cc +0 -138
- package/vendor/librocksdb/vendor/rocksdb/utilities/persistent_cache/volatile_tier_impl.h +0 -139
- package/vendor/librocksdb/vendor/rocksdb/utilities/simulator_cache/cache_simulator.cc +0 -287
- package/vendor/librocksdb/vendor/rocksdb/utilities/simulator_cache/cache_simulator.h +0 -231
- package/vendor/librocksdb/vendor/rocksdb/utilities/simulator_cache/sim_cache.cc +0 -375
- package/vendor/librocksdb/vendor/rocksdb/utilities/table_properties_collectors/compact_for_tiering_collector.cc +0 -144
- package/vendor/librocksdb/vendor/rocksdb/utilities/table_properties_collectors/compact_for_tiering_collector.h +0 -45
- package/vendor/librocksdb/vendor/rocksdb/utilities/table_properties_collectors/compact_on_deletion_collector.cc +0 -233
- package/vendor/librocksdb/vendor/rocksdb/utilities/table_properties_collectors/compact_on_deletion_collector.h +0 -65
- package/vendor/librocksdb/vendor/rocksdb/utilities/trace/file_trace_reader_writer.cc +0 -132
- package/vendor/librocksdb/vendor/rocksdb/utilities/trace/file_trace_reader_writer.h +0 -48
- package/vendor/librocksdb/vendor/rocksdb/utilities/trace/replayer_impl.cc +0 -313
- package/vendor/librocksdb/vendor/rocksdb/utilities/trace/replayer_impl.h +0 -84
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/lock_manager.cc +0 -27
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/lock_manager.h +0 -80
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/lock_tracker.h +0 -207
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/point/point_lock_manager.cc +0 -718
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/point/point_lock_manager.h +0 -222
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/point/point_lock_manager_test.h +0 -324
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/point/point_lock_tracker.cc +0 -255
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/point/point_lock_tracker.h +0 -97
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_lock_manager.h +0 -34
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/db.h +0 -81
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/ft/comparator.h +0 -138
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/ft/ft-status.h +0 -102
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/concurrent_tree.cc +0 -137
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/concurrent_tree.h +0 -174
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/keyrange.cc +0 -220
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/keyrange.h +0 -141
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/lock_request.cc +0 -525
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/lock_request.h +0 -255
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/locktree.cc +0 -1021
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/locktree.h +0 -580
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/manager.cc +0 -525
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/range_buffer.cc +0 -263
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/range_buffer.h +0 -178
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/treenode.cc +0 -518
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/treenode.h +0 -302
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/txnid_set.cc +0 -118
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/txnid_set.h +0 -92
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/wfg.cc +0 -211
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/wfg.h +0 -124
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/memory.h +0 -215
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_assert_subst.h +0 -43
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_atomic.h +0 -130
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_external_pthread.h +0 -87
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_instrumentation.h +0 -286
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_portability.h +0 -87
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_pthread.h +0 -520
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_race_tools.h +0 -179
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_time.h +0 -197
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/txn_subst.h +0 -31
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/standalone_port.cc +0 -139
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/dbt.cc +0 -165
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/dbt.h +0 -98
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/growable_array.h +0 -144
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/memarena.cc +0 -199
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/memarena.h +0 -141
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/omt.h +0 -794
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/omt_impl.h +0 -1295
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/partitioned_counter.h +0 -165
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/status.h +0 -76
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_manager.cc +0 -501
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_manager.h +0 -135
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_tracker.cc +0 -156
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_tracker.h +0 -146
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/optimistic_transaction.cc +0 -208
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/optimistic_transaction.h +0 -99
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/optimistic_transaction_db_impl.cc +0 -111
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/optimistic_transaction_db_impl.h +0 -110
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/pessimistic_transaction.cc +0 -1278
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/pessimistic_transaction.h +0 -345
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/pessimistic_transaction_db.cc +0 -845
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/pessimistic_transaction_db.h +0 -345
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/snapshot_checker.cc +0 -37
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/transaction_base.cc +0 -912
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/transaction_base.h +0 -455
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/transaction_db_mutex_impl.cc +0 -133
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/transaction_db_mutex_impl.h +0 -24
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/transaction_test.h +0 -589
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/transaction_util.cc +0 -207
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/transaction_util.h +0 -86
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/write_prepared_txn.cc +0 -548
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/write_prepared_txn.h +0 -118
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/write_prepared_txn_db.cc +0 -1100
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/write_prepared_txn_db.h +0 -1149
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/write_unprepared_txn.cc +0 -1089
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/write_unprepared_txn.h +0 -333
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/write_unprepared_txn_db.cc +0 -486
- package/vendor/librocksdb/vendor/rocksdb/utilities/transactions/write_unprepared_txn_db.h +0 -105
- package/vendor/librocksdb/vendor/rocksdb/utilities/ttl/db_ttl_impl.cc +0 -638
- package/vendor/librocksdb/vendor/rocksdb/utilities/ttl/db_ttl_impl.h +0 -239
- package/vendor/librocksdb/vendor/rocksdb/utilities/types_util.cc +0 -88
- package/vendor/librocksdb/vendor/rocksdb/utilities/wal_filter.cc +0 -22
- package/vendor/librocksdb/vendor/rocksdb/utilities/write_batch_with_index/write_batch_with_index.cc +0 -1134
- package/vendor/librocksdb/vendor/rocksdb/utilities/write_batch_with_index/write_batch_with_index_internal.cc +0 -934
- package/vendor/librocksdb/vendor/rocksdb/utilities/write_batch_with_index/write_batch_with_index_internal.h +0 -468
|
@@ -1,1217 +0,0 @@
|
|
|
1
|
-
// Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
|
|
2
|
-
// This source code is licensed under both the GPLv2 (found in the
|
|
3
|
-
// COPYING file in the root directory) and Apache 2.0 License
|
|
4
|
-
// (found in the LICENSE.Apache file in the root directory).
|
|
5
|
-
//
|
|
6
|
-
// Copyright (c) 2011 The LevelDB Authors. All rights reserved.
|
|
7
|
-
// Use of this source code is governed by a BSD-style license that can be
|
|
8
|
-
// found in the LICENSE file. See the AUTHORS file for names of contributors.
|
|
9
|
-
|
|
10
|
-
#include "db/flush_job.h"
|
|
11
|
-
|
|
12
|
-
#include <algorithm>
|
|
13
|
-
#include <cinttypes>
|
|
14
|
-
#include <vector>
|
|
15
|
-
|
|
16
|
-
#include "db/builder.h"
|
|
17
|
-
#include "db/db_iter.h"
|
|
18
|
-
#include "db/dbformat.h"
|
|
19
|
-
#include "db/event_helpers.h"
|
|
20
|
-
#include "db/log_reader.h"
|
|
21
|
-
#include "db/log_writer.h"
|
|
22
|
-
#include "db/memtable.h"
|
|
23
|
-
#include "db/memtable_list.h"
|
|
24
|
-
#include "db/merge_context.h"
|
|
25
|
-
#include "db/range_tombstone_fragmenter.h"
|
|
26
|
-
#include "db/version_edit.h"
|
|
27
|
-
#include "db/version_set.h"
|
|
28
|
-
#include "file/file_util.h"
|
|
29
|
-
#include "file/filename.h"
|
|
30
|
-
#include "logging/event_logger.h"
|
|
31
|
-
#include "logging/log_buffer.h"
|
|
32
|
-
#include "logging/logging.h"
|
|
33
|
-
#include "monitoring/iostats_context_imp.h"
|
|
34
|
-
#include "monitoring/perf_context_imp.h"
|
|
35
|
-
#include "monitoring/thread_status_util.h"
|
|
36
|
-
#include "port/port.h"
|
|
37
|
-
#include "rocksdb/db.h"
|
|
38
|
-
#include "rocksdb/env.h"
|
|
39
|
-
#include "rocksdb/statistics.h"
|
|
40
|
-
#include "rocksdb/status.h"
|
|
41
|
-
#include "rocksdb/table.h"
|
|
42
|
-
#include "table/merging_iterator.h"
|
|
43
|
-
#include "table/table_builder.h"
|
|
44
|
-
#include "table/two_level_iterator.h"
|
|
45
|
-
#include "test_util/sync_point.h"
|
|
46
|
-
#include "util/coding.h"
|
|
47
|
-
#include "util/mutexlock.h"
|
|
48
|
-
#include "util/stop_watch.h"
|
|
49
|
-
|
|
50
|
-
namespace ROCKSDB_NAMESPACE {
|
|
51
|
-
|
|
52
|
-
const char* GetFlushReasonString(FlushReason flush_reason) {
|
|
53
|
-
switch (flush_reason) {
|
|
54
|
-
case FlushReason::kOthers:
|
|
55
|
-
return "Other Reasons";
|
|
56
|
-
case FlushReason::kGetLiveFiles:
|
|
57
|
-
return "Get Live Files";
|
|
58
|
-
case FlushReason::kShutDown:
|
|
59
|
-
return "Shut down";
|
|
60
|
-
case FlushReason::kExternalFileIngestion:
|
|
61
|
-
return "External File Ingestion";
|
|
62
|
-
case FlushReason::kManualCompaction:
|
|
63
|
-
return "Manual Compaction";
|
|
64
|
-
case FlushReason::kWriteBufferManager:
|
|
65
|
-
return "Write Buffer Manager";
|
|
66
|
-
case FlushReason::kWriteBufferFull:
|
|
67
|
-
return "Write Buffer Full";
|
|
68
|
-
case FlushReason::kTest:
|
|
69
|
-
return "Test";
|
|
70
|
-
case FlushReason::kDeleteFiles:
|
|
71
|
-
return "Delete Files";
|
|
72
|
-
case FlushReason::kAutoCompaction:
|
|
73
|
-
return "Auto Compaction";
|
|
74
|
-
case FlushReason::kManualFlush:
|
|
75
|
-
return "Manual Flush";
|
|
76
|
-
case FlushReason::kErrorRecovery:
|
|
77
|
-
return "Error Recovery";
|
|
78
|
-
case FlushReason::kErrorRecoveryRetryFlush:
|
|
79
|
-
return "Error Recovery Retry Flush";
|
|
80
|
-
case FlushReason::kWalFull:
|
|
81
|
-
return "WAL Full";
|
|
82
|
-
case FlushReason::kCatchUpAfterErrorRecovery:
|
|
83
|
-
return "Catch Up After Error Recovery";
|
|
84
|
-
default:
|
|
85
|
-
return "Invalid";
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
FlushJob::FlushJob(
|
|
90
|
-
const std::string& dbname, ColumnFamilyData* cfd,
|
|
91
|
-
const ImmutableDBOptions& db_options,
|
|
92
|
-
const MutableCFOptions& mutable_cf_options, uint64_t max_memtable_id,
|
|
93
|
-
const FileOptions& file_options, VersionSet* versions,
|
|
94
|
-
InstrumentedMutex* db_mutex, std::atomic<bool>* shutting_down,
|
|
95
|
-
std::vector<SequenceNumber> existing_snapshots,
|
|
96
|
-
SequenceNumber earliest_write_conflict_snapshot,
|
|
97
|
-
SnapshotChecker* snapshot_checker, JobContext* job_context,
|
|
98
|
-
FlushReason flush_reason, LogBuffer* log_buffer, FSDirectory* db_directory,
|
|
99
|
-
FSDirectory* output_file_directory, CompressionType output_compression,
|
|
100
|
-
Statistics* stats, EventLogger* event_logger, bool measure_io_stats,
|
|
101
|
-
const bool sync_output_directory, const bool write_manifest,
|
|
102
|
-
Env::Priority thread_pri, const std::shared_ptr<IOTracer>& io_tracer,
|
|
103
|
-
std::shared_ptr<const SeqnoToTimeMapping> seqno_to_time_mapping,
|
|
104
|
-
const std::string& db_id, const std::string& db_session_id,
|
|
105
|
-
std::string full_history_ts_low, BlobFileCompletionCallback* blob_callback)
|
|
106
|
-
: dbname_(dbname),
|
|
107
|
-
db_id_(db_id),
|
|
108
|
-
db_session_id_(db_session_id),
|
|
109
|
-
cfd_(cfd),
|
|
110
|
-
db_options_(db_options),
|
|
111
|
-
mutable_cf_options_(mutable_cf_options),
|
|
112
|
-
max_memtable_id_(max_memtable_id),
|
|
113
|
-
file_options_(file_options),
|
|
114
|
-
versions_(versions),
|
|
115
|
-
db_mutex_(db_mutex),
|
|
116
|
-
shutting_down_(shutting_down),
|
|
117
|
-
existing_snapshots_(std::move(existing_snapshots)),
|
|
118
|
-
earliest_snapshot_(existing_snapshots_.empty()
|
|
119
|
-
? kMaxSequenceNumber
|
|
120
|
-
: existing_snapshots_.at(0)),
|
|
121
|
-
earliest_write_conflict_snapshot_(earliest_write_conflict_snapshot),
|
|
122
|
-
snapshot_checker_(snapshot_checker),
|
|
123
|
-
job_context_(job_context),
|
|
124
|
-
flush_reason_(flush_reason),
|
|
125
|
-
log_buffer_(log_buffer),
|
|
126
|
-
db_directory_(db_directory),
|
|
127
|
-
output_file_directory_(output_file_directory),
|
|
128
|
-
output_compression_(output_compression),
|
|
129
|
-
stats_(stats),
|
|
130
|
-
event_logger_(event_logger),
|
|
131
|
-
measure_io_stats_(measure_io_stats),
|
|
132
|
-
sync_output_directory_(sync_output_directory),
|
|
133
|
-
write_manifest_(write_manifest),
|
|
134
|
-
edit_(nullptr),
|
|
135
|
-
base_(nullptr),
|
|
136
|
-
pick_memtable_called(false),
|
|
137
|
-
thread_pri_(thread_pri),
|
|
138
|
-
io_tracer_(io_tracer),
|
|
139
|
-
clock_(db_options_.clock),
|
|
140
|
-
full_history_ts_low_(std::move(full_history_ts_low)),
|
|
141
|
-
blob_callback_(blob_callback),
|
|
142
|
-
seqno_to_time_mapping_(std::move(seqno_to_time_mapping)) {
|
|
143
|
-
// Update the thread status to indicate flush.
|
|
144
|
-
ReportStartedFlush();
|
|
145
|
-
TEST_SYNC_POINT("FlushJob::FlushJob()");
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
FlushJob::~FlushJob() { ThreadStatusUtil::ResetThreadStatus(); }
|
|
149
|
-
|
|
150
|
-
void FlushJob::ReportStartedFlush() {
|
|
151
|
-
ThreadStatusUtil::SetEnableTracking(db_options_.enable_thread_tracking);
|
|
152
|
-
ThreadStatusUtil::SetColumnFamily(cfd_);
|
|
153
|
-
ThreadStatusUtil::SetThreadOperation(ThreadStatus::OP_FLUSH);
|
|
154
|
-
ThreadStatusUtil::SetThreadOperationProperty(ThreadStatus::COMPACTION_JOB_ID,
|
|
155
|
-
job_context_->job_id);
|
|
156
|
-
|
|
157
|
-
IOSTATS_RESET(bytes_written);
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
void FlushJob::ReportFlushInputSize(const autovector<MemTable*>& mems) {
|
|
161
|
-
uint64_t input_size = 0;
|
|
162
|
-
for (auto* mem : mems) {
|
|
163
|
-
input_size += mem->ApproximateMemoryUsage();
|
|
164
|
-
}
|
|
165
|
-
ThreadStatusUtil::IncreaseThreadOperationProperty(
|
|
166
|
-
ThreadStatus::FLUSH_BYTES_MEMTABLES, input_size);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
void FlushJob::RecordFlushIOStats() {
|
|
170
|
-
RecordTick(stats_, FLUSH_WRITE_BYTES, IOSTATS(bytes_written));
|
|
171
|
-
ThreadStatusUtil::IncreaseThreadOperationProperty(
|
|
172
|
-
ThreadStatus::FLUSH_BYTES_WRITTEN, IOSTATS(bytes_written));
|
|
173
|
-
IOSTATS_RESET(bytes_written);
|
|
174
|
-
}
|
|
175
|
-
void FlushJob::PickMemTable() {
|
|
176
|
-
db_mutex_->AssertHeld();
|
|
177
|
-
assert(!pick_memtable_called);
|
|
178
|
-
pick_memtable_called = true;
|
|
179
|
-
|
|
180
|
-
// Maximum "NextLogNumber" of the memtables to flush.
|
|
181
|
-
// When mempurge feature is turned off, this variable is useless
|
|
182
|
-
// because the memtables are implicitly sorted by increasing order of creation
|
|
183
|
-
// time. Therefore mems_->back()->GetNextLogNumber() is already equal to
|
|
184
|
-
// max_next_log_number. However when Mempurge is on, the memtables are no
|
|
185
|
-
// longer sorted by increasing order of creation time. Therefore this variable
|
|
186
|
-
// becomes necessary because mems_->back()->GetNextLogNumber() is no longer
|
|
187
|
-
// necessarily equal to max_next_log_number.
|
|
188
|
-
uint64_t max_next_log_number = 0;
|
|
189
|
-
|
|
190
|
-
// Save the contents of the earliest memtable as a new Table
|
|
191
|
-
cfd_->imm()->PickMemtablesToFlush(max_memtable_id_, &mems_,
|
|
192
|
-
&max_next_log_number);
|
|
193
|
-
if (mems_.empty()) {
|
|
194
|
-
return;
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
// Track effective cutoff user-defined timestamp during flush if
|
|
198
|
-
// user-defined timestamps can be stripped.
|
|
199
|
-
GetEffectiveCutoffUDTForPickedMemTables();
|
|
200
|
-
GetPrecludeLastLevelMinSeqno();
|
|
201
|
-
|
|
202
|
-
ReportFlushInputSize(mems_);
|
|
203
|
-
|
|
204
|
-
// entries mems are (implicitly) sorted in ascending order by their created
|
|
205
|
-
// time. We will use the first memtable's `edit` to keep the meta info for
|
|
206
|
-
// this flush.
|
|
207
|
-
MemTable* m = mems_[0];
|
|
208
|
-
edit_ = m->GetEdits();
|
|
209
|
-
edit_->SetPrevLogNumber(0);
|
|
210
|
-
// SetLogNumber(log_num) indicates logs with number smaller than log_num
|
|
211
|
-
// will no longer be picked up for recovery.
|
|
212
|
-
edit_->SetLogNumber(max_next_log_number);
|
|
213
|
-
edit_->SetColumnFamily(cfd_->GetID());
|
|
214
|
-
|
|
215
|
-
// path 0 for level 0 file.
|
|
216
|
-
meta_.fd = FileDescriptor(versions_->NewFileNumber(), 0, 0);
|
|
217
|
-
meta_.epoch_number = cfd_->NewEpochNumber();
|
|
218
|
-
|
|
219
|
-
base_ = cfd_->current();
|
|
220
|
-
base_->Ref(); // it is likely that we do not need this reference
|
|
221
|
-
}
|
|
222
|
-
|
|
223
|
-
Status FlushJob::Run(LogsWithPrepTracker* prep_tracker, FileMetaData* file_meta,
|
|
224
|
-
bool* switched_to_mempurge, bool* skipped_since_bg_error,
|
|
225
|
-
ErrorHandler* error_handler) {
|
|
226
|
-
TEST_SYNC_POINT("FlushJob::Start");
|
|
227
|
-
db_mutex_->AssertHeld();
|
|
228
|
-
assert(pick_memtable_called);
|
|
229
|
-
// Mempurge threshold can be dynamically changed.
|
|
230
|
-
// For sake of consistency, mempurge_threshold is
|
|
231
|
-
// saved locally to maintain consistency in each
|
|
232
|
-
// FlushJob::Run call.
|
|
233
|
-
double mempurge_threshold =
|
|
234
|
-
mutable_cf_options_.experimental_mempurge_threshold;
|
|
235
|
-
|
|
236
|
-
AutoThreadOperationStageUpdater stage_run(ThreadStatus::STAGE_FLUSH_RUN);
|
|
237
|
-
if (mems_.empty()) {
|
|
238
|
-
ROCKS_LOG_BUFFER(log_buffer_, "[%s] No memtable to flush",
|
|
239
|
-
cfd_->GetName().c_str());
|
|
240
|
-
return Status::OK();
|
|
241
|
-
}
|
|
242
|
-
|
|
243
|
-
// I/O measurement variables
|
|
244
|
-
PerfLevel prev_perf_level = PerfLevel::kEnableTime;
|
|
245
|
-
uint64_t prev_write_nanos = 0;
|
|
246
|
-
uint64_t prev_fsync_nanos = 0;
|
|
247
|
-
uint64_t prev_range_sync_nanos = 0;
|
|
248
|
-
uint64_t prev_prepare_write_nanos = 0;
|
|
249
|
-
uint64_t prev_cpu_write_nanos = 0;
|
|
250
|
-
uint64_t prev_cpu_read_nanos = 0;
|
|
251
|
-
if (measure_io_stats_) {
|
|
252
|
-
prev_perf_level = GetPerfLevel();
|
|
253
|
-
SetPerfLevel(PerfLevel::kEnableTime);
|
|
254
|
-
prev_write_nanos = IOSTATS(write_nanos);
|
|
255
|
-
prev_fsync_nanos = IOSTATS(fsync_nanos);
|
|
256
|
-
prev_range_sync_nanos = IOSTATS(range_sync_nanos);
|
|
257
|
-
prev_prepare_write_nanos = IOSTATS(prepare_write_nanos);
|
|
258
|
-
prev_cpu_write_nanos = IOSTATS(cpu_write_nanos);
|
|
259
|
-
prev_cpu_read_nanos = IOSTATS(cpu_read_nanos);
|
|
260
|
-
}
|
|
261
|
-
Status mempurge_s = Status::NotFound("No MemPurge.");
|
|
262
|
-
if ((mempurge_threshold > 0.0) &&
|
|
263
|
-
(flush_reason_ == FlushReason::kWriteBufferFull) && (!mems_.empty()) &&
|
|
264
|
-
MemPurgeDecider(mempurge_threshold) && !(db_options_.atomic_flush)) {
|
|
265
|
-
cfd_->SetMempurgeUsed();
|
|
266
|
-
mempurge_s = MemPurge();
|
|
267
|
-
if (!mempurge_s.ok()) {
|
|
268
|
-
// Mempurge is typically aborted when the output
|
|
269
|
-
// bytes cannot be contained onto a single output memtable.
|
|
270
|
-
if (mempurge_s.IsAborted()) {
|
|
271
|
-
ROCKS_LOG_INFO(db_options_.info_log, "Mempurge process aborted: %s\n",
|
|
272
|
-
mempurge_s.ToString().c_str());
|
|
273
|
-
} else {
|
|
274
|
-
// However the mempurge process can also fail for
|
|
275
|
-
// other reasons (eg: new_mem->Add() fails).
|
|
276
|
-
ROCKS_LOG_WARN(db_options_.info_log, "Mempurge process failed: %s\n",
|
|
277
|
-
mempurge_s.ToString().c_str());
|
|
278
|
-
}
|
|
279
|
-
} else {
|
|
280
|
-
if (switched_to_mempurge) {
|
|
281
|
-
*switched_to_mempurge = true;
|
|
282
|
-
} else {
|
|
283
|
-
// The mempurge process was successful, but no switch_to_mempurge
|
|
284
|
-
// pointer provided so no way to propagate the state of flush job.
|
|
285
|
-
ROCKS_LOG_WARN(db_options_.info_log,
|
|
286
|
-
"Mempurge process succeeded"
|
|
287
|
-
"but no 'switched_to_mempurge' ptr provided.\n");
|
|
288
|
-
}
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
Status s;
|
|
292
|
-
if (mempurge_s.ok()) {
|
|
293
|
-
base_->Unref();
|
|
294
|
-
s = Status::OK();
|
|
295
|
-
} else {
|
|
296
|
-
// This will release and re-acquire the mutex.
|
|
297
|
-
s = WriteLevel0Table();
|
|
298
|
-
}
|
|
299
|
-
|
|
300
|
-
if (s.ok() && cfd_->IsDropped()) {
|
|
301
|
-
s = Status::ColumnFamilyDropped("Column family dropped during compaction");
|
|
302
|
-
}
|
|
303
|
-
if ((s.ok() || s.IsColumnFamilyDropped()) &&
|
|
304
|
-
shutting_down_->load(std::memory_order_acquire)) {
|
|
305
|
-
s = Status::ShutdownInProgress("Database shutdown");
|
|
306
|
-
}
|
|
307
|
-
|
|
308
|
-
if (s.ok()) {
|
|
309
|
-
s = MaybeIncreaseFullHistoryTsLowToAboveCutoffUDT();
|
|
310
|
-
}
|
|
311
|
-
|
|
312
|
-
if (!s.ok()) {
|
|
313
|
-
cfd_->imm()->RollbackMemtableFlush(
|
|
314
|
-
mems_, /*rollback_succeeding_memtables=*/!db_options_.atomic_flush);
|
|
315
|
-
} else if (write_manifest_) {
|
|
316
|
-
assert(!db_options_.atomic_flush);
|
|
317
|
-
if (!db_options_.atomic_flush &&
|
|
318
|
-
flush_reason_ != FlushReason::kErrorRecovery &&
|
|
319
|
-
flush_reason_ != FlushReason::kErrorRecoveryRetryFlush &&
|
|
320
|
-
error_handler && !error_handler->GetBGError().ok() &&
|
|
321
|
-
error_handler->IsBGWorkStopped()) {
|
|
322
|
-
cfd_->imm()->RollbackMemtableFlush(
|
|
323
|
-
mems_, /*rollback_succeeding_memtables=*/!db_options_.atomic_flush);
|
|
324
|
-
s = error_handler->GetBGError();
|
|
325
|
-
if (skipped_since_bg_error) {
|
|
326
|
-
*skipped_since_bg_error = true;
|
|
327
|
-
}
|
|
328
|
-
} else {
|
|
329
|
-
TEST_SYNC_POINT("FlushJob::InstallResults");
|
|
330
|
-
// Replace immutable memtable with the generated Table
|
|
331
|
-
s = cfd_->imm()->TryInstallMemtableFlushResults(
|
|
332
|
-
cfd_, mutable_cf_options_, mems_, prep_tracker, versions_, db_mutex_,
|
|
333
|
-
meta_.fd.GetNumber(), &job_context_->memtables_to_free, db_directory_,
|
|
334
|
-
log_buffer_, &committed_flush_jobs_info_,
|
|
335
|
-
!(mempurge_s.ok()) /* write_edit : true if no mempurge happened (or if aborted),
|
|
336
|
-
but 'false' if mempurge successful: no new min log number
|
|
337
|
-
or new level 0 file path to write to manifest. */);
|
|
338
|
-
}
|
|
339
|
-
}
|
|
340
|
-
|
|
341
|
-
if (s.ok() && file_meta != nullptr) {
|
|
342
|
-
*file_meta = meta_;
|
|
343
|
-
}
|
|
344
|
-
RecordFlushIOStats();
|
|
345
|
-
|
|
346
|
-
// When measure_io_stats_ is true, the default 512 bytes is not enough.
|
|
347
|
-
auto stream = event_logger_->LogToBuffer(log_buffer_, 1024);
|
|
348
|
-
stream << "job" << job_context_->job_id << "event"
|
|
349
|
-
<< "flush_finished";
|
|
350
|
-
stream << "output_compression"
|
|
351
|
-
<< CompressionTypeToString(output_compression_);
|
|
352
|
-
stream << "lsm_state";
|
|
353
|
-
stream.StartArray();
|
|
354
|
-
auto vstorage = cfd_->current()->storage_info();
|
|
355
|
-
for (int level = 0; level < vstorage->num_levels(); ++level) {
|
|
356
|
-
stream << vstorage->NumLevelFiles(level);
|
|
357
|
-
}
|
|
358
|
-
stream.EndArray();
|
|
359
|
-
|
|
360
|
-
const auto& blob_files = vstorage->GetBlobFiles();
|
|
361
|
-
if (!blob_files.empty()) {
|
|
362
|
-
assert(blob_files.front());
|
|
363
|
-
stream << "blob_file_head" << blob_files.front()->GetBlobFileNumber();
|
|
364
|
-
|
|
365
|
-
assert(blob_files.back());
|
|
366
|
-
stream << "blob_file_tail" << blob_files.back()->GetBlobFileNumber();
|
|
367
|
-
}
|
|
368
|
-
|
|
369
|
-
stream << "immutable_memtables" << cfd_->imm()->NumNotFlushed();
|
|
370
|
-
|
|
371
|
-
if (measure_io_stats_) {
|
|
372
|
-
if (prev_perf_level != PerfLevel::kEnableTime) {
|
|
373
|
-
SetPerfLevel(prev_perf_level);
|
|
374
|
-
}
|
|
375
|
-
stream << "file_write_nanos" << (IOSTATS(write_nanos) - prev_write_nanos);
|
|
376
|
-
stream << "file_range_sync_nanos"
|
|
377
|
-
<< (IOSTATS(range_sync_nanos) - prev_range_sync_nanos);
|
|
378
|
-
stream << "file_fsync_nanos" << (IOSTATS(fsync_nanos) - prev_fsync_nanos);
|
|
379
|
-
stream << "file_prepare_write_nanos"
|
|
380
|
-
<< (IOSTATS(prepare_write_nanos) - prev_prepare_write_nanos);
|
|
381
|
-
stream << "file_cpu_write_nanos"
|
|
382
|
-
<< (IOSTATS(cpu_write_nanos) - prev_cpu_write_nanos);
|
|
383
|
-
stream << "file_cpu_read_nanos"
|
|
384
|
-
<< (IOSTATS(cpu_read_nanos) - prev_cpu_read_nanos);
|
|
385
|
-
}
|
|
386
|
-
|
|
387
|
-
TEST_SYNC_POINT("FlushJob::End");
|
|
388
|
-
return s;
|
|
389
|
-
}
|
|
390
|
-
|
|
391
|
-
void FlushJob::Cancel() {
|
|
392
|
-
db_mutex_->AssertHeld();
|
|
393
|
-
assert(base_ != nullptr);
|
|
394
|
-
base_->Unref();
|
|
395
|
-
}
|
|
396
|
-
|
|
397
|
-
Status FlushJob::MemPurge() {
|
|
398
|
-
Status s;
|
|
399
|
-
db_mutex_->AssertHeld();
|
|
400
|
-
db_mutex_->Unlock();
|
|
401
|
-
assert(!mems_.empty());
|
|
402
|
-
|
|
403
|
-
// Measure purging time.
|
|
404
|
-
const uint64_t start_micros = clock_->NowMicros();
|
|
405
|
-
const uint64_t start_cpu_micros = clock_->CPUMicros();
|
|
406
|
-
|
|
407
|
-
MemTable* new_mem = nullptr;
|
|
408
|
-
// For performance/log investigation purposes:
|
|
409
|
-
// look at how much useful payload we harvest in the new_mem.
|
|
410
|
-
// This value is then printed to the DB log.
|
|
411
|
-
double new_mem_capacity = 0.0;
|
|
412
|
-
|
|
413
|
-
// Create two iterators, one for the memtable data (contains
|
|
414
|
-
// info from puts + deletes), and one for the memtable
|
|
415
|
-
// Range Tombstones (from DeleteRanges).
|
|
416
|
-
// TODO: plumb Env::IOActivity, Env::IOPriority
|
|
417
|
-
ReadOptions ro;
|
|
418
|
-
ro.total_order_seek = true;
|
|
419
|
-
Arena arena;
|
|
420
|
-
std::vector<InternalIterator*> memtables;
|
|
421
|
-
std::vector<std::unique_ptr<FragmentedRangeTombstoneIterator>>
|
|
422
|
-
range_del_iters;
|
|
423
|
-
for (MemTable* m : mems_) {
|
|
424
|
-
memtables.push_back(
|
|
425
|
-
m->NewIterator(ro, /*seqno_to_time_mapping=*/nullptr, &arena));
|
|
426
|
-
auto* range_del_iter = m->NewRangeTombstoneIterator(
|
|
427
|
-
ro, kMaxSequenceNumber, true /* immutable_memtable */);
|
|
428
|
-
if (range_del_iter != nullptr) {
|
|
429
|
-
range_del_iters.emplace_back(range_del_iter);
|
|
430
|
-
}
|
|
431
|
-
}
|
|
432
|
-
|
|
433
|
-
assert(!memtables.empty());
|
|
434
|
-
SequenceNumber first_seqno = kMaxSequenceNumber;
|
|
435
|
-
SequenceNumber earliest_seqno = kMaxSequenceNumber;
|
|
436
|
-
// Pick first and earliest seqno as min of all first_seqno
|
|
437
|
-
// and earliest_seqno of the mempurged memtables.
|
|
438
|
-
for (const auto& mem : mems_) {
|
|
439
|
-
first_seqno = mem->GetFirstSequenceNumber() < first_seqno
|
|
440
|
-
? mem->GetFirstSequenceNumber()
|
|
441
|
-
: first_seqno;
|
|
442
|
-
earliest_seqno = mem->GetEarliestSequenceNumber() < earliest_seqno
|
|
443
|
-
? mem->GetEarliestSequenceNumber()
|
|
444
|
-
: earliest_seqno;
|
|
445
|
-
}
|
|
446
|
-
|
|
447
|
-
ScopedArenaPtr<InternalIterator> iter(
|
|
448
|
-
NewMergingIterator(&(cfd_->internal_comparator()), memtables.data(),
|
|
449
|
-
static_cast<int>(memtables.size()), &arena));
|
|
450
|
-
|
|
451
|
-
auto* ioptions = cfd_->ioptions();
|
|
452
|
-
|
|
453
|
-
// Place iterator at the First (meaning most recent) key node.
|
|
454
|
-
iter->SeekToFirst();
|
|
455
|
-
|
|
456
|
-
const std::string* const full_history_ts_low = &(cfd_->GetFullHistoryTsLow());
|
|
457
|
-
std::unique_ptr<CompactionRangeDelAggregator> range_del_agg(
|
|
458
|
-
new CompactionRangeDelAggregator(&(cfd_->internal_comparator()),
|
|
459
|
-
existing_snapshots_,
|
|
460
|
-
full_history_ts_low));
|
|
461
|
-
for (auto& rd_iter : range_del_iters) {
|
|
462
|
-
range_del_agg->AddTombstones(std::move(rd_iter));
|
|
463
|
-
}
|
|
464
|
-
|
|
465
|
-
// If there is valid data in the memtable,
|
|
466
|
-
// or at least range tombstones, copy over the info
|
|
467
|
-
// to the new memtable.
|
|
468
|
-
if (iter->Valid() || !range_del_agg->IsEmpty()) {
|
|
469
|
-
// MaxSize is the size of a memtable.
|
|
470
|
-
size_t maxSize = mutable_cf_options_.write_buffer_size;
|
|
471
|
-
std::unique_ptr<CompactionFilter> compaction_filter;
|
|
472
|
-
if (ioptions->compaction_filter_factory != nullptr &&
|
|
473
|
-
ioptions->compaction_filter_factory->ShouldFilterTableFileCreation(
|
|
474
|
-
TableFileCreationReason::kFlush)) {
|
|
475
|
-
CompactionFilter::Context ctx;
|
|
476
|
-
ctx.is_full_compaction = false;
|
|
477
|
-
ctx.is_manual_compaction = false;
|
|
478
|
-
ctx.column_family_id = cfd_->GetID();
|
|
479
|
-
ctx.reason = TableFileCreationReason::kFlush;
|
|
480
|
-
compaction_filter =
|
|
481
|
-
ioptions->compaction_filter_factory->CreateCompactionFilter(ctx);
|
|
482
|
-
if (compaction_filter != nullptr &&
|
|
483
|
-
!compaction_filter->IgnoreSnapshots()) {
|
|
484
|
-
s = Status::NotSupported(
|
|
485
|
-
"CompactionFilter::IgnoreSnapshots() = false is not supported "
|
|
486
|
-
"anymore.");
|
|
487
|
-
return s;
|
|
488
|
-
}
|
|
489
|
-
}
|
|
490
|
-
|
|
491
|
-
new_mem = new MemTable((cfd_->internal_comparator()), *(cfd_->ioptions()),
|
|
492
|
-
mutable_cf_options_, cfd_->write_buffer_mgr(),
|
|
493
|
-
earliest_seqno, cfd_->GetID());
|
|
494
|
-
assert(new_mem != nullptr);
|
|
495
|
-
|
|
496
|
-
Env* env = db_options_.env;
|
|
497
|
-
assert(env);
|
|
498
|
-
MergeHelper merge(
|
|
499
|
-
env, (cfd_->internal_comparator()).user_comparator(),
|
|
500
|
-
(ioptions->merge_operator).get(), compaction_filter.get(),
|
|
501
|
-
ioptions->logger, true /* internal key corruption is not ok */,
|
|
502
|
-
existing_snapshots_.empty() ? 0 : existing_snapshots_.back(),
|
|
503
|
-
snapshot_checker_);
|
|
504
|
-
assert(job_context_);
|
|
505
|
-
SequenceNumber job_snapshot_seq = job_context_->GetJobSnapshotSequence();
|
|
506
|
-
const std::atomic<bool> kManualCompactionCanceledFalse{false};
|
|
507
|
-
CompactionIterator c_iter(
|
|
508
|
-
iter.get(), (cfd_->internal_comparator()).user_comparator(), &merge,
|
|
509
|
-
kMaxSequenceNumber, &existing_snapshots_, earliest_snapshot_,
|
|
510
|
-
earliest_write_conflict_snapshot_, job_snapshot_seq, snapshot_checker_,
|
|
511
|
-
env, ShouldReportDetailedTime(env, ioptions->stats),
|
|
512
|
-
true /* internal key corruption is not ok */, range_del_agg.get(),
|
|
513
|
-
nullptr, ioptions->allow_data_in_errors,
|
|
514
|
-
ioptions->enforce_single_del_contracts,
|
|
515
|
-
/*manual_compaction_canceled=*/kManualCompactionCanceledFalse,
|
|
516
|
-
false /* must_count_input_entries */,
|
|
517
|
-
/*compaction=*/nullptr, compaction_filter.get(),
|
|
518
|
-
/*shutting_down=*/nullptr, ioptions->info_log, full_history_ts_low);
|
|
519
|
-
|
|
520
|
-
// Set earliest sequence number in the new memtable
|
|
521
|
-
// to be equal to the earliest sequence number of the
|
|
522
|
-
// memtable being flushed (See later if there is a need
|
|
523
|
-
// to update this number!).
|
|
524
|
-
new_mem->SetEarliestSequenceNumber(earliest_seqno);
|
|
525
|
-
// Likewise for first seq number.
|
|
526
|
-
new_mem->SetFirstSequenceNumber(first_seqno);
|
|
527
|
-
SequenceNumber new_first_seqno = kMaxSequenceNumber;
|
|
528
|
-
|
|
529
|
-
c_iter.SeekToFirst();
|
|
530
|
-
|
|
531
|
-
// Key transfer
|
|
532
|
-
for (; c_iter.Valid(); c_iter.Next()) {
|
|
533
|
-
const ParsedInternalKey ikey = c_iter.ikey();
|
|
534
|
-
const Slice value = c_iter.value();
|
|
535
|
-
new_first_seqno =
|
|
536
|
-
ikey.sequence < new_first_seqno ? ikey.sequence : new_first_seqno;
|
|
537
|
-
|
|
538
|
-
// Should we update "OldestKeyTime" ???? -> timestamp appear
|
|
539
|
-
// to still be an "experimental" feature.
|
|
540
|
-
s = new_mem->Add(
|
|
541
|
-
ikey.sequence, ikey.type, ikey.user_key, value,
|
|
542
|
-
nullptr, // KV protection info set as nullptr since it
|
|
543
|
-
// should only be useful for the first add to
|
|
544
|
-
// the original memtable.
|
|
545
|
-
false, // : allow concurrent_memtable_writes_
|
|
546
|
-
// Not seen as necessary for now.
|
|
547
|
-
nullptr, // get_post_process_info(m) must be nullptr
|
|
548
|
-
// when concurrent_memtable_writes is switched off.
|
|
549
|
-
nullptr); // hint, only used when concurrent_memtable_writes_
|
|
550
|
-
// is switched on.
|
|
551
|
-
if (!s.ok()) {
|
|
552
|
-
break;
|
|
553
|
-
}
|
|
554
|
-
|
|
555
|
-
// If new_mem has size greater than maxSize,
|
|
556
|
-
// then rollback to regular flush operation,
|
|
557
|
-
// and destroy new_mem.
|
|
558
|
-
if (new_mem->ApproximateMemoryUsage() > maxSize) {
|
|
559
|
-
s = Status::Aborted("Mempurge filled more than one memtable.");
|
|
560
|
-
new_mem_capacity = 1.0;
|
|
561
|
-
break;
|
|
562
|
-
}
|
|
563
|
-
}
|
|
564
|
-
|
|
565
|
-
// Check status and propagate
|
|
566
|
-
// potential error status from c_iter
|
|
567
|
-
if (!s.ok()) {
|
|
568
|
-
c_iter.status().PermitUncheckedError();
|
|
569
|
-
} else if (!c_iter.status().ok()) {
|
|
570
|
-
s = c_iter.status();
|
|
571
|
-
}
|
|
572
|
-
|
|
573
|
-
// Range tombstone transfer.
|
|
574
|
-
if (s.ok()) {
|
|
575
|
-
auto range_del_it = range_del_agg->NewIterator();
|
|
576
|
-
for (range_del_it->SeekToFirst(); range_del_it->Valid();
|
|
577
|
-
range_del_it->Next()) {
|
|
578
|
-
auto tombstone = range_del_it->Tombstone();
|
|
579
|
-
new_first_seqno =
|
|
580
|
-
tombstone.seq_ < new_first_seqno ? tombstone.seq_ : new_first_seqno;
|
|
581
|
-
s = new_mem->Add(
|
|
582
|
-
tombstone.seq_, // Sequence number
|
|
583
|
-
kTypeRangeDeletion, // KV type
|
|
584
|
-
tombstone.start_key_, // Key is start key.
|
|
585
|
-
tombstone.end_key_, // Value is end key.
|
|
586
|
-
nullptr, // KV protection info set as nullptr since it
|
|
587
|
-
// should only be useful for the first add to
|
|
588
|
-
// the original memtable.
|
|
589
|
-
false, // : allow concurrent_memtable_writes_
|
|
590
|
-
// Not seen as necessary for now.
|
|
591
|
-
nullptr, // get_post_process_info(m) must be nullptr
|
|
592
|
-
// when concurrent_memtable_writes is switched off.
|
|
593
|
-
nullptr); // hint, only used when concurrent_memtable_writes_
|
|
594
|
-
// is switched on.
|
|
595
|
-
|
|
596
|
-
if (!s.ok()) {
|
|
597
|
-
break;
|
|
598
|
-
}
|
|
599
|
-
|
|
600
|
-
// If new_mem has size greater than maxSize,
|
|
601
|
-
// then rollback to regular flush operation,
|
|
602
|
-
// and destroy new_mem.
|
|
603
|
-
if (new_mem->ApproximateMemoryUsage() > maxSize) {
|
|
604
|
-
s = Status::Aborted(Slice("Mempurge filled more than one memtable."));
|
|
605
|
-
new_mem_capacity = 1.0;
|
|
606
|
-
break;
|
|
607
|
-
}
|
|
608
|
-
}
|
|
609
|
-
}
|
|
610
|
-
|
|
611
|
-
// If everything happened smoothly and new_mem contains valid data,
|
|
612
|
-
// decide if it is flushed to storage or kept in the imm()
|
|
613
|
-
// memtable list (memory).
|
|
614
|
-
if (s.ok() && (new_first_seqno != kMaxSequenceNumber)) {
|
|
615
|
-
// Rectify the first sequence number, which (unlike the earliest seq
|
|
616
|
-
// number) needs to be present in the new memtable.
|
|
617
|
-
new_mem->SetFirstSequenceNumber(new_first_seqno);
|
|
618
|
-
|
|
619
|
-
// The new_mem is added to the list of immutable memtables
|
|
620
|
-
// only if it filled at less than 100% capacity and isn't flagged
|
|
621
|
-
// as in need of being flushed.
|
|
622
|
-
if (new_mem->ApproximateMemoryUsage() < maxSize &&
|
|
623
|
-
!(new_mem->ShouldFlushNow())) {
|
|
624
|
-
// Construct fragmented memtable range tombstones without mutex
|
|
625
|
-
new_mem->ConstructFragmentedRangeTombstones();
|
|
626
|
-
db_mutex_->Lock();
|
|
627
|
-
uint64_t new_mem_id = mems_[0]->GetID();
|
|
628
|
-
|
|
629
|
-
new_mem->SetID(new_mem_id);
|
|
630
|
-
new_mem->SetNextLogNumber(mems_[0]->GetNextLogNumber());
|
|
631
|
-
|
|
632
|
-
// This addition will not trigger another flush, because
|
|
633
|
-
// we do not call SchedulePendingFlush().
|
|
634
|
-
cfd_->imm()->Add(new_mem, &job_context_->memtables_to_free);
|
|
635
|
-
new_mem->Ref();
|
|
636
|
-
// Piggyback FlushJobInfo on the first flushed memtable.
|
|
637
|
-
db_mutex_->AssertHeld();
|
|
638
|
-
meta_.fd.file_size = 0;
|
|
639
|
-
mems_[0]->SetFlushJobInfo(GetFlushJobInfo());
|
|
640
|
-
db_mutex_->Unlock();
|
|
641
|
-
} else {
|
|
642
|
-
s = Status::Aborted(Slice("Mempurge filled more than one memtable."));
|
|
643
|
-
new_mem_capacity = 1.0;
|
|
644
|
-
if (new_mem) {
|
|
645
|
-
job_context_->memtables_to_free.push_back(new_mem);
|
|
646
|
-
}
|
|
647
|
-
}
|
|
648
|
-
} else {
|
|
649
|
-
// In this case, the newly allocated new_mem is empty.
|
|
650
|
-
assert(new_mem != nullptr);
|
|
651
|
-
job_context_->memtables_to_free.push_back(new_mem);
|
|
652
|
-
}
|
|
653
|
-
}
|
|
654
|
-
|
|
655
|
-
// Reacquire the mutex for WriteLevel0 function.
|
|
656
|
-
db_mutex_->Lock();
|
|
657
|
-
|
|
658
|
-
// If mempurge successful, don't write input tables to level0,
|
|
659
|
-
// but write any full output table to level0.
|
|
660
|
-
if (s.ok()) {
|
|
661
|
-
TEST_SYNC_POINT("DBImpl::FlushJob:MemPurgeSuccessful");
|
|
662
|
-
} else {
|
|
663
|
-
TEST_SYNC_POINT("DBImpl::FlushJob:MemPurgeUnsuccessful");
|
|
664
|
-
}
|
|
665
|
-
const uint64_t micros = clock_->NowMicros() - start_micros;
|
|
666
|
-
const uint64_t cpu_micros = clock_->CPUMicros() - start_cpu_micros;
|
|
667
|
-
ROCKS_LOG_INFO(db_options_.info_log,
|
|
668
|
-
"[%s] [JOB %d] Mempurge lasted %" PRIu64
|
|
669
|
-
" microseconds, and %" PRIu64
|
|
670
|
-
" cpu "
|
|
671
|
-
"microseconds. Status is %s ok. Perc capacity: %f\n",
|
|
672
|
-
cfd_->GetName().c_str(), job_context_->job_id, micros,
|
|
673
|
-
cpu_micros, s.ok() ? "" : "not", new_mem_capacity);
|
|
674
|
-
|
|
675
|
-
return s;
|
|
676
|
-
}
|
|
677
|
-
|
|
678
|
-
bool FlushJob::MemPurgeDecider(double threshold) {
|
|
679
|
-
// Never trigger mempurge if threshold is not a strictly positive value.
|
|
680
|
-
if (!(threshold > 0.0)) {
|
|
681
|
-
return false;
|
|
682
|
-
}
|
|
683
|
-
if (threshold > (1.0 * mems_.size())) {
|
|
684
|
-
return true;
|
|
685
|
-
}
|
|
686
|
-
// Payload and useful_payload (in bytes).
|
|
687
|
-
// The useful payload ratio of a given MemTable
|
|
688
|
-
// is estimated to be useful_payload/payload.
|
|
689
|
-
uint64_t payload = 0, useful_payload = 0, entry_size = 0;
|
|
690
|
-
|
|
691
|
-
// Local variables used repetitively inside the for-loop
|
|
692
|
-
// when iterating over the sampled entries.
|
|
693
|
-
Slice key_slice, value_slice;
|
|
694
|
-
ParsedInternalKey res;
|
|
695
|
-
SnapshotImpl min_snapshot;
|
|
696
|
-
std::string vget;
|
|
697
|
-
Status mget_s, parse_s;
|
|
698
|
-
MergeContext merge_context;
|
|
699
|
-
SequenceNumber max_covering_tombstone_seq = 0, sqno = 0,
|
|
700
|
-
min_seqno_snapshot = 0;
|
|
701
|
-
bool get_res, can_be_useful_payload, not_in_next_mems;
|
|
702
|
-
|
|
703
|
-
// If estimated_useful_payload is > threshold,
|
|
704
|
-
// then flush to storage, else MemPurge.
|
|
705
|
-
double estimated_useful_payload = 0.0;
|
|
706
|
-
// Cochran formula for determining sample size.
|
|
707
|
-
// 95% confidence interval, 7% precision.
|
|
708
|
-
// n0 = (1.96*1.96)*0.25/(0.07*0.07) = 196.0
|
|
709
|
-
double n0 = 196.0;
|
|
710
|
-
// TODO: plumb Env::IOActivity, Env::IOPriority
|
|
711
|
-
ReadOptions ro;
|
|
712
|
-
ro.total_order_seek = true;
|
|
713
|
-
|
|
714
|
-
// Iterate over each memtable of the set.
|
|
715
|
-
for (auto mem_iter = std::begin(mems_); mem_iter != std::end(mems_);
|
|
716
|
-
mem_iter++) {
|
|
717
|
-
MemTable* mt = *mem_iter;
|
|
718
|
-
|
|
719
|
-
// Else sample from the table.
|
|
720
|
-
uint64_t nentries = mt->num_entries();
|
|
721
|
-
// Corrected Cochran formula for small populations
|
|
722
|
-
// (converges to n0 for large populations).
|
|
723
|
-
uint64_t target_sample_size =
|
|
724
|
-
static_cast<uint64_t>(ceil(n0 / (1.0 + (n0 / nentries))));
|
|
725
|
-
std::unordered_set<const char*> sentries = {};
|
|
726
|
-
// Populate sample entries set.
|
|
727
|
-
mt->UniqueRandomSample(target_sample_size, &sentries);
|
|
728
|
-
|
|
729
|
-
// Estimate the garbage ratio by comparing if
|
|
730
|
-
// each sample corresponds to a valid entry.
|
|
731
|
-
for (const char* ss : sentries) {
|
|
732
|
-
key_slice = GetLengthPrefixedSlice(ss);
|
|
733
|
-
parse_s = ParseInternalKey(key_slice, &res, true /*log_err_key*/);
|
|
734
|
-
if (!parse_s.ok()) {
|
|
735
|
-
ROCKS_LOG_WARN(db_options_.info_log,
|
|
736
|
-
"Memtable Decider: ParseInternalKey did not parse "
|
|
737
|
-
"key_slice %s successfully.",
|
|
738
|
-
key_slice.data());
|
|
739
|
-
}
|
|
740
|
-
|
|
741
|
-
// Size of the entry is "key size (+ value size if KV entry)"
|
|
742
|
-
entry_size = key_slice.size();
|
|
743
|
-
if (res.type == kTypeValue) {
|
|
744
|
-
value_slice =
|
|
745
|
-
GetLengthPrefixedSlice(key_slice.data() + key_slice.size());
|
|
746
|
-
entry_size += value_slice.size();
|
|
747
|
-
}
|
|
748
|
-
|
|
749
|
-
// Count entry bytes as payload.
|
|
750
|
-
payload += entry_size;
|
|
751
|
-
|
|
752
|
-
LookupKey lkey(res.user_key, kMaxSequenceNumber);
|
|
753
|
-
|
|
754
|
-
// Paranoia: zero out these values just in case.
|
|
755
|
-
max_covering_tombstone_seq = 0;
|
|
756
|
-
sqno = 0;
|
|
757
|
-
|
|
758
|
-
// Pick the oldest existing snapshot that is more recent
|
|
759
|
-
// than the sequence number of the sampled entry.
|
|
760
|
-
min_seqno_snapshot = kMaxSequenceNumber;
|
|
761
|
-
for (SequenceNumber seq_num : existing_snapshots_) {
|
|
762
|
-
if (seq_num > res.sequence && seq_num < min_seqno_snapshot) {
|
|
763
|
-
min_seqno_snapshot = seq_num;
|
|
764
|
-
}
|
|
765
|
-
}
|
|
766
|
-
min_snapshot.number_ = min_seqno_snapshot;
|
|
767
|
-
ro.snapshot =
|
|
768
|
-
min_seqno_snapshot < kMaxSequenceNumber ? &min_snapshot : nullptr;
|
|
769
|
-
|
|
770
|
-
// Estimate if the sample entry is valid or not.
|
|
771
|
-
get_res = mt->Get(lkey, &vget, /*columns=*/nullptr, /*timestamp=*/nullptr,
|
|
772
|
-
&mget_s, &merge_context, &max_covering_tombstone_seq,
|
|
773
|
-
&sqno, ro, true /* immutable_memtable */);
|
|
774
|
-
if (!get_res) {
|
|
775
|
-
ROCKS_LOG_WARN(
|
|
776
|
-
db_options_.info_log,
|
|
777
|
-
"Memtable Get returned false when Get(sampled entry). "
|
|
778
|
-
"Yet each sample entry should exist somewhere in the memtable, "
|
|
779
|
-
"unrelated to whether it has been deleted or not.");
|
|
780
|
-
}
|
|
781
|
-
|
|
782
|
-
// TODO(bjlemaire): evaluate typeMerge.
|
|
783
|
-
// This is where the sampled entry is estimated to be
|
|
784
|
-
// garbage or not. Note that this is a garbage *estimation*
|
|
785
|
-
// because we do not include certain items such as
|
|
786
|
-
// CompactionFitlers triggered at flush, or if the same delete
|
|
787
|
-
// has been inserted twice or more in the memtable.
|
|
788
|
-
|
|
789
|
-
// Evaluate if the entry can be useful payload
|
|
790
|
-
// Situation #1: entry is a KV entry, was found in the memtable mt
|
|
791
|
-
// and the sequence numbers match.
|
|
792
|
-
can_be_useful_payload = (res.type == kTypeValue) && get_res &&
|
|
793
|
-
mget_s.ok() && (sqno == res.sequence);
|
|
794
|
-
|
|
795
|
-
// Situation #2: entry is a delete entry, was found in the memtable mt
|
|
796
|
-
// (because gres==true) and no valid KV entry is found.
|
|
797
|
-
// (note: duplicate delete entries are also taken into
|
|
798
|
-
// account here, because the sequence number 'sqno'
|
|
799
|
-
// in memtable->Get(&sqno) operation is set to be equal
|
|
800
|
-
// to the most recent delete entry as well).
|
|
801
|
-
can_be_useful_payload |=
|
|
802
|
-
((res.type == kTypeDeletion) || (res.type == kTypeSingleDeletion)) &&
|
|
803
|
-
mget_s.IsNotFound() && get_res && (sqno == res.sequence);
|
|
804
|
-
|
|
805
|
-
// If there is a chance that the entry is useful payload
|
|
806
|
-
// Verify that the entry does not appear in the following memtables
|
|
807
|
-
// (memtables with greater memtable ID/larger sequence numbers).
|
|
808
|
-
if (can_be_useful_payload) {
|
|
809
|
-
not_in_next_mems = true;
|
|
810
|
-
for (auto next_mem_iter = mem_iter + 1;
|
|
811
|
-
next_mem_iter != std::end(mems_); next_mem_iter++) {
|
|
812
|
-
if ((*next_mem_iter)
|
|
813
|
-
->Get(lkey, &vget, /*columns=*/nullptr, /*timestamp=*/nullptr,
|
|
814
|
-
&mget_s, &merge_context, &max_covering_tombstone_seq,
|
|
815
|
-
&sqno, ro, true /* immutable_memtable */)) {
|
|
816
|
-
not_in_next_mems = false;
|
|
817
|
-
break;
|
|
818
|
-
}
|
|
819
|
-
}
|
|
820
|
-
if (not_in_next_mems) {
|
|
821
|
-
useful_payload += entry_size;
|
|
822
|
-
}
|
|
823
|
-
}
|
|
824
|
-
}
|
|
825
|
-
if (payload > 0) {
|
|
826
|
-
// We use the estimated useful payload ratio to
|
|
827
|
-
// evaluate how many of the memtable bytes are useful bytes.
|
|
828
|
-
estimated_useful_payload +=
|
|
829
|
-
(mt->ApproximateMemoryUsage()) * (useful_payload * 1.0 / payload);
|
|
830
|
-
|
|
831
|
-
ROCKS_LOG_INFO(db_options_.info_log,
|
|
832
|
-
"Mempurge sampling [CF %s] - found garbage ratio from "
|
|
833
|
-
"sampling: %f. Threshold is %f\n",
|
|
834
|
-
cfd_->GetName().c_str(),
|
|
835
|
-
(payload - useful_payload) * 1.0 / payload, threshold);
|
|
836
|
-
} else {
|
|
837
|
-
ROCKS_LOG_WARN(db_options_.info_log,
|
|
838
|
-
"Mempurge sampling: null payload measured, and collected "
|
|
839
|
-
"sample size is %zu\n.",
|
|
840
|
-
sentries.size());
|
|
841
|
-
}
|
|
842
|
-
}
|
|
843
|
-
// We convert the total number of useful payload bytes
|
|
844
|
-
// into the proportion of memtable necessary to store all these bytes.
|
|
845
|
-
// We compare this proportion with the threshold value.
|
|
846
|
-
return ((estimated_useful_payload / mutable_cf_options_.write_buffer_size) <
|
|
847
|
-
threshold);
|
|
848
|
-
}
|
|
849
|
-
|
|
850
|
-
Status FlushJob::WriteLevel0Table() {
|
|
851
|
-
AutoThreadOperationStageUpdater stage_updater(
|
|
852
|
-
ThreadStatus::STAGE_FLUSH_WRITE_L0);
|
|
853
|
-
db_mutex_->AssertHeld();
|
|
854
|
-
const uint64_t start_micros = clock_->NowMicros();
|
|
855
|
-
const uint64_t start_cpu_micros = clock_->CPUMicros();
|
|
856
|
-
Status s;
|
|
857
|
-
|
|
858
|
-
meta_.temperature = mutable_cf_options_.default_write_temperature;
|
|
859
|
-
file_options_.temperature = meta_.temperature;
|
|
860
|
-
|
|
861
|
-
std::vector<BlobFileAddition> blob_file_additions;
|
|
862
|
-
|
|
863
|
-
{
|
|
864
|
-
auto write_hint = cfd_->CalculateSSTWriteHint(0);
|
|
865
|
-
Env::IOPriority io_priority = GetRateLimiterPriority();
|
|
866
|
-
db_mutex_->Unlock();
|
|
867
|
-
if (log_buffer_) {
|
|
868
|
-
log_buffer_->FlushBufferToLog();
|
|
869
|
-
}
|
|
870
|
-
// memtables and range_del_iters store internal iterators over each data
|
|
871
|
-
// memtable and its associated range deletion memtable, respectively, at
|
|
872
|
-
// corresponding indexes.
|
|
873
|
-
std::vector<InternalIterator*> memtables;
|
|
874
|
-
std::vector<std::unique_ptr<FragmentedRangeTombstoneIterator>>
|
|
875
|
-
range_del_iters;
|
|
876
|
-
ReadOptions ro;
|
|
877
|
-
ro.total_order_seek = true;
|
|
878
|
-
ro.io_activity = Env::IOActivity::kFlush;
|
|
879
|
-
Arena arena;
|
|
880
|
-
uint64_t total_num_entries = 0, total_num_deletes = 0;
|
|
881
|
-
uint64_t total_data_size = 0;
|
|
882
|
-
size_t total_memory_usage = 0;
|
|
883
|
-
uint64_t total_num_range_deletes = 0;
|
|
884
|
-
// Used for testing:
|
|
885
|
-
uint64_t mems_size = mems_.size();
|
|
886
|
-
(void)mems_size; // avoids unused variable error when
|
|
887
|
-
// TEST_SYNC_POINT_CALLBACK not used.
|
|
888
|
-
TEST_SYNC_POINT_CALLBACK("FlushJob::WriteLevel0Table:num_memtables",
|
|
889
|
-
&mems_size);
|
|
890
|
-
assert(job_context_);
|
|
891
|
-
for (MemTable* m : mems_) {
|
|
892
|
-
ROCKS_LOG_INFO(
|
|
893
|
-
db_options_.info_log,
|
|
894
|
-
"[%s] [JOB %d] Flushing memtable with next log file: %" PRIu64 "\n",
|
|
895
|
-
cfd_->GetName().c_str(), job_context_->job_id, m->GetNextLogNumber());
|
|
896
|
-
memtables.push_back(
|
|
897
|
-
m->NewIterator(ro, /*seqno_to_time_mapping=*/nullptr, &arena));
|
|
898
|
-
auto* range_del_iter = m->NewRangeTombstoneIterator(
|
|
899
|
-
ro, kMaxSequenceNumber, true /* immutable_memtable */);
|
|
900
|
-
if (range_del_iter != nullptr) {
|
|
901
|
-
range_del_iters.emplace_back(range_del_iter);
|
|
902
|
-
}
|
|
903
|
-
total_num_entries += m->num_entries();
|
|
904
|
-
total_num_deletes += m->num_deletes();
|
|
905
|
-
total_data_size += m->get_data_size();
|
|
906
|
-
total_memory_usage += m->ApproximateMemoryUsage();
|
|
907
|
-
total_num_range_deletes += m->num_range_deletes();
|
|
908
|
-
}
|
|
909
|
-
|
|
910
|
-
// TODO(cbi): when memtable is flushed due to number of range deletions
|
|
911
|
-
// hitting limit memtable_max_range_deletions, flush_reason_ is still
|
|
912
|
-
// "Write Buffer Full", should make update flush_reason_ accordingly.
|
|
913
|
-
event_logger_->Log() << "job" << job_context_->job_id << "event"
|
|
914
|
-
<< "flush_started"
|
|
915
|
-
<< "num_memtables" << mems_.size() << "num_entries"
|
|
916
|
-
<< total_num_entries << "num_deletes"
|
|
917
|
-
<< total_num_deletes << "total_data_size"
|
|
918
|
-
<< total_data_size << "memory_usage"
|
|
919
|
-
<< total_memory_usage << "num_range_deletes"
|
|
920
|
-
<< total_num_range_deletes << "flush_reason"
|
|
921
|
-
<< GetFlushReasonString(flush_reason_);
|
|
922
|
-
|
|
923
|
-
{
|
|
924
|
-
ScopedArenaPtr<InternalIterator> iter(
|
|
925
|
-
NewMergingIterator(&cfd_->internal_comparator(), memtables.data(),
|
|
926
|
-
static_cast<int>(memtables.size()), &arena));
|
|
927
|
-
ROCKS_LOG_INFO(db_options_.info_log,
|
|
928
|
-
"[%s] [JOB %d] Level-0 flush table #%" PRIu64 ": started",
|
|
929
|
-
cfd_->GetName().c_str(), job_context_->job_id,
|
|
930
|
-
meta_.fd.GetNumber());
|
|
931
|
-
|
|
932
|
-
TEST_SYNC_POINT_CALLBACK("FlushJob::WriteLevel0Table:output_compression",
|
|
933
|
-
&output_compression_);
|
|
934
|
-
int64_t _current_time = 0;
|
|
935
|
-
auto status = clock_->GetCurrentTime(&_current_time);
|
|
936
|
-
// Safe to proceed even if GetCurrentTime fails. So, log and proceed.
|
|
937
|
-
if (!status.ok()) {
|
|
938
|
-
ROCKS_LOG_WARN(
|
|
939
|
-
db_options_.info_log,
|
|
940
|
-
"Failed to get current time to populate creation_time property. "
|
|
941
|
-
"Status: %s",
|
|
942
|
-
status.ToString().c_str());
|
|
943
|
-
}
|
|
944
|
-
const uint64_t current_time = static_cast<uint64_t>(_current_time);
|
|
945
|
-
|
|
946
|
-
uint64_t oldest_key_time = mems_.front()->ApproximateOldestKeyTime();
|
|
947
|
-
|
|
948
|
-
// It's not clear whether oldest_key_time is always available. In case
|
|
949
|
-
// it is not available, use current_time.
|
|
950
|
-
uint64_t oldest_ancester_time = std::min(current_time, oldest_key_time);
|
|
951
|
-
|
|
952
|
-
TEST_SYNC_POINT_CALLBACK(
|
|
953
|
-
"FlushJob::WriteLevel0Table:oldest_ancester_time",
|
|
954
|
-
&oldest_ancester_time);
|
|
955
|
-
meta_.oldest_ancester_time = oldest_ancester_time;
|
|
956
|
-
meta_.file_creation_time = current_time;
|
|
957
|
-
|
|
958
|
-
uint64_t num_input_entries = 0;
|
|
959
|
-
uint64_t memtable_payload_bytes = 0;
|
|
960
|
-
uint64_t memtable_garbage_bytes = 0;
|
|
961
|
-
IOStatus io_s;
|
|
962
|
-
|
|
963
|
-
const std::string* const full_history_ts_low =
|
|
964
|
-
(full_history_ts_low_.empty()) ? nullptr : &full_history_ts_low_;
|
|
965
|
-
ReadOptions read_options(Env::IOActivity::kFlush);
|
|
966
|
-
read_options.rate_limiter_priority = io_priority;
|
|
967
|
-
const WriteOptions write_options(io_priority, Env::IOActivity::kFlush);
|
|
968
|
-
TableBuilderOptions tboptions(
|
|
969
|
-
*cfd_->ioptions(), mutable_cf_options_, read_options, write_options,
|
|
970
|
-
cfd_->internal_comparator(), cfd_->internal_tbl_prop_coll_factories(),
|
|
971
|
-
output_compression_, mutable_cf_options_.compression_opts,
|
|
972
|
-
cfd_->GetID(), cfd_->GetName(), 0 /* level */,
|
|
973
|
-
false /* is_bottommost */, TableFileCreationReason::kFlush,
|
|
974
|
-
oldest_key_time, current_time, db_id_, db_session_id_,
|
|
975
|
-
0 /* target_file_size */, meta_.fd.GetNumber(),
|
|
976
|
-
preclude_last_level_min_seqno_ == kMaxSequenceNumber
|
|
977
|
-
? preclude_last_level_min_seqno_
|
|
978
|
-
: std::min(earliest_snapshot_, preclude_last_level_min_seqno_));
|
|
979
|
-
const SequenceNumber job_snapshot_seq =
|
|
980
|
-
job_context_->GetJobSnapshotSequence();
|
|
981
|
-
|
|
982
|
-
s = BuildTable(
|
|
983
|
-
dbname_, versions_, db_options_, tboptions, file_options_,
|
|
984
|
-
cfd_->table_cache(), iter.get(), std::move(range_del_iters), &meta_,
|
|
985
|
-
&blob_file_additions, existing_snapshots_, earliest_snapshot_,
|
|
986
|
-
earliest_write_conflict_snapshot_, job_snapshot_seq,
|
|
987
|
-
snapshot_checker_, mutable_cf_options_.paranoid_file_checks,
|
|
988
|
-
cfd_->internal_stats(), &io_s, io_tracer_,
|
|
989
|
-
BlobFileCreationReason::kFlush, seqno_to_time_mapping_.get(),
|
|
990
|
-
event_logger_, job_context_->job_id, &table_properties_, write_hint,
|
|
991
|
-
full_history_ts_low, blob_callback_, base_, &num_input_entries,
|
|
992
|
-
&memtable_payload_bytes, &memtable_garbage_bytes);
|
|
993
|
-
TEST_SYNC_POINT_CALLBACK("FlushJob::WriteLevel0Table:s", &s);
|
|
994
|
-
// TODO: Cleanup io_status in BuildTable and table builders
|
|
995
|
-
assert(!s.ok() || io_s.ok());
|
|
996
|
-
io_s.PermitUncheckedError();
|
|
997
|
-
if (num_input_entries != total_num_entries && s.ok()) {
|
|
998
|
-
std::string msg = "Expected " + std::to_string(total_num_entries) +
|
|
999
|
-
" entries in memtables, but read " +
|
|
1000
|
-
std::to_string(num_input_entries);
|
|
1001
|
-
ROCKS_LOG_WARN(db_options_.info_log, "[%s] [JOB %d] Level-0 flush %s",
|
|
1002
|
-
cfd_->GetName().c_str(), job_context_->job_id,
|
|
1003
|
-
msg.c_str());
|
|
1004
|
-
if (db_options_.flush_verify_memtable_count) {
|
|
1005
|
-
s = Status::Corruption(msg);
|
|
1006
|
-
}
|
|
1007
|
-
}
|
|
1008
|
-
if (tboptions.reason == TableFileCreationReason::kFlush) {
|
|
1009
|
-
TEST_SYNC_POINT("DBImpl::FlushJob:Flush");
|
|
1010
|
-
RecordTick(stats_, MEMTABLE_PAYLOAD_BYTES_AT_FLUSH,
|
|
1011
|
-
memtable_payload_bytes);
|
|
1012
|
-
RecordTick(stats_, MEMTABLE_GARBAGE_BYTES_AT_FLUSH,
|
|
1013
|
-
memtable_garbage_bytes);
|
|
1014
|
-
}
|
|
1015
|
-
LogFlush(db_options_.info_log);
|
|
1016
|
-
}
|
|
1017
|
-
ROCKS_LOG_BUFFER(log_buffer_,
|
|
1018
|
-
"[%s] [JOB %d] Level-0 flush table #%" PRIu64 ": %" PRIu64
|
|
1019
|
-
" bytes %s"
|
|
1020
|
-
" %s"
|
|
1021
|
-
" %s",
|
|
1022
|
-
cfd_->GetName().c_str(), job_context_->job_id,
|
|
1023
|
-
meta_.fd.GetNumber(), meta_.fd.GetFileSize(),
|
|
1024
|
-
s.ToString().c_str(),
|
|
1025
|
-
s.ok() && meta_.fd.GetFileSize() == 0
|
|
1026
|
-
? "It's an empty SST file from a successful flush so "
|
|
1027
|
-
"won't be kept in the DB"
|
|
1028
|
-
: "",
|
|
1029
|
-
meta_.marked_for_compaction ? " (needs compaction)" : "");
|
|
1030
|
-
|
|
1031
|
-
if (s.ok() && output_file_directory_ != nullptr && sync_output_directory_) {
|
|
1032
|
-
s = output_file_directory_->FsyncWithDirOptions(
|
|
1033
|
-
IOOptions(), nullptr,
|
|
1034
|
-
DirFsyncOptions(DirFsyncOptions::FsyncReason::kNewFileSynced));
|
|
1035
|
-
}
|
|
1036
|
-
TEST_SYNC_POINT_CALLBACK("FlushJob::WriteLevel0Table", &mems_);
|
|
1037
|
-
db_mutex_->Lock();
|
|
1038
|
-
}
|
|
1039
|
-
base_->Unref();
|
|
1040
|
-
|
|
1041
|
-
// Note that if file_size is zero, the file has been deleted and
|
|
1042
|
-
// should not be added to the manifest.
|
|
1043
|
-
const bool has_output = meta_.fd.GetFileSize() > 0;
|
|
1044
|
-
|
|
1045
|
-
if (s.ok() && has_output) {
|
|
1046
|
-
TEST_SYNC_POINT("DBImpl::FlushJob:SSTFileCreated");
|
|
1047
|
-
// if we have more than 1 background thread, then we cannot
|
|
1048
|
-
// insert files directly into higher levels because some other
|
|
1049
|
-
// threads could be concurrently producing compacted files for
|
|
1050
|
-
// that key range.
|
|
1051
|
-
// Add file to L0
|
|
1052
|
-
edit_->AddFile(0 /* level */, meta_.fd.GetNumber(), meta_.fd.GetPathId(),
|
|
1053
|
-
meta_.fd.GetFileSize(), meta_.smallest, meta_.largest,
|
|
1054
|
-
meta_.fd.smallest_seqno, meta_.fd.largest_seqno,
|
|
1055
|
-
meta_.marked_for_compaction, meta_.temperature,
|
|
1056
|
-
meta_.oldest_blob_file_number, meta_.oldest_ancester_time,
|
|
1057
|
-
meta_.file_creation_time, meta_.epoch_number,
|
|
1058
|
-
meta_.file_checksum, meta_.file_checksum_func_name,
|
|
1059
|
-
meta_.unique_id, meta_.compensated_range_deletion_size,
|
|
1060
|
-
meta_.tail_size, meta_.user_defined_timestamps_persisted);
|
|
1061
|
-
edit_->SetBlobFileAdditions(std::move(blob_file_additions));
|
|
1062
|
-
}
|
|
1063
|
-
// Piggyback FlushJobInfo on the first first flushed memtable.
|
|
1064
|
-
mems_[0]->SetFlushJobInfo(GetFlushJobInfo());
|
|
1065
|
-
|
|
1066
|
-
// Note that here we treat flush as level 0 compaction in internal stats
|
|
1067
|
-
InternalStats::CompactionStats stats(CompactionReason::kFlush, 1);
|
|
1068
|
-
const uint64_t micros = clock_->NowMicros() - start_micros;
|
|
1069
|
-
const uint64_t cpu_micros = clock_->CPUMicros() - start_cpu_micros;
|
|
1070
|
-
stats.micros = micros;
|
|
1071
|
-
stats.cpu_micros = cpu_micros;
|
|
1072
|
-
|
|
1073
|
-
ROCKS_LOG_INFO(db_options_.info_log,
|
|
1074
|
-
"[%s] [JOB %d] Flush lasted %" PRIu64
|
|
1075
|
-
" microseconds, and %" PRIu64 " cpu microseconds.\n",
|
|
1076
|
-
cfd_->GetName().c_str(), job_context_->job_id, micros,
|
|
1077
|
-
cpu_micros);
|
|
1078
|
-
|
|
1079
|
-
if (has_output) {
|
|
1080
|
-
stats.bytes_written = meta_.fd.GetFileSize();
|
|
1081
|
-
stats.num_output_files = 1;
|
|
1082
|
-
}
|
|
1083
|
-
|
|
1084
|
-
const auto& blobs = edit_->GetBlobFileAdditions();
|
|
1085
|
-
for (const auto& blob : blobs) {
|
|
1086
|
-
stats.bytes_written_blob += blob.GetTotalBlobBytes();
|
|
1087
|
-
}
|
|
1088
|
-
|
|
1089
|
-
stats.num_output_files_blob = static_cast<int>(blobs.size());
|
|
1090
|
-
|
|
1091
|
-
RecordTimeToHistogram(stats_, FLUSH_TIME, stats.micros);
|
|
1092
|
-
cfd_->internal_stats()->AddCompactionStats(0 /* level */, thread_pri_, stats);
|
|
1093
|
-
cfd_->internal_stats()->AddCFStats(
|
|
1094
|
-
InternalStats::BYTES_FLUSHED,
|
|
1095
|
-
stats.bytes_written + stats.bytes_written_blob);
|
|
1096
|
-
RecordFlushIOStats();
|
|
1097
|
-
|
|
1098
|
-
return s;
|
|
1099
|
-
}
|
|
1100
|
-
|
|
1101
|
-
Env::IOPriority FlushJob::GetRateLimiterPriority() {
|
|
1102
|
-
if (versions_ && versions_->GetColumnFamilySet() &&
|
|
1103
|
-
versions_->GetColumnFamilySet()->write_controller()) {
|
|
1104
|
-
WriteController* write_controller =
|
|
1105
|
-
versions_->GetColumnFamilySet()->write_controller();
|
|
1106
|
-
if (write_controller->IsStopped() || write_controller->NeedsDelay()) {
|
|
1107
|
-
return Env::IO_USER;
|
|
1108
|
-
}
|
|
1109
|
-
}
|
|
1110
|
-
|
|
1111
|
-
return Env::IO_HIGH;
|
|
1112
|
-
}
|
|
1113
|
-
|
|
1114
|
-
std::unique_ptr<FlushJobInfo> FlushJob::GetFlushJobInfo() const {
|
|
1115
|
-
db_mutex_->AssertHeld();
|
|
1116
|
-
std::unique_ptr<FlushJobInfo> info(new FlushJobInfo{});
|
|
1117
|
-
info->cf_id = cfd_->GetID();
|
|
1118
|
-
info->cf_name = cfd_->GetName();
|
|
1119
|
-
|
|
1120
|
-
const uint64_t file_number = meta_.fd.GetNumber();
|
|
1121
|
-
info->file_path =
|
|
1122
|
-
MakeTableFileName(cfd_->ioptions()->cf_paths[0].path, file_number);
|
|
1123
|
-
info->file_number = file_number;
|
|
1124
|
-
info->oldest_blob_file_number = meta_.oldest_blob_file_number;
|
|
1125
|
-
info->thread_id = db_options_.env->GetThreadID();
|
|
1126
|
-
info->job_id = job_context_->job_id;
|
|
1127
|
-
info->smallest_seqno = meta_.fd.smallest_seqno;
|
|
1128
|
-
info->largest_seqno = meta_.fd.largest_seqno;
|
|
1129
|
-
info->table_properties = table_properties_;
|
|
1130
|
-
info->flush_reason = flush_reason_;
|
|
1131
|
-
info->blob_compression_type = mutable_cf_options_.blob_compression_type;
|
|
1132
|
-
|
|
1133
|
-
// Update BlobFilesInfo.
|
|
1134
|
-
for (const auto& blob_file : edit_->GetBlobFileAdditions()) {
|
|
1135
|
-
BlobFileAdditionInfo blob_file_addition_info(
|
|
1136
|
-
BlobFileName(cfd_->ioptions()->cf_paths.front().path,
|
|
1137
|
-
blob_file.GetBlobFileNumber()) /*blob_file_path*/,
|
|
1138
|
-
blob_file.GetBlobFileNumber(), blob_file.GetTotalBlobCount(),
|
|
1139
|
-
blob_file.GetTotalBlobBytes());
|
|
1140
|
-
info->blob_file_addition_infos.emplace_back(
|
|
1141
|
-
std::move(blob_file_addition_info));
|
|
1142
|
-
}
|
|
1143
|
-
return info;
|
|
1144
|
-
}
|
|
1145
|
-
|
|
1146
|
-
void FlushJob::GetEffectiveCutoffUDTForPickedMemTables() {
|
|
1147
|
-
db_mutex_->AssertHeld();
|
|
1148
|
-
assert(pick_memtable_called);
|
|
1149
|
-
const auto* ucmp = cfd_->internal_comparator().user_comparator();
|
|
1150
|
-
assert(ucmp);
|
|
1151
|
-
const size_t ts_sz = ucmp->timestamp_size();
|
|
1152
|
-
if (db_options_.atomic_flush || ts_sz == 0 ||
|
|
1153
|
-
cfd_->ioptions()->persist_user_defined_timestamps) {
|
|
1154
|
-
return;
|
|
1155
|
-
}
|
|
1156
|
-
// Find the newest user-defined timestamps from all the flushed memtables.
|
|
1157
|
-
for (MemTable* m : mems_) {
|
|
1158
|
-
Slice table_newest_udt = m->GetNewestUDT();
|
|
1159
|
-
if (cutoff_udt_.empty() ||
|
|
1160
|
-
ucmp->CompareTimestamp(table_newest_udt, cutoff_udt_) > 0) {
|
|
1161
|
-
if (!cutoff_udt_.empty()) {
|
|
1162
|
-
assert(table_newest_udt.size() == cutoff_udt_.size());
|
|
1163
|
-
}
|
|
1164
|
-
cutoff_udt_.assign(table_newest_udt.data(), table_newest_udt.size());
|
|
1165
|
-
}
|
|
1166
|
-
}
|
|
1167
|
-
}
|
|
1168
|
-
|
|
1169
|
-
void FlushJob::GetPrecludeLastLevelMinSeqno() {
|
|
1170
|
-
if (cfd_->ioptions()->preclude_last_level_data_seconds == 0) {
|
|
1171
|
-
return;
|
|
1172
|
-
}
|
|
1173
|
-
int64_t current_time = 0;
|
|
1174
|
-
Status s = db_options_.clock->GetCurrentTime(¤t_time);
|
|
1175
|
-
if (!s.ok()) {
|
|
1176
|
-
ROCKS_LOG_WARN(db_options_.info_log,
|
|
1177
|
-
"Failed to get current time in Flush: Status: %s",
|
|
1178
|
-
s.ToString().c_str());
|
|
1179
|
-
} else {
|
|
1180
|
-
SequenceNumber preserve_time_min_seqno;
|
|
1181
|
-
seqno_to_time_mapping_->GetCurrentTieringCutoffSeqnos(
|
|
1182
|
-
static_cast<uint64_t>(current_time),
|
|
1183
|
-
cfd_->ioptions()->preserve_internal_time_seconds,
|
|
1184
|
-
cfd_->ioptions()->preclude_last_level_data_seconds,
|
|
1185
|
-
&preserve_time_min_seqno, &preclude_last_level_min_seqno_);
|
|
1186
|
-
}
|
|
1187
|
-
}
|
|
1188
|
-
|
|
1189
|
-
Status FlushJob::MaybeIncreaseFullHistoryTsLowToAboveCutoffUDT() {
|
|
1190
|
-
db_mutex_->AssertHeld();
|
|
1191
|
-
const auto* ucmp = cfd_->user_comparator();
|
|
1192
|
-
assert(ucmp);
|
|
1193
|
-
const std::string& full_history_ts_low = cfd_->GetFullHistoryTsLow();
|
|
1194
|
-
// Update full_history_ts_low to right above cutoff udt only if that would
|
|
1195
|
-
// increase it.
|
|
1196
|
-
if (cutoff_udt_.empty() ||
|
|
1197
|
-
(!full_history_ts_low.empty() &&
|
|
1198
|
-
ucmp->CompareTimestamp(cutoff_udt_, full_history_ts_low) < 0)) {
|
|
1199
|
-
return Status::OK();
|
|
1200
|
-
}
|
|
1201
|
-
std::string new_full_history_ts_low;
|
|
1202
|
-
Slice cutoff_udt_slice = cutoff_udt_;
|
|
1203
|
-
// TODO(yuzhangyu): Add a member to AdvancedColumnFamilyOptions for an
|
|
1204
|
-
// operation to get the next immediately larger user-defined timestamp to
|
|
1205
|
-
// expand this feature to other user-defined timestamp formats.
|
|
1206
|
-
GetFullHistoryTsLowFromU64CutoffTs(&cutoff_udt_slice,
|
|
1207
|
-
&new_full_history_ts_low);
|
|
1208
|
-
VersionEdit edit;
|
|
1209
|
-
edit.SetColumnFamily(cfd_->GetID());
|
|
1210
|
-
edit.SetFullHistoryTsLow(new_full_history_ts_low);
|
|
1211
|
-
return versions_->LogAndApply(cfd_, *cfd_->GetLatestMutableCFOptions(),
|
|
1212
|
-
ReadOptions(Env::IOActivity::kFlush),
|
|
1213
|
-
WriteOptions(Env::IOActivity::kFlush), &edit,
|
|
1214
|
-
db_mutex_, output_file_directory_);
|
|
1215
|
-
}
|
|
1216
|
-
|
|
1217
|
-
} // namespace ROCKSDB_NAMESPACE
|