erigon-pulse/eth/ethconfig/estimate/esitmated_ram.go
2022-10-18 15:38:14 +07:00

28 lines
1.1 KiB
Go

package estimate
import (
"runtime"
"github.com/c2h5oh/datasize"
"github.com/ledgerwatch/erigon-lib/common/cmp"
"github.com/pbnjay/memory"
)
type estimatedRamPerWorker datasize.ByteSize
// Workers - return max workers amount based on total Memory/CPU's and estimated RAM per worker
func (r estimatedRamPerWorker) Workers() int {
// 80% of TotalMemory. Better don't count on 100% because OOM Killer may have aggressive defaults and other software may need RAM
totalMemory := memory.TotalMemory() / 5 * 4
maxWorkersForGivenMemory := totalMemory / uint64(r)
maxWorkersForGivenCPU := runtime.NumCPU() - 1 // reserve 1 cpu for "work-producer thread", also IO software on machine in cloud-providers using 1 CPU
return cmp.InRange(1, maxWorkersForGivenCPU, int(maxWorkersForGivenMemory))
}
const (
IndexSnapshot = estimatedRamPerWorker(2 * datasize.GB) //elias-fano index building is single-threaded
CompressSnapshot = estimatedRamPerWorker(1 * datasize.GB) //1-file-compression is multi-threaded
ReconstituteState = estimatedRamPerWorker(4 * datasize.GB) //state-reconstitution is multi-threaded
)