-
Notifications
You must be signed in to change notification settings - Fork 601
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
pubsub: app with default settings eventually runs out of memory (but does not crash) #2810
Comments
@jadekler sorry you're running into this problem. This is actually a duplicate of googleapis/nodejs-pubsub#13 and should be resolved by googleapis/nodejs-pubsub#92 if you'd like to test out that fork. I'm going to close this, but please feel free to subscribe the issue/PR mentioned about and thanks for reporting! |
Hi @callmehiphop. This issue seems to be better, but not resolved. Here is the graph with latest numbers; note that it still runs out of memory and the consumption rate (although better) is still a trickle. By trickle, I mean 0-100 or so acks per minute, whereas our C# client libraries are doing around 100k per minute (Go does around 12k per minute, for a more middle-of-the-road number). |
@jadekler are you applying any flow control limits to this test? If you have a ton of pending messages and aren't capping the number of messages to be in process then you will definitely run out of memory pretty quickly. const subscription = topic.subscription('my-sub', {
flowControl: {maxMessages: 50}
}); When we investigated as to why PubSub was using so much memory, we found that writing to the server was sometimes slow and if we did not apply an upper bound to the number of messages we processed we would run out of memory because of all the pending ack/modack requests. Ideally we would solve this by decreasing our write times, but I'm not sure how we would go about that? @murgatroid99 are we able to configure how server requests are buffered within a gRPC duplex stream? |
@callmehiphop That makes sense to me. Is there currently no flowControl.maxMessages default? I would imagine the flow to be, we'll set it to x where x is a number that works for 99% of environments, and if you want it faster you can set it higher; as opposed to, we'll have it unbounded and it will OOM any environment given enough pending messages. |
@jadekler by default maxMessages is set to Infinity. However I agree that we would be better off setting it lower and letting the user set higher if need be. Although I'm not certain what a reasonable default would be. |
@callmehiphop Right on. In Go we use 1000 as our max outstanding messages limit. In python I think it's 100? Perhaps something in that range? |
@callmehiphop In 0.18.0, I get segfaults: Also, could this issue be re-opened please? |
@jadekler is this happening with the code provided in the overview? |
@callmehiphop The code is pasted above. I snagged it from an example of ours somewhere. |
@callmehiphop can you please validate Jean's code as a Node expert? If we can repro, this is likely P0. Please let us know. Thanks! |
@danoscarmike absolutely. I had been testing on GCE and not seen this issue, it wasn't until later I realized this is happening in GKE. I think we still have gRPC 1.9.x pinned, so I want to see if upgrading to 1.10.x resolves this issue. |
Awesome, thank you! Would be great if the upgrade solves it. |
@callmehiphop Just noticed how much this issue has drifted since the original. Let me know if you'd like me to close this and open a new issue with accurate details + repro steps of the current issue. |
@jadekler this should be fine, but thanks for offering! |
@jadekler I've just cut a patch release for the google-gax package that should allow PubSub to pick up the latest gRPC version. On the off chance upgrading resolves this issue, would you mind giving this another go before I do a deep dive into the issue? |
@callmehiphop Sure thing! Node noob - will npm installing |
That is perfect! Thanks!
…On Sun, Apr 8, 2018, 10:42 AM Jean de Klerk ***@***.***> wrote:
@callmehiphop <https://github.com/callmehiphop> Sure thing! Node noob -
will npm installing ***@***.***/pubsub": "^0.18.0", be fine or do I
need a higher version?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#2810 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/ABoNA9Kj2brP4DXWfL7JFuW31aRaoc0kks5tmUDVgaJpZM4SvB92>
.
|
@callmehiphop I'm not seeing anything coming up, but I'll let it run over the weekend and check it out monday for weirdnesses. |
Excellent, thank you so much!
On Apr 8, 2018 11:00 AM, "Jean de Klerk" <[email protected]> wrote:
@callmehiphop <https://github.com/callmehiphop> I'm not seeing anything
coming up, but I'll let it run over the weekend and check it out monday for
weirdnesses.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#2810 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/ABoNA-t-p8VsSdDrj7b_rwFdEdusFWMSks5tmUUjgaJpZM4SvB92>
.
|
@callmehiphop Happy to report that I saw no problems over the weekend, and that the node pubsub library chugged through 67M messages at a rate of 61,000 acks / minute. |
@jadekler hooray! Thank you for all your help, I definitely would not have resolved this issue as quickly without it. |
No prob! |
Environment details
@google-cloud/[email protected]
Steps to reproduce
Run the following on GKE, pump 30 million messages into pubsub:
Once the app runs out of memory (1.5GB), reception slows from ~20k/min to something like 200/min:
(removing the timeout, it still runs out of memory)
Let me know if I'm missing something silly here.
The text was updated successfully, but these errors were encountered: