mirror of https://github.com/lukechilds/node.git
Browse Source
Ensure that AdjustAmountOfExternalAllocatedMemory() is called when the SecurePair is destroyed. Not doing so is not an actual memory leak but it makes `process.memoryUsage().external` wildly inaccurate and can cause performance problems due to excessive garbage collection. PR-URL: https://github.com/nodejs/node/pull/11896 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net>v7.x
Ben Noordhuis
8 years ago
committed by
Myles Borins
2 changed files with 30 additions and 5 deletions
@ -0,0 +1,29 @@ |
|||
// Flags: --expose-gc --no-deprecation
|
|||
'use strict'; |
|||
|
|||
const common = require('../common'); |
|||
const assert = require('assert'); |
|||
|
|||
if (!common.hasCrypto) { |
|||
common.skip('missing crypto'); |
|||
return; |
|||
} |
|||
|
|||
const { createSecureContext } = require('tls'); |
|||
const { createSecurePair } = require('_tls_legacy'); |
|||
|
|||
const before = process.memoryUsage().external; |
|||
{ |
|||
const context = createSecureContext(); |
|||
const options = {}; |
|||
for (let i = 0; i < 1e4; i += 1) |
|||
createSecurePair(context, false, false, false, options).destroy(); |
|||
} |
|||
global.gc(); |
|||
const after = process.memoryUsage().external; |
|||
|
|||
// It's not an exact science but a SecurePair grows .external by about 45 kB.
|
|||
// Unless AdjustAmountOfExternalAllocatedMemory() is called on destruction,
|
|||
// 10,000 instances make it grow by well over 400 MB. Allow for some slop
|
|||
// because objects like buffers also affect the external limit.
|
|||
assert(after - before < 25 << 20); |
Loading…
Reference in new issue