Author

Topic: Dedicated bitcoind node, 1gb ram ="errors" : "EXCEPTION: St9bad_alloc \nstd::bad (Read 2194 times)

kjj
legendary
Activity: 1302
Merit: 1026
I have a 32 bit box running with less than 1 GB of ram.  It has two instances of bitcoind running, one with 1 connection, and one with 60 (nearly or all incoming).

I think the real problem is running into some artificial limitation in lousy VPS software.
donator
Activity: 1731
Merit: 1008
Yes, bitcoind memory usage seems to grow fairly steadily at the moment.
I haven't seen that— a node with 8 connections appears pretty stable at about 300MB res, nodes with many in-bounds use about a gig— which is the roughly the same as it was 6 months ago.

Are you sure the people here aren't just running out of address space on 32 bit systems?
Maybe someone can report on memory usage for a node with 100+ nodes,

32bit ? I don't know, the OS is 64bit.
staff
Activity: 4284
Merit: 8808
Yes, bitcoind memory usage seems to grow fairly steadily at the moment.
I haven't seen that— a node with 8 connections appears pretty stable at about 300MB res, nodes with many in-bounds use about a gig— which is the roughly the same as it was 6 months ago.

Are you sure the people here aren't just running out of address space on 32 bit systems?
donator
Activity: 1731
Merit: 1008
I'm supprised by the ressource required.

Fixing this exessive ram usage could mean a lot more seeding node and much faster blockchain download.

One of the most expensive part of VPS is ram, (beside the 500gb+ in monthly upload I can live with)
full member
Activity: 144
Merit: 100
Memory usage is pretty stable for me when not downloading blocks, though it could be lower.  During initial block download, memory usage can grow without limit due to mapOrphanBlocks.  More details are in issue 2353.
legendary
Activity: 1526
Merit: 1134
Yes, bitcoind memory usage seems to grow fairly steadily at the moment. I spent some time with a heap profiler and it's not obviously a leak - possibly it's a side effect of the huge send/receive buffers in the code so the more peers you accumulate the more RAM is required.

I'm testing some optimizations by sipa to the networking code on my own VPS now. That one has a hard cap of 1gig of RAM, but that's way more than should really be needed. Bitcoin should work fine in just a few hundred megs, tops.
full member
Activity: 142
Merit: 100
I did get that myself just a couple of hours ago.

My bitcoind instance had turned itself off (or crashed - don't know), so I had to restart it.

1 536 Mb of ram.

Running bitcoind on the main net and on the testnet...

donator
Activity: 1731
Merit: 1008
Code:
{
    "version" : 80100,
...
    "blocks" : 227829,
    "connections" : 49,
 ...
    "errors" : "EXCEPTION: St9bad_alloc       \nstd::bad_alloc       \nbitcoin in ProcessMessages()       \n"
}
I've been told this meant it was low on memory.

This is a on dedicated bitcoind node on a ubuntu VPS with 1024mb and 2048 brustable ram.

I usually reach 950mb ram when at about 36 connections.

Since all I want it to do is seed the blockchain as much as it can, should I lower the connection number to 36 even if it sometime goes to 56 without any apparent issue other than that error message.

Jump to: