Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[kvbench] Question about KVBench configuartion options #55

Open
manojps opened this issue May 10, 2020 · 3 comments
Open

[kvbench] Question about KVBench configuartion options #55

manojps opened this issue May 10, 2020 · 3 comments

Comments

@manojps
Copy link

manojps commented May 10, 2020

  1. What is the difference between [kvs] write_mode and [operation] write_type?
  2. What are the supported options for [kvs] store_option, other than post?
  3. What is the difference between [threads] readers and reader_ops, or writer and writer_ops?
  4. What is the purpose of [population] pop_first?
  5. We have thread configuration options under multiple section in the config file - [kvs]aiothreads_per_device, [population] nthreads and an entire [threads] section. What are the differences between these?
  6. If we don't want I/Os to be cached for direct KV access, which options should I chenge in the bench_config.ini file and which values should be set? I have noticed mismatch between both KVS_ops.txt and smartctl logs in terms of I?o count and data read. However, such discrepancies doesn't exist when using sample codes provided in the repo for I/Os.
  7. Your documentation says "allocator = posix # 'posix' or 'numa' for block device; 'spdk' for KV SSD only". What should be allocator for KDD?
@hao86yan
Copy link
Collaborator

Pelease see the reply in line.

  1. What is the difference between [kvs] write_mode and [operation] write_type?
    "[kvs] write_mode" indicates which type of APIs will be invoked. KVS API has 2 types of API: aysnchronous APIs and synchronous APIs.
    "[operation] write_type" only works for RocksDB, not for KV SSD. It indicates the data is wrote to disk synchronously or firsly to memory and then to disk asynchronously.

  2. What are the supported options for [kvs] store_option, other than post?
    For KV SSD, only post is supported.

  3. What is the difference between [threads] readers and reader_ops, or writer and writer_ops?
    Readers and writers represent the number of threads for read and write operation
    reader_opts and writer_ops were not used so far.

  4. What is the purpose of [population] pop_first?
    pop_first indicates if it's is needed to pre-write data to SSD before test.

  5. We have thread configuration options under multiple section in the config file -
    [kvs]aiothreads_per_device is unused.
    [population] nthreads means the number of pre-write threads.
    [threads] means the number of test threads.

  6. If we don't want I/Os to be cached for direct KV access, which options should I chenge in the bench_config.ini file and which values should be set? I have noticed mismatch between both KVS_ops.txt and smartctl logs in terms of I?o count and data read. However, such discrepancies doesn't exist when using sample codes provided in the repo for I/Os. Your documentation says "allocator = posix # 'posix' or 'numa' for block device; 'spdk' for KV SSD only". What should be allocator for KDD?
    For KVAPI testing, there is no cache functionality in kvbench

@manojps
Copy link
Author

manojps commented May 21, 2020

  1. Only [kvs] with_iterator = alone with [population] seq_fill = false returns throughput for iterator. What is the difference between "with_iterator = alone" and "with_iterator = true"? And how should we interpret the throughput results of the benchmark with these two options?

  2. How to open multiple iterators using KVBench for KV direct access?

  3. How to set the bitmask and bit_pattern for iterators in KVBench for KV direct access?

  4. During insertion phase, we can control sequential inserts by modifying [population] seq_fill settings. Is there a way to do strictly sequential read, write and inserts during benchmark phase using KV direct access in KVBench, instead of using a KV store like RocksDB?

  5. When we're using KDD, should we set the [system] allocator = kdd?

  6. What's the difference between key_existing = true and = false?

  7. What does [kvs] mem_size_mb set?

@hao86yan
Copy link
Collaborator

For question 7,8, and 9, we removed the test support of iterator in kv_bench, because kv_bench is originally developed for RocksDB and aerospike, so it doesn't supported iterator well. If you want to test iterator, we recommend to use our sample code.

  1. During insertion phase, we can control sequential inserts by modifying [population] seq_fill settings. Is there a way to do strictly sequential read, write and inserts during benchmark phase using KV direct access in KVBench, instead of using a KV store like RocksDB?
    Please refer to the section 3 of the readme file in kvbench folder to compile kv_bench running on KV SSD directily. The configuration of seq_fill also takes effect in direct KV SSD access.

  2. When we're using KDD, should we set the [system] allocator = kdd?
    There is no need to setting the allocator to KDD when you use KDD.

  3. What's the difference between key_existing = true and = false?
    When key_existing is set to true, kv_bench guarantees the keys already existed in KV SSD when doing read, delete, and update operations.

  4. What does [kvs] mem_size_mb set?
    This configuration item has not been used.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants