Opened 5 years ago
Closed 5 years ago
#1751 closed defect (fixed)
nginx memory leak in ngx_event_openssl.c with patch
Reported by: | Nikolay Morozov | Owned by: | |
---|---|---|---|
Priority: | major | Milestone: | |
Component: | nginx-core | Version: | 1.14.x |
Keywords: | Cc: | ||
uname -a: | Linux nmorozov 4.15.0-46-generic #49-Ubuntu SMP Wed Feb 6 09:33:07 UTC 2019 | ||
nginx -V: | nginx version: nginx/1.14.2 |
Description
on some error cases X509 certificate is leaking. I have attached the patch to correct this
Attachments (1)
Change History (8)
by , 5 years ago
Attachment: | nginx_leak_for_upstream.diff added |
---|
comment:1 by , 5 years ago
comment:2 by , 5 years ago
Could you please clarify - are you seeing these leaks in practice, or you've found this by reading the code? It looks like these errors shouldn't happen in practice, as both X509_get_issuer_name()
and X509_get_subject_name()
will always return valid pointers.
comment:3 by , 5 years ago
In searching the memory leaks in production. There is a patched nginx with many external modules. I just found them analyzing code.
comment:4 by , 5 years ago
Both X509_get_issuer_name() and X509_get_subject_name() will always return valid pointers only if client certificate is ok, but there can be a defective certificate.
I wiil use mercurial to submit changes
comment:5 by , 5 years ago
Both X509_get_issuer_name() and X509_get_subject_name() will always return valid pointers only if client certificate is ok, but there can be a defective certificate.
Sure, but these fields are mandatory, and handshake is expected to fail if such a defective certificate is provided by the client. As such, I suspect the issue is purely theoretical, and cannot lead to real memory leaks. (It needs to be fixed anyway, of course, but the question is about possible impact.)
comment:6 by , 5 years ago
ok, I have alreday submited the chanes to ngix-devel maillist with hg email
comment:7 by , 5 years ago
Owner: | set to |
---|---|
Resolution: | → fixed |
Status: | new → closed |
The patch looks good.
Please take a look at http://nginx.org/en/docs/contributing_changes.html.
It'd be best if you could use Mercurial to submit patches.