postgresql 连接超时_解决PostgreSQL 执行超时的情况

使用背景

最近在使用PostgreSQL的时候,在执行一些数据库事务的时候,先后出现了statement timetout 和idle-in-transaction timeout的问题,导致数据库操作失败。

经研究查找,PostgreSQL有关于SQL语句执行超时和事务执行超时的相关配置,而默认超时时间是10000毫秒,即10秒钟的时间,这样会导致执行时间稍长的任务执行失败。可以通过修改PostgreSQL服务器配置文件的方式修改默认配置。

参数说明

statement_timeout

statement_timeout 在 postgresql 被用来控制语句执行时长,单位是ms。

$ vi postgresql.conf

#statement_timeout = 0 # in milliseconds, 0 is disabled

默认是0,表示语句可以一直执行下去。

如果设置为10000,那就意味着语句最多可以执行 10000ms = 10s。

建议设置为0,禁用该参数。

idle_in_transaction_session_timeout

PostgreSQL 9.6版本开始支持自动查杀超过指定时间的 idle in transaction 空闲事务连接,用于清理应用代码中忘记关闭已开启的事务,或者系统中存在僵死进程等。

idle_in_transaction_session_timeout 在 postgresql 被用来控制事务执行时长,单位是ms。

$ vi postgresql.conf

#idle_in_transaction_session_timeout = 0 # in milliseconds, 0 is disabl

使用背景 最近在使用PostgreSQL的时候,在执行一些数据库事务的时候,先后出现了statement timetout 和idle-in-transaction timeout的问题,导致数据库操作失败。 经研究查找,PostgreSQL有关于SQL语句执行超时和事务执行超时的相关配置,而默认超时时间是10000毫秒,即10秒钟的时间,这样会导致执行时间稍长的任务执行失败。可以通过修改PostgreSQL服务器配置文件的方式修改默认配置。 参数说明 statement_timeout statement_timeout 在 postgresql 被用来控制语句执行时长,单位是ms。 $ vi postgresql.conf #statement_timeout = 0 # in milliseconds, 0 is disabled 默认是0,表示语句可以一直执行下去。 如果设置为10000,那就意味着语句最多可以执行 10000ms = 10s。 建议设置为0,禁用该参数。 idle_in_transaction_session_timeout PostgreSQL 9.6版本开始支持自动查杀超过指定时间的 idle in transaction 空闲事务连接,用于清理应用代码中忘记关闭已开启的事务,或者系统中存在僵死进程等。 idle_in_transaction_session_timeout 在 postgresql 被用来控制事务执行时长,单位是ms。 $ vi postgresql.conf #idle_in_transaction_session_timeout = 0 # in milliseconds, 0 is disabl
经验分享 程序员 微信小程序 职场和发展