首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >菲尼克斯1.4:如何在多个请求中保持一个DBConnection?

菲尼克斯1.4:如何在多个请求中保持一个DBConnection?
EN

Stack Overflow用户
提问于 2019-11-12 21:44:30
回答 1查看 333关注 0票数 0

我有一个带有Elixir1.9的凤凰应用程序,一个带有PostgreSQL数据库的菲尼克斯1.4。这个应用程序充当一个API服务器。

它需要这样的特性:

假设它运行1000个并发进程,这些进程连接到数据库,数据库池大小为100。每个进程都需要运行5个不同的查询。

通常,在这样的设置中,1000个进程将共享池中的100个DBConnection,然后轮流运行查询,每个进程将运行1或2个查询,或几个查询,并将连接到另一个要运行的进程。进程一直共享池中的连接以运行查询,直到它们都完成了每个查询的所有5个查询。

问题:是否有任何配置或指令来强制每个进程完成所有5个查询,然后才能将连接返回到池共享?

EN

回答 1

Stack Overflow用户

发布于 2019-11-13 06:59:02

通常在这样的设置中,1000个进程将共享池中的100个DBConnection .

在2019年和百老汇之前是“正常”的。事实上,早在2016年和GenStage之前,百老汇就把应对反压力变成了一种魅力。现在,我们通常在消费者和潜在的瓶颈(DB )之间设置GenStage (低级)或Broadway (高级别)背压处理程序。与一群工人相比,这要强大得多。

强制每个进程在返回连接之前完成所有5个查询。

将查询包装在Ecto.Multi中。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58827156

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档