mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-14 10:22:10 +00:00
Correct merge
This commit is contained in:
parent
fde6f0507d
commit
e3d2942aa6
@ -168,9 +168,7 @@ std::unique_ptr<ReadBufferFromFileBase> DiskWebServer::readFile(const String & p
|
|||||||
|
|
||||||
bool threadpool_read = read_settings.remote_fs_method == RemoteFSReadMethod::read_threadpool;
|
bool threadpool_read = read_settings.remote_fs_method == RemoteFSReadMethod::read_threadpool;
|
||||||
|
|
||||||
auto web_impl = std::make_unique<ReadBufferFromWebServerGather>(url, meta, getContext(),
|
auto web_impl = std::make_unique<ReadBufferFromWebServerGather>(url, meta, getContext(), threadpool_read, read_settings);
|
||||||
read_settings,
|
|
||||||
threadpool_read);
|
|
||||||
|
|
||||||
if (threadpool_read)
|
if (threadpool_read)
|
||||||
{
|
{
|
||||||
|
@ -36,7 +36,7 @@ SeekableReadBufferPtr ReadBufferFromS3Gather::createImplementationBuffer(const S
|
|||||||
|
|
||||||
SeekableReadBufferPtr ReadBufferFromWebServerGather::createImplementationBuffer(const String & path) const
|
SeekableReadBufferPtr ReadBufferFromWebServerGather::createImplementationBuffer(const String & path) const
|
||||||
{
|
{
|
||||||
return std::make_unique<ReadBufferFromWebServer>(fs::path(uri) / path, context, buf_size, backoff_threshold, max_tries, threadpool_read);
|
return std::make_unique<ReadBufferFromWebServer>(fs::path(uri) / path, context, settings, threadpool_read);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
|
|
||||||
#include <Disks/IDiskRemote.h>
|
#include <Disks/IDiskRemote.h>
|
||||||
#include <IO/ReadBufferFromFile.h>
|
#include <IO/ReadBufferFromFile.h>
|
||||||
|
#include <IO/ReadSettings.h>
|
||||||
|
|
||||||
namespace Aws
|
namespace Aws
|
||||||
{
|
{
|
||||||
@ -92,17 +93,13 @@ public:
|
|||||||
const String & uri_,
|
const String & uri_,
|
||||||
RemoteMetadata metadata_,
|
RemoteMetadata metadata_,
|
||||||
ContextPtr context_,
|
ContextPtr context_,
|
||||||
size_t buf_size_,
|
size_t threadpool_read_,
|
||||||
size_t backoff_threshold_,
|
const ReadSettings & settings_)
|
||||||
size_t max_tries_,
|
|
||||||
size_t threadpool_read_)
|
|
||||||
: ReadBufferFromRemoteFSGather(metadata_)
|
: ReadBufferFromRemoteFSGather(metadata_)
|
||||||
, uri(uri_)
|
, uri(uri_)
|
||||||
, context(context_)
|
, context(context_)
|
||||||
, buf_size(buf_size_)
|
|
||||||
, backoff_threshold(backoff_threshold_)
|
|
||||||
, max_tries(max_tries_)
|
|
||||||
, threadpool_read(threadpool_read_)
|
, threadpool_read(threadpool_read_)
|
||||||
|
, settings(settings_)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -111,10 +108,8 @@ public:
|
|||||||
private:
|
private:
|
||||||
String uri;
|
String uri;
|
||||||
ContextPtr context;
|
ContextPtr context;
|
||||||
size_t buf_size;
|
|
||||||
size_t backoff_threshold;
|
|
||||||
size_t max_tries;
|
|
||||||
bool threadpool_read;
|
bool threadpool_read;
|
||||||
|
ReadSettings settings;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,6 +20,8 @@ namespace ErrorCodes
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static constexpr size_t HTTP_MAX_TRIES = 10;
|
||||||
|
|
||||||
ReadBufferFromWebServer::ReadBufferFromWebServer(
|
ReadBufferFromWebServer::ReadBufferFromWebServer(
|
||||||
const String & url_, ContextPtr context_, const ReadSettings & settings_, bool use_external_buffer_)
|
const String & url_, ContextPtr context_, const ReadSettings & settings_, bool use_external_buffer_)
|
||||||
: SeekableReadBuffer(nullptr, 0)
|
: SeekableReadBuffer(nullptr, 0)
|
||||||
@ -92,9 +94,24 @@ bool ReadBufferFromWebServer::nextImpl()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
/// Initialize impl with retry.
|
||||||
|
auto num_tries = std::max(read_settings.http_max_tries, HTTP_MAX_TRIES);
|
||||||
|
for (size_t i = 0; i < num_tries; ++i)
|
||||||
|
{
|
||||||
|
try
|
||||||
{
|
{
|
||||||
impl = initialize();
|
impl = initialize();
|
||||||
}
|
}
|
||||||
|
catch (Poco::Exception &)
|
||||||
|
{
|
||||||
|
if (i == num_tries - 1)
|
||||||
|
throw;
|
||||||
|
|
||||||
|
tryLogCurrentException(__PRETTY_FUNCTION__);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
auto result = impl->next();
|
auto result = impl->next();
|
||||||
if (result)
|
if (result)
|
||||||
|
@ -41,9 +41,9 @@ private:
|
|||||||
|
|
||||||
off_t offset = 0;
|
off_t offset = 0;
|
||||||
|
|
||||||
bool use_external_buffer;
|
|
||||||
|
|
||||||
ReadSettings read_settings;
|
ReadSettings read_settings;
|
||||||
|
|
||||||
|
bool use_external_buffer;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -239,6 +239,16 @@ namespace detail
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
impl = std::make_unique<ReadBufferFromIStream>(*istr, buffer_size);
|
impl = std::make_unique<ReadBufferFromIStream>(*istr, buffer_size);
|
||||||
|
|
||||||
|
if (use_external_buffer)
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* See comment 30 lines lower.
|
||||||
|
*/
|
||||||
|
impl->set(internal_buffer.begin(), internal_buffer.size());
|
||||||
|
assert(working_buffer.begin() != nullptr);
|
||||||
|
assert(!internal_buffer.empty());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (const Poco::Exception & e)
|
catch (const Poco::Exception & e)
|
||||||
{
|
{
|
||||||
@ -255,6 +265,8 @@ namespace detail
|
|||||||
if (next_callback)
|
if (next_callback)
|
||||||
next_callback(count());
|
next_callback(count());
|
||||||
|
|
||||||
|
if (impl)
|
||||||
|
{
|
||||||
if (use_external_buffer)
|
if (use_external_buffer)
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
@ -278,6 +290,7 @@ namespace detail
|
|||||||
if (!working_buffer.empty())
|
if (!working_buffer.empty())
|
||||||
impl->position() = position();
|
impl->position() = position();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (total_bytes_to_read && bytes_read == total_bytes_to_read.value())
|
if (total_bytes_to_read && bytes_read == total_bytes_to_read.value())
|
||||||
return false;
|
return false;
|
||||||
|
Loading…
Reference in New Issue
Block a user