Skip to content

Commit 1b720aa

Browse files
ronagBridgeAR
authored andcommitted
http: free listeners on free sockets
Reduced memory usage by ensuring free sockets don't have extra listeners while in the pool. PR-URL: #29259 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Matteo Collina <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Rich Trott <[email protected]> Reviewed-By: Ruben Bridgewater <[email protected]>
1 parent 892e7b0 commit 1b720aa

File tree

2 files changed

+17
-3
lines changed

2 files changed

+17
-3
lines changed

lib/_http_client.js

+2
Original file line numberDiff line numberDiff line change
@@ -618,6 +618,8 @@ function responseKeepAlive(req) {
618618
}
619619
socket.removeListener('close', socketCloseListener);
620620
socket.removeListener('error', socketErrorListener);
621+
socket.removeListener('data', socketOnData);
622+
socket.removeListener('end', socketOnEnd);
621623
socket.once('error', freeSocketErrorListener);
622624
// There are cases where _handle === null. Avoid those. Passing null to
623625
// nextTick() will call getDefaultTriggerAsyncId() to retrieve the id.

test/parallel/test-http-agent-keepalive.js

+15-3
Original file line numberDiff line numberDiff line change
@@ -140,9 +140,21 @@ server.listen(0, common.mustCall(() => {
140140

141141
// Check for listener leaks when reusing sockets.
142142
function checkListeners(socket) {
143-
assert.strictEqual(socket.listenerCount('data'), 1);
144-
assert.strictEqual(socket.listenerCount('drain'), 1);
143+
const callback = common.mustCall(() => {
144+
if (!socket.destroyed) {
145+
assert.strictEqual(socket.listenerCount('data'), 0);
146+
assert.strictEqual(socket.listenerCount('drain'), 0);
147+
// Sockets have freeSocketErrorListener.
148+
assert.strictEqual(socket.listenerCount('error'), 1);
149+
// Sockets have onReadableStreamEnd.
150+
assert.strictEqual(socket.listenerCount('end'), 1);
151+
}
152+
153+
socket.off('free', callback);
154+
socket.off('close', callback);
155+
});
145156
assert.strictEqual(socket.listenerCount('error'), 1);
146-
// Sockets have onReadableStreamEnd.
147157
assert.strictEqual(socket.listenerCount('end'), 2);
158+
socket.once('free', callback);
159+
socket.once('close', callback);
148160
}

0 commit comments

Comments
 (0)