build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
# These are the sources from which librocksdb.a is built:
|
|
|
|
LIB_SOURCES = \
|
|
|
|
db/builder.cc \
|
|
|
|
db/c.cc \
|
|
|
|
db/column_family.cc \
|
|
|
|
db/compaction.cc \
|
|
|
|
db/compaction_job.cc \
|
|
|
|
db/compaction_picker.cc \
|
|
|
|
db/db_filesnapshot.cc \
|
|
|
|
db/dbformat.cc \
|
|
|
|
db/db_impl.cc \
|
|
|
|
db/db_impl_debug.cc \
|
|
|
|
db/db_impl_readonly.cc \
|
Add experimental API MarkForCompaction()
Summary:
Some Mongo+Rocks datasets in Parse's environment are not doing compactions very frequently. During the quiet period (with no IO), we'd like to schedule compactions so that our reads become faster. Also, aggressively compacting during quiet periods helps when write bursts happen. In addition, we also want to compact files that are containing deleted key ranges (like old oplog keys).
All of this is currently not possible with CompactRange() because it's single-threaded and blocks all other compactions from happening. Running CompactRange() risks an issue of blocking writes because we generate too much Level 0 files before the compaction is over. Stopping writes is very dangerous because they hold transaction locks. We tried running manual compaction once on Mongo+Rocks and everything fell apart.
MarkForCompaction() solves all of those problems. This is very light-weight manual compaction. It is lower priority than automatic compactions, which means it shouldn't interfere with background process keeping the LSM tree clean. However, if no automatic compactions need to be run (or we have extra background threads available), we will start compacting files that are marked for compaction.
Test Plan: added a new unit test
Reviewers: yhchiang, rven, MarkCallaghan, sdong
Reviewed By: sdong
Subscribers: yoshinorim, dhruba, leveldb
Differential Revision: https://reviews.facebook.net/D37083
10 years ago
|
|
|
db/db_impl_experimental.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
db/db_iter.cc \
|
Add experimental API MarkForCompaction()
Summary:
Some Mongo+Rocks datasets in Parse's environment are not doing compactions very frequently. During the quiet period (with no IO), we'd like to schedule compactions so that our reads become faster. Also, aggressively compacting during quiet periods helps when write bursts happen. In addition, we also want to compact files that are containing deleted key ranges (like old oplog keys).
All of this is currently not possible with CompactRange() because it's single-threaded and blocks all other compactions from happening. Running CompactRange() risks an issue of blocking writes because we generate too much Level 0 files before the compaction is over. Stopping writes is very dangerous because they hold transaction locks. We tried running manual compaction once on Mongo+Rocks and everything fell apart.
MarkForCompaction() solves all of those problems. This is very light-weight manual compaction. It is lower priority than automatic compactions, which means it shouldn't interfere with background process keeping the LSM tree clean. However, if no automatic compactions need to be run (or we have extra background threads available), we will start compacting files that are marked for compaction.
Test Plan: added a new unit test
Reviewers: yhchiang, rven, MarkCallaghan, sdong
Reviewed By: sdong
Subscribers: yoshinorim, dhruba, leveldb
Differential Revision: https://reviews.facebook.net/D37083
10 years ago
|
|
|
db/experimental.cc \
|
|
|
|
db/event_helpers.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
db/file_indexer.cc \
|
|
|
|
db/filename.cc \
|
|
|
|
db/flush_job.cc \
|
|
|
|
db/flush_scheduler.cc \
|
|
|
|
db/forward_iterator.cc \
|
|
|
|
db/internal_stats.cc \
|
|
|
|
db/log_reader.cc \
|
|
|
|
db/log_writer.cc \
|
|
|
|
db/managed_iterator.cc \
|
|
|
|
db/memtable_allocator.cc \
|
|
|
|
db/memtable.cc \
|
|
|
|
db/memtable_list.cc \
|
|
|
|
db/merge_helper.cc \
|
|
|
|
db/merge_operator.cc \
|
|
|
|
db/repair.cc \
|
|
|
|
db/slice.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
db/table_cache.cc \
|
|
|
|
db/table_properties_collector.cc \
|
|
|
|
db/transaction_log_impl.cc \
|
|
|
|
db/version_builder.cc \
|
|
|
|
db/version_edit.cc \
|
|
|
|
db/version_set.cc \
|
|
|
|
db/wal_manager.cc \
|
|
|
|
db/write_batch.cc \
|
|
|
|
db/write_batch_base.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
db/write_controller.cc \
|
|
|
|
db/write_thread.cc \
|
|
|
|
port/stack_trace.cc \
|
|
|
|
port/port_posix.cc \
|
|
|
|
table/adaptive_table_factory.cc \
|
|
|
|
table/block_based_filter_block.cc \
|
|
|
|
table/block_based_table_builder.cc \
|
|
|
|
table/block_based_table_factory.cc \
|
|
|
|
table/block_based_table_reader.cc \
|
|
|
|
table/block_builder.cc \
|
|
|
|
table/block.cc \
|
|
|
|
table/block_hash_index.cc \
|
|
|
|
table/block_prefix_index.cc \
|
|
|
|
table/bloom_block.cc \
|
|
|
|
table/cuckoo_table_builder.cc \
|
|
|
|
table/cuckoo_table_factory.cc \
|
|
|
|
table/cuckoo_table_reader.cc \
|
|
|
|
table/flush_block_policy.cc \
|
|
|
|
table/format.cc \
|
|
|
|
table/full_filter_block.cc \
|
|
|
|
table/get_context.cc \
|
|
|
|
table/iterator.cc \
|
|
|
|
table/merger.cc \
|
|
|
|
table/meta_blocks.cc \
|
|
|
|
table/plain_table_builder.cc \
|
|
|
|
table/plain_table_factory.cc \
|
|
|
|
table/plain_table_index.cc \
|
|
|
|
table/plain_table_key_coding.cc \
|
|
|
|
table/plain_table_reader.cc \
|
|
|
|
table/table_properties.cc \
|
|
|
|
table/two_level_iterator.cc \
|
|
|
|
util/arena.cc \
|
|
|
|
util/auto_roll_logger.cc \
|
|
|
|
util/bloom.cc \
|
|
|
|
util/build_version.cc \
|
|
|
|
util/cache.cc \
|
|
|
|
util/coding.cc \
|
|
|
|
util/comparator.cc \
|
|
|
|
util/crc32c.cc \
|
|
|
|
util/db_info_dumper.cc \
|
|
|
|
util/dynamic_bloom.cc \
|
|
|
|
util/env.cc \
|
|
|
|
util/env_hdfs.cc \
|
|
|
|
util/env_posix.cc \
|
|
|
|
util/file_util.cc \
|
|
|
|
util/filter_policy.cc \
|
|
|
|
util/hash.cc \
|
|
|
|
util/hash_cuckoo_rep.cc \
|
|
|
|
util/hash_linklist_rep.cc \
|
|
|
|
util/hash_skiplist_rep.cc \
|
|
|
|
util/histogram.cc \
|
|
|
|
util/instrumented_mutex.cc \
|
|
|
|
util/iostats_context.cc \
|
|
|
|
utilities/backupable/backupable_db.cc \
|
|
|
|
utilities/convenience/convenience.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
utilities/checkpoint/checkpoint.cc \
|
|
|
|
utilities/compacted_db/compacted_db_impl.cc \
|
|
|
|
utilities/document/document_db.cc \
|
|
|
|
utilities/document/json_document_builder.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
utilities/document/json_document.cc \
|
|
|
|
utilities/flashcache/flashcache.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
utilities/geodb/geodb_impl.cc \
|
|
|
|
utilities/leveldb_options/leveldb_options.cc \
|
|
|
|
utilities/merge_operators/put.cc \
|
|
|
|
utilities/merge_operators/string_append/stringappend2.cc \
|
|
|
|
utilities/merge_operators/string_append/stringappend.cc \
|
|
|
|
utilities/merge_operators/uint64add.cc \
|
|
|
|
utilities/redis/redis_lists.cc \
|
|
|
|
utilities/spatialdb/spatial_db.cc \
|
|
|
|
utilities/ttl/db_ttl_impl.cc \
|
|
|
|
utilities/write_batch_with_index/write_batch_with_index.cc \
|
|
|
|
utilities/write_batch_with_index/write_batch_with_index_internal.cc \
|
EventLogger
Summary:
Here's my proposal for making our LOGs easier to read by machines.
The idea is to dump all events as JSON objects. JSON is easy to read by humans, but more importantly, it's easy to read by machines. That way, we can parse this, load into SQLite/mongo and then query or visualize.
I started with table_create and table_delete events, but if everybody agrees, I'll continue by adding more events (flush/compaction/etc etc)
Test Plan:
Ran db_bench. Observed:
2015/01/15-14:13:25.788019 1105ef000 EVENT_LOG_v1 {"time_micros": 1421360005788015, "event": "table_file_creation", "file_number": 12, "file_size": 1909699}
2015/01/15-14:13:25.956500 110740000 EVENT_LOG_v1 {"time_micros": 1421360005956498, "event": "table_file_deletion", "file_number": 12}
Reviewers: yhchiang, rven, dhruba, MarkCallaghan, lgalanis, sdong
Reviewed By: sdong
Subscribers: dhruba, leveldb
Differential Revision: https://reviews.facebook.net/D31647
10 years ago
|
|
|
util/event_logger.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
util/ldb_cmd.cc \
|
|
|
|
util/ldb_tool.cc \
|
|
|
|
util/log_buffer.cc \
|
|
|
|
util/logging.cc \
|
|
|
|
util/memenv.cc \
|
|
|
|
util/murmurhash.cc \
|
|
|
|
util/mutable_cf_options.cc \
|
|
|
|
util/options_builder.cc \
|
|
|
|
util/options.cc \
|
|
|
|
util/options_helper.cc \
|
|
|
|
util/perf_context.cc \
|
|
|
|
util/rate_limiter.cc \
|
|
|
|
util/skiplistrep.cc \
|
|
|
|
util/slice.cc \
|
|
|
|
util/sst_dump_tool.cc \
|
|
|
|
util/statistics.cc \
|
|
|
|
util/status.cc \
|
|
|
|
util/string_util.cc \
|
|
|
|
util/sync_point.cc \
|
|
|
|
util/thread_local.cc \
|
|
|
|
util/thread_status_impl.cc \
|
|
|
|
util/thread_status_updater.cc \
|
|
|
|
util/thread_status_updater_debug.cc \
|
|
|
|
util/thread_status_util.cc \
|
|
|
|
util/thread_status_util_debug.cc \
|
|
|
|
util/vectorrep.cc \
|
|
|
|
util/xfunc.cc \
|
|
|
|
util/xxhash.cc \
|
|
|
|
|
|
|
|
MOCK_SOURCES = \
|
|
|
|
table/mock_table.cc \
|
|
|
|
util/mock_env.cc
|
|
|
|
|
|
|
|
TEST_BENCH_SOURCES = \
|
|
|
|
third-party/gtest-1.7.0/fused-src/gtest/gtest-all.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
db/column_family_test.cc \
|
|
|
|
db/compaction_job_test.cc \
|
|
|
|
db/compaction_picker_test.cc \
|
|
|
|
db/comparator_db_test.cc \
|
|
|
|
db/corruption_test.cc \
|
|
|
|
db/cuckoo_table_db_test.cc \
|
|
|
|
db/db_bench.cc \
|
|
|
|
db/dbformat_test.cc \
|
|
|
|
db/db_iter_test.cc \
|
|
|
|
db/db_test.cc \
|
|
|
|
db/deletefile_test.cc \
|
|
|
|
db/fault_injection_test.cc \
|
|
|
|
db/file_indexer_test.cc \
|
|
|
|
db/filename_test.cc \
|
|
|
|
db/flush_job_test.cc \
|
|
|
|
db/listener_test.cc \
|
|
|
|
db/log_and_apply_bench.cc \
|
|
|
|
db/log_test.cc \
|
|
|
|
db/memtablerep_bench.cc \
|
|
|
|
db/merge_test.cc \
|
|
|
|
db/perf_context_test.cc \
|
|
|
|
db/plain_table_db_test.cc \
|
|
|
|
db/prefix_test.cc \
|
|
|
|
db/skiplist_test.cc \
|
|
|
|
db/table_properties_collector_test.cc \
|
|
|
|
db/version_builder_test.cc \
|
|
|
|
db/version_edit_test.cc \
|
|
|
|
db/version_set_test.cc \
|
|
|
|
db/wal_manager_test.cc \
|
|
|
|
db/write_batch_test.cc \
|
|
|
|
db/write_controller_test.cc \
|
|
|
|
table/block_based_filter_block_test.cc \
|
|
|
|
table/block_hash_index_test.cc \
|
|
|
|
table/block_test.cc \
|
|
|
|
table/cuckoo_table_builder_test.cc \
|
|
|
|
table/cuckoo_table_reader_test.cc \
|
|
|
|
table/full_filter_block_test.cc \
|
|
|
|
table/merger_test.cc \
|
|
|
|
table/table_reader_bench.cc \
|
|
|
|
table/table_test.cc \
|
|
|
|
tools/db_sanity_test.cc \
|
|
|
|
tools/reduce_levels_test.cc \
|
|
|
|
util/arena_test.cc \
|
|
|
|
util/auto_roll_logger_test.cc \
|
|
|
|
util/autovector_test.cc \
|
|
|
|
util/benchharness.cc \
|
|
|
|
util/benchharness_test.cc \
|
|
|
|
util/bloom_test.cc \
|
|
|
|
util/cache_bench.cc \
|
|
|
|
util/cache_test.cc \
|
|
|
|
util/coding_test.cc \
|
|
|
|
util/crc32c_test.cc \
|
|
|
|
util/dynamic_bloom_test.cc \
|
|
|
|
util/env_test.cc \
|
|
|
|
util/filelock_test.cc \
|
|
|
|
util/histogram_test.cc \
|
|
|
|
utilities/backupable/backupable_db_test.cc \
|
|
|
|
utilities/document/document_db_test.cc \
|
|
|
|
utilities/document/json_document_test.cc \
|
|
|
|
utilities/geodb/geodb_test.cc \
|
|
|
|
utilities/merge_operators/string_append/stringappend_test.cc \
|
|
|
|
utilities/redis/redis_lists_test.cc \
|
|
|
|
utilities/spatialdb/spatial_db_test.cc \
|
|
|
|
utilities/ttl/ttl_test.cc \
|
|
|
|
utilities/write_batch_with_index/write_batch_with_index_test.cc \
|
|
|
|
util/log_write_bench.cc \
|
|
|
|
util/manual_compaction_test.cc \
|
|
|
|
util/memenv_test.cc \
|
|
|
|
util/mock_env_test.cc \
|
|
|
|
util/options_test.cc \
|
EventLogger
Summary:
Here's my proposal for making our LOGs easier to read by machines.
The idea is to dump all events as JSON objects. JSON is easy to read by humans, but more importantly, it's easy to read by machines. That way, we can parse this, load into SQLite/mongo and then query or visualize.
I started with table_create and table_delete events, but if everybody agrees, I'll continue by adding more events (flush/compaction/etc etc)
Test Plan:
Ran db_bench. Observed:
2015/01/15-14:13:25.788019 1105ef000 EVENT_LOG_v1 {"time_micros": 1421360005788015, "event": "table_file_creation", "file_number": 12, "file_size": 1909699}
2015/01/15-14:13:25.956500 110740000 EVENT_LOG_v1 {"time_micros": 1421360005956498, "event": "table_file_deletion", "file_number": 12}
Reviewers: yhchiang, rven, dhruba, MarkCallaghan, lgalanis, sdong
Reviewed By: sdong
Subscribers: dhruba, leveldb
Differential Revision: https://reviews.facebook.net/D31647
10 years ago
|
|
|
util/event_logger_test.cc \
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
util/rate_limiter_test.cc \
|
|
|
|
util/slice_transform_test.cc \
|
|
|
|
util/sst_dump_test.cc \
|
|
|
|
util/testharness.cc \
|
|
|
|
util/testutil.cc \
|
|
|
|
util/thread_list_test.cc \
|
|
|
|
util/thread_local_test.cc
|
|
|
|
|
|
|
|
JNI_NATIVE_SOURCES = \
|
|
|
|
java/rocksjni/backupablejni.cc \
|
|
|
|
java/rocksjni/checkpoint.cc \
|
|
|
|
java/rocksjni/columnfamilyhandle.cc \
|
|
|
|
java/rocksjni/comparator.cc \
|
|
|
|
java/rocksjni/comparatorjnicallback.cc \
|
|
|
|
java/rocksjni/env.cc \
|
|
|
|
java/rocksjni/filter.cc \
|
|
|
|
java/rocksjni/iterator.cc \
|
|
|
|
java/rocksjni/loggerjnicallback.cc \
|
|
|
|
java/rocksjni/memtablejni.cc \
|
|
|
|
java/rocksjni/merge_operator.cc \
|
|
|
|
java/rocksjni/options.cc \
|
|
|
|
java/rocksjni/ratelimiterjni.cc \
|
|
|
|
java/rocksjni/restorejni.cc \
|
|
|
|
java/rocksjni/rocksjni.cc \
|
|
|
|
java/rocksjni/slice.cc \
|
|
|
|
java/rocksjni/snapshot.cc \
|
|
|
|
java/rocksjni/statistics.cc \
|
|
|
|
java/rocksjni/table.cc \
|
|
|
|
java/rocksjni/transaction_log.cc \
|
|
|
|
java/rocksjni/ttl.cc \
|
|
|
|
java/rocksjni/write_batch.cc \
|
|
|
|
java/rocksjni/writebatchhandlerjnicallback.cc \
|
|
|
|
java/rocksjni/write_batch_test.cc \
|
|
|
|
java/rocksjni/write_batch_with_index.cc
|
|
|
|
|
build: fix missing dependency problems
Summary:
Any time one would modify a dependent of any *test*.cc file,
"make" would fail to rebuild the affected test binaries,
e.g., db_test. That was due to the fact that we deliberately
excluded those test-related files from the definition of SOURCES
and only $(SOURCES) was used to create the automatically-generated
.d dependency files. The fix is to generate a .d file for every
source file.
* src.mk: New file. Defines LIB_SOURCES, MOCK_SOURCES
and TEST_BENCH_SOURCES.
* Makefile: Include src.mk.
Reflect s/SOURCES/LIB_SOURCES/ renaming.
* build_tools/build_detect_platform: Remove the code
that was used to generate SOURCES= and MOCK_SOURCES=
definitions in make_config.mk. Those lists of files
are now hard-coded in src.mk. Hard-coding this list of
sources is desirable, because without that, one risks
including stray .cc files in a build. Not reproducible.
Test Plan:
Touch a file used by db_test's dependent .o files and ensure that
they are all recompiled. Before, none would be:
$ touch db/db_impl.h && make db_test
CC db/db_test.o
CC db/column_family.o
CC db/db_filesnapshot.o
CC db/db_impl.o
CC db/db_impl_debug.o
CC db/db_impl_readonly.o
CC db/forward_iterator.o
CC db/internal_stats.o
CC db/managed_iterator.o
CC db/repair.o
CC db/write_batch.o
CC utilities/compacted_db/compacted_db_impl.o
CC utilities/ttl/db_ttl_impl.o
CC util/ldb_cmd.o
CC util/ldb_tool.o
CC util/sst_dump_tool.o
CC util/xfunc.o
CCLD db_test
Reviewers: ljin, igor.sugak, igor, rven, sdong
Reviewed By: sdong
Subscribers: yhchiang, adamretter, fyrz, dhruba
Differential Revision: https://reviews.facebook.net/D33849
10 years ago
|
|
|
# Currently, we do not generate dependencies for
|
|
|
|
# java/rocksjni/write_batch_test.cc, because its dependent,
|
|
|
|
# java/include/org_rocksdb_WriteBatch.h is generated.
|
|
|
|
# TODO/FIXME: fix the above. Otherwise, the current rules would fail:
|
|
|
|
# java/rocksjni/write_batch_test.cc:13:44: fatal error: include/org_rocksdb_WriteBatch.h: No such file or directory
|
|
|
|
# #include "include/org_rocksdb_WriteBatch.h"
|
|
|
|
|
|
|
|
# These are the xfunc tests run :
|
|
|
|
XFUNC_TESTS = \
|
|
|
|
"managed_new" \
|
|
|
|
"managed_xftest_dropold" \
|
|
|
|
"managed_xftest_release" \
|
|
|
|
"inplace_lock_test"
|