You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository has been archived by the owner on Jan 16, 2024. It is now read-only.
Very common to allow the Aurora Serverless autoPause after some period of time. When this happens and Rails tries to connect, you will see an error like this pretty quickly.
Aws::RDSDataService::Errors::BadRequestException (Communications link failure)
The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
At one time I had code in place to handle this but removed it due to the issues from #8 for flaky tests because I assumed it was due to the Retriable (https://github.com/kamui/retriable) gem. It was not, so it is safe to add this back. Here is quick implementation I had that we can add back. I liked this method since it meant we only used retrys for the initial connect and not all the time for each execute statement.
defexecute_statement_retry(sql)if@connectedexecute_statement(sql)elseauto_paused_retry{execute_statement(sql)}endenddefexecute_statement(sql)raw_client.execute_statement({# ...}).tapdo |r|
@connected=true# ...endendprivatedefauto_paused_retryekls=Aws::RDSDataService::Errors::BadRequestExceptionemsg=/last packet sent successfully to the server was/rtry=Proc.new{Rails.logger.info'Aurora auto paused, retrying...'}optn={on: {ekls=>emsg},on_retry: rtry,tries: 10}Retriable.retriable(optn){yield}end
The text was updated successfully, but these errors were encountered:
Very common to allow the Aurora Serverless
autoPause
after some period of time. When this happens and Rails tries to connect, you will see an error like this pretty quickly.At one time I had code in place to handle this but removed it due to the issues from #8 for flaky tests because I assumed it was due to the Retriable (https://github.com/kamui/retriable) gem. It was not, so it is safe to add this back. Here is quick implementation I had that we can add back. I liked this method since it meant we only used retrys for the initial connect and not all the time for each execute statement.
The text was updated successfully, but these errors were encountered: