Skip to content
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

Memory leaks #67

Merged
2 commits merged into from
Oct 4, 2010
Merged

Memory leaks #67

2 commits merged into from
Oct 4, 2010

Conversation

3rd-Eden
Copy link
Contributor

@3rd-Eden 3rd-Eden commented Oct 4, 2010

Hi,

http://speedo.no.de/ has been plagued with memory leaks for a while now. I have been debugging this issue since the end of NKO. I finally found the issues. After a ECONNECTRESET error occurred each request started taking about 1 MB per connection o_O ( still no clue why ) anyways I was able to backtrace all errors and capture them using the error event. By closing the connections in every possible way I was able to close several leaks. Yes, they all leaked...

I have been running these patches for over a while now on 300 concurrent active streaming users and my memory usage has never been so low, normally I would been around 1 / 2 gig of memory, but now I run 250mb.
Awsomenesss.

While I was at it I also fixed a small bug that caught my attention.

The only issue that remains to be fixed is that some connected clients says queued up on the clientList as I'm still losing memory on that ( I know this because I log the length of the queue on each connection, and after a server reset the queue list is significantly smaller than the logged stats. ) Anyways that is another bug.

Gives us something to hunt after in future versions :)

… exception.

This small if statement solves it.
… will leak memory.

This caused http://speedo.no.de/ to go up from 1mb per connection after a ECONNECTRESET message
@rauchg
Copy link
Contributor

rauchg commented Oct 4, 2010

Thanks for the patch.
I moved the error handling around because it was potentially interfering with the main http server:

http://github.com/LearnBoost/Socket.IO-node/commit/999eba68dc647738d425666d777f47817627e474

@3rd-Eden
Copy link
Contributor Author

3rd-Eden commented Oct 4, 2010

I wonder if your edits will work. If I remember correctly I did attempt to fix it that way but some errors where still uncaught..

@rauchg
Copy link
Contributor

rauchg commented Oct 4, 2010

But then those leaks will be unrelated to socket.io :)

@3rd-Eden
Copy link
Contributor Author

3rd-Eden commented Oct 4, 2010

I would love that to be true, but the only thing running on my server is socket.io :p anways I spotted an error in your commit: http://github.com/LearnBoost/Socket.IO-node/commit/999eba68dc647738d425666d777f47817627e474#diff-2

You dont have a req and socket variable there

@rauchg
Copy link
Contributor

rauchg commented Oct 4, 2010

http://github.com/LearnBoost/Socket.IO-node/blob/999eba68dc647738d425666d777f47817627e474/lib/socket.io/transports/websocket.js#L13

Sure, not consistent with this.connection, but websocket.js will be cleaned up soon anyways.

@3rd-Eden
Copy link
Contributor Author

3rd-Eden commented Oct 4, 2010

Whoops, I totally missed that. And a clean up sounds great :)

@3rd-Eden
Copy link
Contributor Author

3rd-Eden commented Oct 4, 2010

@rauchg
Copy link
Contributor

rauchg commented Oct 4, 2010

I still see it there? Can you re-commit your suggestions?

@3rd-Eden
Copy link
Contributor Author

3rd-Eden commented Oct 4, 2010

Will re-commit a load patches tomorrow, found another issue a few min ago. And this time i will leave out the console.log's so its easier for you ;)

This pull request was closed.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants