CVE-2021-29509

HIGH

Puma < 4.3.8 - Denial of Service via Keep-Alive Connection Starvation

Title source: llm
STIX 2.1

Description

Puma is a concurrent HTTP 1.1 server for Ruby/Rack applications. The fix for CVE-2019-16770 was incomplete. The original fix only protected existing connections that had already been accepted from having their requests starved by greedy persistent-connections saturating all threads in the same process. However, new connections may still be starved by greedy persistent-connections saturating all threads in all processes in the cluster. A `puma` server which received more concurrent `keep-alive` connections than the server had threads in its threadpool would service only a subset of connections, denying service to the unserved connections. This problem has been fixed in `puma` 4.3.8 and 5.3.1. Setting `queue_requests false` also fixes the issue. This is not advised when using `puma` without a reverse proxy, such as `nginx` or `apache`, because you will open yourself to slow client attacks (e.g. slowloris). The fix is very small and a git patch is available for those using unsupported versions of Puma.

References (6)

Core 6
Core References
Patch, Third Party Advisory x_refsource_confirm
https://github.com/puma/puma/security/advisories/GHSA-q28m-8xjw-8vr5
Patch, Third Party Advisory x_refsource_misc
https://gist.github.com/nateberkopec/4b3ea5676c0d70cbb37c82d54be25837
Third Party Advisory x_refsource_misc
https://github.com/puma/puma/security/policy
Product, Third Party Advisory x_refsource_misc
https://rubygems.org/gems/puma
Third Party Advisory vendor-advisory x_refsource_gentoo
https://security.gentoo.org/glsa/202208-28
Mailing List, Third Party Advisory mailing-list x_refsource_mlist
https://lists.debian.org/debian-lts-announce/2022/08/msg00015.html

Scores

CVSS v3 7.5
EPSS 0.0136
EPSS Percentile 80.4%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H

Details

CWE
CWE-667 CWE-400
Status published
Products (3)
debian/debian_linux 10.0
puma/puma < 4.3.8
rubygems/puma 0 - 4.3.8RubyGems
Published May 11, 2021
Tracked Since Feb 18, 2026