Skip to content

Commit

Permalink
enable connection reuse in libcurl
Browse files Browse the repository at this point in the history
Originally, in the `HttpClient::perform()` method, a new `CurlHandle` was created
upon every invocation, leading to subsequent calls to `curl_easy_init()` and
`curl_easy_cleanup()`, as the variable went in and out of scope while it executed
on the `asio::thread_pool`. This meant that there was no opportunity to reuse
connections from the underlying connection pool, because it was always cleaned up.

By marking the `CurlHandle` with the `thread_local` storage duration, it ensures
that the same one remains in use for each thread, thus providing the means to
reuse the established connection pool.

Fixes #51.
  • Loading branch information
copperlight committed Oct 19, 2023
1 parent 79a2713 commit a74f366
Showing 1 changed file with 1 addition and 1 deletion.
2 changes: 1 addition & 1 deletion spectator/http_client.cc
Original file line number Diff line number Diff line change
Expand Up @@ -199,7 +199,7 @@ auto HttpClient::perform(const char* method, const std::string& url,
int attempt_number) const -> HttpResponse {
LogEntry entry{registry_, method, url};

CurlHandle curl;
thread_local CurlHandle curl;
auto total_timeout = config_.connect_timeout + config_.read_timeout;
curl.set_timeout(total_timeout);
curl.set_connect_timeout(config_.connect_timeout);
Expand Down

0 comments on commit a74f366

Please sign in to comment.