rocksdb/include/rocksdb/utilities
Sergei Glushchenko 39c6c5fc1b Expose DB methods to lock and unlock the WAL (#5146)
Summary:
Expose DB methods to lock and unlock the WAL.

These methods are intended to use by MyRocks in order to obtain WAL
coordinates in consistent way.

Usage scenario is following:

MySQL has performance_schema.log_status which provides information that
enables a backup tool to copy the required log files without locking for
the duration of copy. To populate this table MySQL does following:

1. Lock the binary log. Transactions are not allowed to commit now
2. Save the binary log coordinates
3. Walk through the storage engines and lock writes on each engine. For
   InnoDB, redo log is locked. For MyRocks, WAL should be locked.
4. Ask storage engines for their coordinates. InnoDB reports its current
   LSN and checkpoint LSN. MyRocks should report active WAL files names
   and sizes.
5. Release storage engine's locks
6. Unlock binary log

Backup tool will then use this information to copy InnoDB, RocksDB and
MySQL binary logs up to specified positions to end up with consistent DB
state after restore.

Currently, RocksDB allows to obtain the list of WAL files. Only missing
bit is the method to lock the writes to WAL files.

LockWAL method must flush the WAL in order for the reported size to be
accurate (GetSortedWALFiles is using file system stat call to return the
file size), also, since backup tool is going to copy the WAL, it is
better to be flushed.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/5146

Differential Revision: D14815447

Pulled By: maysamyabandeh

fbshipit-source-id: eec9535a6025229ed471119f19fe7b3d8ae888a3
2019-04-06 06:40:36 -07:00
..
lua Remove Lua compaction filter from RocksDB main repo (#4971) 2019-02-13 12:42:44 -08:00
backupable_db.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
checkpoint.h Change RocksDB License 2017-07-15 16:11:23 -07:00
convenience.h Change RocksDB License 2017-07-15 16:11:23 -07:00
db_ttl.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
debug.h GetAllKeyVersions() to take an extra argument of max_num_ikeys. (#4271) 2018-08-16 15:57:08 -07:00
env_librados.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
env_mirror.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
info_log_finder.h Change RocksDB License 2017-07-15 16:11:23 -07:00
ldb_cmd_execute_result.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
ldb_cmd.h ldb command parsing: allow option values to contain equals signs (#5088) 2019-03-25 13:23:11 -07:00
leveldb_options.h Change RocksDB License 2017-07-15 16:11:23 -07:00
memory_util.h Change RocksDB License 2017-07-15 16:11:23 -07:00
object_registry.h Update all unique/shared_ptr instances to be qualified with namespace std (#4638) 2018-11-09 11:19:58 -08:00
optimistic_transaction_db.h Make Optimistic Tx database stackable 2018-04-03 15:28:40 -07:00
option_change_migration.h Change RocksDB License 2017-07-15 16:11:23 -07:00
options_util.h Option string/map can set merge operator from object registry (#5123) 2019-03-28 14:54:29 -07:00
sim_cache.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
stackable_db.h Expose DB methods to lock and unlock the WAL (#5146) 2019-04-06 06:40:36 -07:00
table_properties_collectors.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
transaction_db_mutex.h Change RocksDB License 2017-07-15 16:11:23 -07:00
transaction_db.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
transaction.h Fix Windows broken build error due to non-const override (#4798) 2018-12-19 13:29:51 -08:00
utility_db.h Run automatic formatter against public header files (#5115) 2019-03-27 13:24:25 -07:00
write_batch_with_index.h Revert "BaseDeltaIterator: always check valid() before accessing key(… (#4744) 2018-12-03 23:38:27 -08:00