Levi Tamasi
1e35584251
Move the index readers out of the block cache ( #5298 )
...
Summary:
Currently, when the block cache is used for index blocks as well, it is
not really the index block that is stored in the cache but an
IndexReader object. Since this object is not pure data (it has, for
instance, pointers that might dangle), it's not really sharable. To
avoid the issues around this, the current code uses a dummy unique cache
key for each TableReader to store the IndexReader, and erases the
IndexReader entry when the TableReader is closed. Instead of doing this,
the new code moves the IndexReader out of the cache altogether. In
particular, instead of the TableReader owning, or caching/pinning the
IndexReader based on the customer's settings, the TableReader
unconditionally owns the IndexReader, which in turn owns/caches/pins
the index block (which is itself sharable and thus can be safely put in
the cache without any hacks).
Note: the change has two side effects:
1) Partitions of partitioned indexes no longer affect the read
amplification statistics.
2) Eviction statistics for index blocks are temporarily broken. We plan to fix
this in a separate phase.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/5298
Differential Revision: D15303203
Pulled By: ltamasi
fbshipit-source-id: 935a69ba59d87d5e44f42e2310619b790c366e47
2019-05-30 11:53:27 -07:00
..
2019-05-30 11:25:51 -07:00
2019-04-10 19:31:18 -07:00
2019-04-25 11:25:43 -07:00
2019-05-13 17:47:21 -07:00
2019-05-30 11:25:51 -07:00
2019-05-29 20:47:06 -07:00
2019-05-24 12:07:15 -07:00
2019-05-30 11:25:51 -07:00
2018-10-08 22:54:43 -07:00
2018-12-07 17:06:02 -08:00
2017-08-19 14:10:08 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-03 17:30:22 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-23 16:57:46 -07:00
2019-05-22 23:40:57 -07:00
2019-04-16 23:32:20 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2018-05-29 15:44:34 -07:00
2019-05-30 11:25:51 -07:00
2019-05-28 12:24:38 -07:00
2019-05-30 11:25:51 -07:00
2019-05-24 12:24:28 -07:00
2019-05-30 11:25:51 -07:00
2018-11-09 11:19:58 -08:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2017-10-17 08:57:09 -07:00
2019-05-30 11:53:27 -07:00
2019-05-13 17:47:21 -07:00
2019-02-14 14:41:36 -08:00
2019-05-30 11:25:51 -07:00
2018-11-12 16:42:16 -08:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-04-16 23:32:20 -07:00
2018-08-03 17:42:34 -07:00
2019-05-29 20:47:06 -07:00
2019-05-30 11:25:51 -07:00
2019-02-28 10:27:59 -08:00
2019-03-27 16:24:45 -07:00
2019-05-24 15:32:03 -07:00
2019-05-24 15:32:03 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-24 13:09:55 -07:00
2019-05-29 20:47:06 -07:00
2017-07-15 16:11:23 -07:00
2017-07-15 16:11:23 -07:00
2018-10-29 14:36:31 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-29 20:47:06 -07:00
2019-05-23 16:11:38 -07:00
2019-05-09 14:20:04 -07:00
2019-02-14 14:41:36 -08:00
2019-05-15 11:21:48 -07:00
2019-04-02 14:47:16 -07:00
2019-05-30 11:25:51 -07:00
2019-02-15 09:51:41 -08:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:12:59 -07:00
2019-03-01 10:42:09 -08:00
2019-05-30 11:25:51 -07:00
2018-07-17 14:43:18 -07:00
2019-05-01 10:17:30 -07:00
2019-05-13 17:47:21 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-03-27 16:24:45 -07:00
2019-05-23 16:44:20 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-29 20:47:06 -07:00
2018-10-04 20:46:50 -07:00
2019-04-22 15:30:07 -07:00
2018-09-15 13:43:04 -07:00
2018-04-12 17:59:16 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-02-12 19:16:17 -08:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2017-07-15 16:11:23 -07:00
2017-07-15 16:11:23 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-03-19 17:28:19 -07:00
2017-07-15 16:11:23 -07:00
2019-05-13 17:47:21 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2018-03-05 13:13:41 -08:00
2019-05-24 11:40:05 -07:00
2019-05-24 11:40:05 -07:00
2019-04-18 10:55:01 -07:00
2019-03-19 17:28:19 -07:00
2019-01-15 21:34:38 -08:00
2019-05-30 11:25:51 -07:00
2018-08-24 18:13:20 -07:00
2019-03-26 16:45:31 -07:00
2019-04-24 12:08:44 -07:00
2019-05-30 11:25:51 -07:00
2019-05-21 12:33:17 -07:00
2019-04-25 10:11:41 -07:00
2018-05-03 15:43:09 -07:00
2018-05-03 15:43:09 -07:00
2019-04-11 14:28:26 -07:00
2019-01-03 16:30:12 -08:00
2017-07-15 16:11:23 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-29 20:47:06 -07:00
2019-04-17 10:15:05 -07:00
2019-02-19 12:15:39 -08:00
2019-04-11 14:28:26 -07:00
2019-05-30 11:25:51 -07:00
2019-02-28 10:27:59 -08:00
2018-12-17 17:33:46 -08:00
2017-07-15 16:11:23 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2017-07-15 16:11:23 -07:00
2019-05-30 11:25:51 -07:00
2019-04-02 15:17:47 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-04-18 12:27:25 -07:00
2019-05-16 15:24:28 -07:00
2019-05-30 11:25:51 -07:00
2019-04-16 11:37:47 -07:00
2018-12-17 13:20:51 -08:00
2019-04-12 14:40:41 -07:00
2019-05-29 20:47:06 -07:00
2019-05-29 20:47:06 -07:00
2019-01-16 09:55:32 -08:00
2017-07-15 16:11:23 -07:00
2019-05-03 17:30:22 -07:00
2019-05-30 11:25:51 -07:00
2019-05-24 14:26:43 -07:00
2019-05-30 11:25:51 -07:00
2019-03-18 12:15:34 -07:00
2019-03-18 12:15:34 -07:00
2019-03-27 12:27:54 -07:00
2019-05-29 20:47:06 -07:00
2019-05-30 11:25:51 -07:00
2019-03-26 16:45:31 -07:00
2019-03-26 16:45:31 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-03-26 16:45:31 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-22 09:21:56 -07:00
2019-05-30 11:25:51 -07:00
2019-05-30 11:25:51 -07:00
2019-05-24 10:40:30 -07:00
2017-07-15 16:11:23 -07:00
2018-06-28 18:58:29 -07:00
2019-05-30 11:25:51 -07:00
2019-05-13 17:47:21 -07:00
2019-05-30 11:25:51 -07:00
2017-07-15 16:11:23 -07:00
2019-05-30 11:25:51 -07:00
2017-07-15 16:11:23 -07:00
2017-07-15 16:11:23 -07:00
2019-05-30 11:25:51 -07:00
2019-01-03 12:40:42 -08:00