我想返回一个特定的错误响应(带有自定义消息的HTTP 503 )遇到数据库查询超时。
当发生超时时,抛出的异常如下所示:
** (DBConnection.ConnectionError) tcp recv: closed
(ecto) lib/ecto/adapters/postgres/connection.ex:86: Ecto.Adapters.Postgres.Connection.prepare_execute/5
(ecto) lib/ecto/adapters/sql.ex:243: Ecto.Adapters.SQL.sql_call/6
(ecto) lib/ecto/adapters/sql.ex:431: Ecto.Adapters.SQL.execute_and_cache/7
(ecto) lib/ecto/repo/queryable.ex:130: Ecto.Repo.Queryable.execute/5
(ecto) lib/ecto/repo/queryable.ex:35: Ecto.Repo.Queryable.all/4
(stdlib) timer.erl:166: :timer.tc/1我为Plug.Exception协议定义了一个实现,以便在异常消息为"tcp recv: closed"时将DBConnection.ConnectionError映射到状态503,这似乎是可行的。
defimpl Plug.Exception, for: DBConnection.ConnectionError do
def status(exception) do
if exception.message == "tcp recv: closed" do
503
else
500
end
end
end但是,我担心的是,对于我来说,DBConnection.ConnectionError异常和"tcp recv: closed"异常太过笼统,不能假定发生了DB超时。如果关闭的连接是由其他原因引起的,例如网络故障,该怎么办?
是否有更具体的方法来检测何时发生数据库查询超时?
发布于 2021-07-08 22:31:09
如果在发生数据库连接问题时检查DNS解析是否正常,以及网络连接是否正常,则可以使错误消息更加具体。
网络连接检查示例:
curl --head http://ipaddress/或
ping ipadress或
#!/bin/bash
echo -e "GET http://stackoverflow.com HTTP/1.0\n\n" | nc stackoverflow.com 80 > /dev/null 2>&1
if [ $? -eq 0 ]; then
echo "Online"
else
echo "Offline"
fihttps://stackoverflow.com/questions/46436016
复制相似问题