Network problems, memory, network size #986

Closed
opened 2017-03-26 11:22:19 +02:00 by wrapperband · 16 comments
wrapperband commented 2017-03-26 11:22:19 +02:00 (Migrated from github.com)

I've been having some problems with PC slowing down / stalling (last week), these were fixed by closing BitMessage. There were a lot of big messages waiting to download 135), but setting the allowed transfer rate down seemed to fix it. Bitmessage had suddenly seemed to hog all my Internet bandwidth.

Today that got worse and I ended up taking up 13.6 GB of (32GB) ram. So i have made the issue.

It looks like there is a problem, with large files combined with some sort of DDoS on the network. Can do further checking / information, if you wish to investigate.

I've been having some problems with PC slowing down / stalling (last week), these were fixed by closing BitMessage. There were a lot of big messages waiting to download 135), but setting the allowed transfer rate down seemed to fix it. Bitmessage had suddenly seemed to hog all my Internet bandwidth. Today that got worse and I ended up taking up 13.6 GB of (32GB) ram. So i have made the issue. It looks like there is a problem, with large files combined with some sort of DDoS on the network. Can do further checking / information, if you wish to investigate.
PeterSurda commented 2017-03-26 12:06:07 +02:00 (Migrated from github.com)

Thank you for the report, this is a known issue and there are several tickets open already about it (#964 #870). There are multiple factors causing this (that I know of). You can try the v0.6, there have been some changes that may make it easier for you (it has less memory and CPU usage).

You don't write if you're accepting incoming connections, if yes, then edit keys.dat and add a new variable, maxtotalconnections and set it to maybe 50 or even 30. You may also reduce the bandwidth in network settings, because incoming connections will hog all your bandwidth.

Thank you for the report, this is a known issue and there are several tickets open already about it (#964 #870). There are multiple factors causing this (that I know of). You can try the v0.6, there have been some changes that may make it easier for you (it has less memory and CPU usage). You don't write if you're accepting incoming connections, if yes, then edit keys.dat and add a new variable, maxtotalconnections and set it to maybe 50 or even 30. You may also reduce the bandwidth in network settings, because incoming connections will hog all your bandwidth.
wrapperband commented 2017-03-26 12:14:22 +02:00 (Migrated from github.com)

Thanks Peter, I'll try the keys.dat and check out the other reports I missed .. I've checked and I was on (latest?) 0.6.2 is 0.6.3 "out" soon?..

Just FYI :
The number of connections is 142.
I didn't seem to be able to edit the max difficulty down from 5.0 to 4.0. to test if that helped.
It is taking a long, long time to disconnect, The keys.dat was in ~/.config/pybitmessage in Kubuntu.

Thanks Peter, I'll try the keys.dat and check out the other reports I missed .. I've checked and I was on (latest?) 0.6.2 is 0.6.3 "out" soon?.. Just FYI : The number of connections is 142. I didn't seem to be able to edit the max difficulty down from 5.0 to 4.0. to test if that helped. It is taking a long, long time to disconnect, The keys.dat was in ~/.config/pybitmessage in Kubuntu.
wrapperband commented 2017-03-26 14:37:16 +02:00 (Migrated from github.com)

FYI : after adding maxtotalconnections = 25 to [bitmessagesettings] in keys.dat
(Shame I can't cut and paste the error text along the bottom information panel and had to type this)

Failed to build C PoW module. Please build manually.

FYI : after adding maxtotalconnections = 25 to [bitmessagesettings] in keys.dat (Shame I can't cut and paste the error text along the bottom information panel and had to type this) Failed to build C PoW module. Please build manually.
PeterSurda commented 2017-03-26 18:16:52 +02:00 (Migrated from github.com)

I didn't seem to be able to edit the max difficulty down from 5.0 to 4.0. to test if that helped.

I think max difficulty must be at least 1000, but that's for creating PoW.

It is taking a long, long time to disconnect

This is also a related issue, similarly as with the memory hog should be fixed with the new network subsystem.

Failed to build C PoW module. Please build manually.

This means you're missing g++ and/or openssl headers. On Kubuntu, execute as root

apt-get install build-essential libssl-dev

> I didn't seem to be able to edit the max difficulty down from 5.0 to 4.0. to test if that helped. I think max difficulty must be at least 1000, but that's for creating PoW. > It is taking a long, long time to disconnect This is also a related issue, similarly as with the memory hog should be fixed with the new network subsystem. > Failed to build C PoW module. Please build manually. This means you're missing g++ and/or openssl headers. On Kubuntu, execute as root `apt-get install build-essential libssl-dev`
PeterSurda commented 2017-05-29 15:54:50 +02:00 (Migrated from github.com)

Please try the latest code (v0.6 branch) and let me know if you're seeing and improvement. It should be able to handle hundreds of connections on a normal computer now.

Please try the latest code (v0.6 branch) and let me know if you're seeing and improvement. It should be able to handle hundreds of connections on a normal computer now.
wrapperband commented 2017-05-29 16:19:57 +02:00 (Migrated from github.com)

Thanks Peter, my BM 0.6.2 currently has 3 GB memory and still slow to close down.
As soon as it closes ... I will update BM and note here if there is any obvious change / improvement.

Thanks again.

Closed down, git pull, git checkout 0.6.2 (already on 0.6.2) -- started up : testing ...

Thanks Peter, my BM 0.6.2 currently has 3 GB memory and still slow to close down. As soon as it closes ... I will update BM and note *here* if there is any obvious change / improvement. Thanks again. Closed down, git pull, git checkout 0.6.2 (already on 0.6.2) -- started up : testing ...
PeterSurda commented 2017-05-29 16:45:34 +02:00 (Migrated from github.com)

Well on my workstation I now have 44 connections and PyBM uses 561MB RAM. I had up to 75 connections earlier, it needed a little bit more memory but still under 1GB.

Well on my workstation I now have 44 connections and PyBM uses 561MB RAM. I had up to 75 connections earlier, it needed a little bit more memory but still under 1GB.
wrapperband commented 2017-05-29 17:53:49 +02:00 (Migrated from github.com)

Well, it (new 0.6.2 version) seem to be working with less memory and the shut down took seconds not minutes. I'll keep an eye on it, after it's had longer hours to build up transfers.

Thanks again.

Well, it (new 0.6.2 version) seem to be working with less memory and the shut down took seconds not minutes. I'll keep an eye on it, after it's had longer hours to build up transfers. Thanks again.
wrapperband commented 2017-05-30 10:49:01 +02:00 (Migrated from github.com)

Just checking next day. Everything tests better, thanks for the update.
Closed down : few seconds.
Memory running at 220 MB.

Just checking next day. Everything tests better, thanks for the update. Closed down : few seconds. Memory running at 220 MB.
PeterSurda commented 2017-05-30 13:39:58 +02:00 (Migrated from github.com)

Earlier today I got 100 connections on linux with about 680MB RAM.

Earlier today I got 100 connections on linux with about 680MB RAM.
Suraquis commented 2018-07-08 14:00:36 +02:00 (Migrated from github.com)

Same here, network bandwidth consuming looks excessive. I add my stats for this issue, lest create a new one.

Version: 0.6.3.2-529559d (latest I could get via 'git pull')

OS: Ubuntu 16.04.4 64-bit

Bandwidth usage (Up/Down): 697Mb/1124Mb after 7 hours of being online.

Network speed limits: (Up/Down): 48/96 kB/s

Some keys.dat parameters:
maxoutboundconnections = 8

Default ports (TCP/UDP 8444) are open, incoming connections accepted. At the moment of writing this, 16 incoming and 5 outgoing connections to other BM nodes exist.

I would appreciate developers' efforts to prevent bandwidth hogging, or at least providing instructions on how to see detailed stats (which data type consumes how much bandwidth). Thanks.

Same here, network bandwidth consuming looks excessive. I add my stats for this issue, lest create a new one. Version: 0.6.3.2-529559d (latest I could get via 'git pull') OS: Ubuntu 16.04.4 64-bit Bandwidth usage (Up/Down): 697Mb/1124Mb after 7 hours of being online. Network speed limits: (Up/Down): 48/96 kB/s Some keys.dat parameters: maxoutboundconnections = 8 Default ports (TCP/UDP 8444) are open, incoming connections accepted. At the moment of writing this, 16 incoming and 5 outgoing connections to other BM nodes exist. I would appreciate developers' efforts to prevent bandwidth hogging, or at least providing instructions on how to see detailed stats (which data type consumes how much bandwidth). Thanks.
wrapperband commented 2018-07-08 14:14:51 +02:00 (Migrated from github.com)

That was an "attack" on the network that was fixed over a year ago. Have you tried upgrading, my version is 0.6.3.2 and there is settings / network settings where you can also set a max bandwidth to allocate to bitmessage.

(I'm not a dev)

That was an "attack" on the network that was fixed over a year ago. Have you tried upgrading, my version is 0.6.3.2 and there is settings / network settings where you can also set a max bandwidth to allocate to bitmessage. (I'm not a dev)
Suraquis commented 2018-07-09 03:49:05 +02:00 (Migrated from github.com)

@wrapperband In fact, I am using the latest pullable version (I mentioned its exact ID), so if something was fixed, it's either a regression, or a new bug.

Also, I have set bandwidth limit (please read my comment), but even with it the bandwidth usage is quite unrealistic, unless clients are requesting public keys thousand times in a row, without actual necessity.

@wrapperband In fact, I am using the latest pullable version (I mentioned its exact ID), so if something was fixed, it's either a regression, or a new bug. Also, I **have** set bandwidth limit (please read my comment), but even with it the bandwidth usage is quite unrealistic, unless clients are requesting public keys thousand times in a row, without actual necessity.
PeterSurda commented 2018-07-09 05:32:28 +02:00 (Migrated from github.com)

If you're accepting incoming connections, the current protocol design will cause a lot of bandwidth consumption. There may be some bugs that exacerbate bandwith usage but mainly it's the inv exchange that happens right after the protocol handshake that's consuming bandwidth. There isn't much that can be done in short term.

If you're accepting incoming connections, the current protocol design will cause a lot of bandwidth consumption. There may be some bugs that exacerbate bandwith usage but mainly it's the inv exchange that happens right after the protocol handshake that's consuming bandwidth. There isn't much that can be done in short term.
Suraquis commented 2018-07-10 09:37:08 +02:00 (Migrated from github.com)

@PeterSurda I see. Perhaps this should be explicitly said in FAQ/wherever, otherwise there will be more users complaining at high bandwidth usage.

In any case, I would still suggest creating a stats feature that could show the percentage of different traffic type (AFAIK, that doesn't compromise anyone's security).

Thanks.

@PeterSurda I see. Perhaps this should be explicitly said in FAQ/wherever, otherwise there will be more users complaining at high bandwidth usage. In any case, I would still suggest creating a stats feature that could show the percentage of different traffic type (AFAIK, that doesn't compromise anyone's security). Thanks.
PeterSurda commented 2020-09-24 10:00:41 +02:00 (Migrated from github.com)

This is for practical purposes fixed, there are no more known urgent issues in the current code. There is still some performance penalty due to slicing write / read buffers, and the protocol overhead that requires to send all invs. This will be addressed separately.

This is for practical purposes fixed, there are no more known urgent issues in the current code. There is still some performance penalty due to slicing write / read buffers, and the protocol overhead that requires to send all invs. This will be addressed separately.
This repo is archived. You cannot comment on issues.
No Milestone
No project
No Assignees
1 Participants
Due Date
The due date is invalid or out of range. Please use the format 'yyyy-mm-dd'.

No due date set.

Dependencies

No dependencies set.

Reference: Bitmessage/PyBitmessage-2024-12-24#986
No description provided.