Skip to content

Commit

Permalink
fix: Retry in POST method
Browse files Browse the repository at this point in the history
  • Loading branch information
kar0t committed Dec 10, 2024
1 parent 55c3bdc commit 7e6ea27
Showing 1 changed file with 36 additions and 11 deletions.
47 changes: 36 additions & 11 deletions lib/trino/client/statement_client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -66,20 +66,45 @@ def init_request(req)

def post_query_request!
uri = "/v1/statement"
response = @faraday.post do |req|
req.url uri

req.body = @query
init_request(req)
end
start = Process.clock_gettime(Process::CLOCK_MONOTONIC)
attempts = 0

# TODO error handling
if response.status != 200
exception! TrinoHttpError.new(response.status, "Failed to start query: #{response.body} (#{response.status})")
end
loop do
begin
response = @faraday.post do |req|
req.url uri

@results_headers = response.headers
@results = decode_model(uri, parse_body(response), @models::QueryResults)
req.body = @query
init_request(req)
end
rescue Faraday::TimeoutError, Faraday::ConnectionFailed
# temporally error to retry
response = nil
rescue => e
exception! e
end

if response
if response.status == 200 && !response.body.to_s.empty?
@results_headers = response.headers
@results = decode_model(uri, parse_body(response), @models::QueryResults)
return
end
# retry if 502, 503, 504 according to the trino protocol
unless [502, 503, 504].include?(response.status)
# deterministic error
exception! TrinoHttpError.new(response.status, "Trino API error at #{uri} returned #{response.status}: #{response.body}")
end
end

raise_if_timeout!

attempts += 1
sleep attempts * 0.1

break unless (Process.clock_gettime(Process::CLOCK_MONOTONIC) - start) < @retry_timeout && !client_aborted?
end
end

private :post_query_request!
Expand Down

0 comments on commit 7e6ea27

Please sign in to comment.