如何规避错误 pq_flush: could not send data to client: Broken pipe found
Posted
技术标签:
【中文标题】如何规避错误 pq_flush: could not send data to client: Broken pipe found【英文标题】:How to circumvent error pq_flush: could not send data to client: Broken pipe found 【发布时间】:2021-02-11 22:24:09 【问题描述】:我正在尝试使用看起来像这样的 Lambda 函数创建一个异步进程:
Lambda 1 在我的 redshift 集群上触发查询并结束 Lambda 2 轮询集群以获取查询状态,并根据结果结束/成功我使用了几种不同的选项,但它们似乎都在某一时刻失败了。我可以创建一个查询并触发它,并让 lambda 结束,但是当查询完成执行而不是成功时,它会抱怨客户端连接不再存在
error pq_flush: could not send data to client: Broken pipe found in xyz
问题是这完全符合我的用例。我不希望客户端(Lambda 1)等待,因为我的查询可能需要一个小时才能运行(夸大但可能),这就是我创建第二个 lambda 的原因。有没有办法可以将它传达给 Redshift/postgresql 并规避这个问题?
这是我的触发代码(最终会转到 lambda,但我正在本地机器上进行测试)
import select
import psycopg2
def wait(conn):
while True:
state = conn.poll()
if state == psycopg2.extensions.POLL_OK:
break
elif state == psycopg2.extensions.POLL_WRITE:
select.select([], [conn.fileno()], [])
elif state == psycopg2.extensions.POLL_READ:
select.select([conn.fileno()], [], [])
else:
raise psycopg2.OperationalError("poll() returned %s" % state)
conn = psycopg2.connect(
user='someuser',
dbname='somedb',
host='myredshiftcluster',
port=5432,
password='somepassword',
async_=1,
sslmode="require"
)
wait(conn)
acurs = conn.cursor()
acurs.execute('call public.test_sp(\'xyz\')')
【问题讨论】:
【参考方案1】:ODBC 和 JDBC 连接是同步的,因此构建异步进程将无法正常工作。幸运的是,AWS 最近宣布了 Redshift Data API,它是一个异步 REST 接口。因此,您可以通过该方法执行您正在寻找的内容。
见:https://docs.aws.amazon.com/redshift/latest/mgmt/data-api.html
【讨论】:
你是救生员。这非常适合我的需要。非常感谢。 很高兴听到这个消息。以上是关于如何规避错误 pq_flush: could not send data to client: Broken pipe found的主要内容,如果未能解决你的问题,请参考以下文章