mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-14 10:22:10 +00:00
a25dd1d348
Server settings: - max_local_read_bandwidth_for_server - max_local_write_bandwidth_for_server Query settings: - max_local_read_bandwidth - max_local_write_bandwidth This is the preparation for adding ability to throttle BACKUPs Signed-off-by: Azat Khuzhin <a.khuzhin@semrush.com>
135 lines
4.1 KiB
C++
135 lines
4.1 KiB
C++
#pragma once
|
|
|
|
#include <cstddef>
|
|
#include <string>
|
|
#include <Core/Defines.h>
|
|
#include <Interpreters/Cache/FileCache_fwd.h>
|
|
#include <Common/Throttler_fwd.h>
|
|
#include <IO/ResourceLink.h>
|
|
|
|
namespace DB
|
|
{
|
|
enum class LocalFSReadMethod
|
|
{
|
|
/**
|
|
* Simple synchronous reads with 'read'.
|
|
* Can use direct IO after specified size.
|
|
* Can use prefetch by asking OS to perform readahead.
|
|
*/
|
|
read,
|
|
|
|
/**
|
|
* Simple synchronous reads with 'pread'.
|
|
* In contrast to 'read', shares single file descriptor from multiple threads.
|
|
* Can use direct IO after specified size.
|
|
* Can use prefetch by asking OS to perform readahead.
|
|
*/
|
|
pread,
|
|
|
|
/**
|
|
* Use mmap after specified size or simple synchronous reads with 'pread'.
|
|
* Can use prefetch by asking OS to perform readahead.
|
|
*/
|
|
mmap,
|
|
|
|
/**
|
|
* Use the io_uring Linux subsystem for asynchronous reads.
|
|
* Can use direct IO after specified size.
|
|
* Can do prefetch with double buffering.
|
|
*/
|
|
io_uring,
|
|
|
|
/**
|
|
* Checks if data is in page cache with 'preadv2' on modern Linux kernels.
|
|
* If data is in page cache, read from the same thread.
|
|
* If not, offload IO to separate threadpool.
|
|
* Can do prefetch with double buffering.
|
|
* Can use specified priorities and limit the number of concurrent reads.
|
|
*/
|
|
pread_threadpool,
|
|
|
|
/// Use asynchronous reader with fake backend that in fact synchronous.
|
|
/// @attention Use only for testing purposes.
|
|
pread_fake_async
|
|
};
|
|
|
|
enum class RemoteFSReadMethod
|
|
{
|
|
read,
|
|
threadpool,
|
|
};
|
|
|
|
class MMappedFileCache;
|
|
|
|
struct ReadSettings
|
|
{
|
|
/// Method to use reading from local filesystem.
|
|
LocalFSReadMethod local_fs_method = LocalFSReadMethod::pread;
|
|
/// Method to use reading from remote filesystem.
|
|
RemoteFSReadMethod remote_fs_method = RemoteFSReadMethod::threadpool;
|
|
|
|
size_t local_fs_buffer_size = DBMS_DEFAULT_BUFFER_SIZE;
|
|
size_t remote_fs_buffer_size = DBMS_DEFAULT_BUFFER_SIZE;
|
|
|
|
bool local_fs_prefetch = false;
|
|
bool remote_fs_prefetch = false;
|
|
|
|
/// For 'read', 'pread' and 'pread_threadpool' methods.
|
|
size_t direct_io_threshold = 0;
|
|
|
|
/// For 'mmap' method.
|
|
size_t mmap_threshold = 0;
|
|
MMappedFileCache * mmap_cache = nullptr;
|
|
|
|
/// For 'pread_threadpool'/'io_uring' method. Lower is more priority.
|
|
size_t priority = 0;
|
|
|
|
bool load_marks_asynchronously = true;
|
|
|
|
size_t remote_fs_read_max_backoff_ms = 10000;
|
|
size_t remote_fs_read_backoff_max_tries = 4;
|
|
|
|
bool enable_filesystem_read_prefetches_log = false;
|
|
|
|
bool enable_filesystem_cache = true;
|
|
bool read_from_filesystem_cache_if_exists_otherwise_bypass_cache = false;
|
|
bool enable_filesystem_cache_log = false;
|
|
bool is_file_cache_persistent = false; /// Some files can be made non-evictable.
|
|
/// Some buffers which read via thread pool can also do caching in threadpool
|
|
/// (instead of caching the result outside of threadpool). By default, if they support it,
|
|
/// they will do it. But this behaviour can be changed with this setting.
|
|
bool enable_filesystem_cache_on_lower_level = true;
|
|
|
|
size_t filesystem_cache_max_download_size = (128UL * 1024 * 1024 * 1024);
|
|
bool skip_download_if_exceeds_query_cache = true;
|
|
|
|
size_t remote_read_min_bytes_for_seek = DBMS_DEFAULT_BUFFER_SIZE;
|
|
|
|
FileCachePtr remote_fs_cache;
|
|
|
|
/// Bandwidth throttler to use during reading
|
|
ThrottlerPtr remote_throttler;
|
|
ThrottlerPtr local_throttler;
|
|
|
|
// Resource to be used during reading
|
|
ResourceLink resource_link;
|
|
|
|
size_t http_max_tries = 1;
|
|
size_t http_retry_initial_backoff_ms = 100;
|
|
size_t http_retry_max_backoff_ms = 1600;
|
|
bool http_skip_not_found_url_for_globs = true;
|
|
|
|
/// Monitoring
|
|
bool for_object_storage = false; // to choose which profile events should be incremented
|
|
|
|
ReadSettings adjustBufferSize(size_t file_size) const
|
|
{
|
|
ReadSettings res = *this;
|
|
res.local_fs_buffer_size = std::min(file_size, local_fs_buffer_size);
|
|
res.remote_fs_buffer_size = std::min(file_size, remote_fs_buffer_size);
|
|
return res;
|
|
}
|
|
};
|
|
|
|
}
|