aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPéter Szilágyi <peterke@gmail.com>2018-06-04 22:40:51 +0800
committerGitHub <noreply@github.com>2018-06-04 22:40:51 +0800
commited40767355b5f3964d134ae37d0eaf78d7083bc1 (patch)
treed3f9c30196b0a4d4bb0d4f9c624dfb286867b250
parentb659718fd0aa19c6b5977eb22cd58449bbb824a0 (diff)
parenta20cc75b4a2982917db83370cadd40e26d1b35b6 (diff)
downloadgo-tangerine-ed40767355b5f3964d134ae37d0eaf78d7083bc1.tar
go-tangerine-ed40767355b5f3964d134ae37d0eaf78d7083bc1.tar.gz
go-tangerine-ed40767355b5f3964d134ae37d0eaf78d7083bc1.tar.bz2
go-tangerine-ed40767355b5f3964d134ae37d0eaf78d7083bc1.tar.lz
go-tangerine-ed40767355b5f3964d134ae37d0eaf78d7083bc1.tar.xz
go-tangerine-ed40767355b5f3964d134ae37d0eaf78d7083bc1.tar.zst
go-tangerine-ed40767355b5f3964d134ae37d0eaf78d7083bc1.zip
Merge pull request #16800 from rjl493456442/memory_allowance_warining
cmd: cap cache size if exceeds reasonable range
-rw-r--r--cmd/geth/main.go20
1 files changed, 20 insertions, 0 deletions
diff --git a/cmd/geth/main.go b/cmd/geth/main.go
index 09d9c493d..edf2a557a 100644
--- a/cmd/geth/main.go
+++ b/cmd/geth/main.go
@@ -19,12 +19,16 @@ package main
import (
"fmt"
+ "math"
"os"
"runtime"
+ godebug "runtime/debug"
"sort"
+ "strconv"
"strings"
"time"
+ "github.com/elastic/gosigar"
"github.com/ethereum/go-ethereum/accounts"
"github.com/ethereum/go-ethereum/accounts/keystore"
"github.com/ethereum/go-ethereum/cmd/utils"
@@ -188,6 +192,22 @@ func init() {
if err := debug.Setup(ctx); err != nil {
return err
}
+ // Cap the cache allowance and tune the garbage colelctor
+ var mem gosigar.Mem
+ if err := mem.Get(); err == nil {
+ allowance := int(mem.Total / 1024 / 1024 / 3)
+ if cache := ctx.GlobalInt(utils.CacheFlag.Name); cache > allowance {
+ log.Warn("Sanitizing cache to Go's GC limits", "provided", cache, "updated", allowance)
+ ctx.GlobalSet(utils.CacheFlag.Name, strconv.Itoa(allowance))
+ }
+ }
+ // Ensure Go's GC ignores the database cache for trigger percentage
+ cache := ctx.GlobalInt(utils.CacheFlag.Name)
+ gogc := math.Max(20, math.Min(100, 100/(float64(cache)/1024)))
+
+ log.Debug("Sanitizing Go's GC trigger", "percent", int(gogc))
+ godebug.SetGCPercent(int(gogc))
+
// Start system runtime metrics collection
go metrics.CollectProcessMetrics(3 * time.Second)