-
Notifications
You must be signed in to change notification settings - Fork 30.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Crash in wrap_js_stream.js during doClose #27258
Comments
How easy is this to reproduce for you? Can you modify the Node.js source code? It might be helpful to add an assertion in |
Putting a modified Node.js compilation on the server and waiting to reproduce was something we raised as an option but were hopping to for it to be plan B.
But if you're saying that compiling is the way then I'll get working on that. |
Ok, I've got a modified node running and got new stacktrace:
So TLSWrap._parent points to Socket._handle that shows how the invalid call is possible, but this doesn't reproduce to a million other tls sockets used by the app. Sounds like a race condition of some sorts, but it's beyond my code understanding to figure it out. Edit: increased Error.stackTraceLimit and got full stack
|
We've been able to narrow the crash down to HTTP2 client sockets by correlating http2 usage and crash frequency. Will appreciate if someone can take a look at the stacktraces I provided and/or give more debugging instructions. |
looks like difference between good and bad case is the former is handling cc @nodejs/streams |
Since upgrading to Node 10 from Node 8 we've been seeing the following stack appear. I'm having trouble tracking down what's causing it - but could it be related to this issue? {
"date": "Thu Feb 06 2020 12:05:47 GMT+1100 (Australian Eastern Daylight Time)",
"process": {
"pid": 339,
"uid": 496,
"gid": 494,
"cwd": "/var/app/current",
"execPath": "/node-install/node-v10.18.1-linux-x64/bin/node",
"version": "v10.18.1",
"argv": [
"/node-install/node-v10.18.1-linux-x64/bin/node",
"/var/app/current/packages/app/lib/server.js"
],
"memoryUsage": {
"rss": 217214976,
"heapTotal": 111587328,
"heapUsed": 85340080,
"external": 62857751
}
},
"os": {
"loadavg": [
0,
0,
0
],
"uptime": 89121
},
"trace": [
{
"column": 23,
"file": "_tls_wrap.js",
"function": "TLSWrap.close",
"line": 395,
"method": "close",
"native": false
},
{
"column": 18,
"file": "net.js",
"function": "TLSSocket.Socket._destroy",
"line": 605,
"method": "_destroy",
"native": false
},
{
"column": 8,
"file": "internal/streams/destroy.js",
"function": "TLSSocket.destroy",
"line": 37,
"method": "destroy",
"native": false
},
{
"column": 20,
"file": "events.js",
"function": "Object.onceWrapper",
"line": 286,
"method": "onceWrapper",
"native": false
},
{
"column": 13,
"file": "events.js",
"function": "TLSSocket.emit",
"line": 198,
"method": "emit",
"native": false
},
{
"column": 23,
"file": "domain.js",
"function": "TLSSocket.EventEmitter.emit",
"line": 466,
"method": "emit",
"native": false
},
{
"column": 14,
"file": "_stream_writable.js",
"function": "finishMaybe",
"line": 646,
"method": null,
"native": false
},
{
"column": 5,
"file": "_stream_writable.js",
"function": "ShutdownWrap.stream._final [as callback]",
"line": 624,
"method": "_final [as callback]",
"native": false
},
{
"column": 8,
"file": "net.js",
"function": "ShutdownWrap.afterShutdown [as oncomplete]",
"line": 374,
"method": "afterShutdown [as oncomplete]",
"native": false
}
],
"stack": [
"TypeError: this._parent.close is not a function",
" at TLSWrap.close (_tls_wrap.js:395:23)",
" at TLSSocket.Socket._destroy (net.js:605:18)",
" at TLSSocket.destroy (internal/streams/destroy.js:37:8)",
" at Object.onceWrapper (events.js:286:20)",
" at TLSSocket.emit (events.js:198:13)",
" at TLSSocket.EventEmitter.emit (domain.js:466:23)",
" at finishMaybe (_stream_writable.js:646:14)",
" at ShutdownWrap.stream._final [as callback] (_stream_writable.js:624:5)",
" at ShutdownWrap.afterShutdown [as oncomplete] (net.js:374:8)"
],
"level": "error",
"message": "uncaughtException: this._parent.close is not a function"
} |
@omgaz have you been able to reproduce this reliably? could you post a script to reproduce? |
Not yet, it's proving taxing tracking down what could potentially be trying to end this connection. I'll update when/if I can repro the script. |
I've also been seeing a lot of this, with HTTP/2 traffic on both node v10.15.1 and v12.8.3, but I've just been testing v14.6.0 and it doesn't seem to reproduce at all there. |
I haven't been able to create an isolated example for this, but believe I'm getting this when using custom certificate authorities. |
I've debated whether this belongs in node/help, but due to potential of being a node bug I've decided to post here (apologize in advance if it turns out otherwise).
We have a crash happening on our production servers a few times a day (especially during high load times):
I was unable to see any possible code path that could cause
this._handle
to be null before the call todoClose
as it's only triggered by callingthis._handle.close()
.Async paths printing would have come very useful here, however, this is node 10.x.
I've done grep on all our code as well as all node-modules for anything that could relate to 'games' with
"_handle = "
ordoClose
, nothing pop'ed up.I've put DEBUG_NODE=net,stream_wrap on one of the servers to avoid overall network degradation (waiting for crash to re-occur).
Note: server is a large traffic networking proxy application involving http/s/2.
I would like to give more info (specifically
setImmediate
async callstack), however, I'm unsure how to continue, would appreciate any advice.The text was updated successfully, but these errors were encountered: