2019-12-20 12:25:40 +00:00
|
|
|
package debug
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
2021-02-09 02:31:37 +00:00
|
|
|
"strconv"
|
2020-05-04 05:55:51 +00:00
|
|
|
"sync"
|
2021-02-09 02:31:37 +00:00
|
|
|
"time"
|
2019-12-20 12:25:40 +00:00
|
|
|
)
|
|
|
|
|
2021-02-09 02:31:37 +00:00
|
|
|
var (
|
|
|
|
bigRoTx uint
|
|
|
|
getBigRoTx sync.Once
|
|
|
|
)
|
|
|
|
|
|
|
|
// DEBUG_BIG_RO_TX_KB - print logs with info about large read-only transactions
|
|
|
|
// DEBUG_BIG_RW_TX_KB - print logs with info about large read-write transactions
|
|
|
|
// DEBUG_SLOW_COMMIT_MS - print logs with commit timing details if commit is slower than this threshold
|
|
|
|
func BigRoTxKb() uint {
|
|
|
|
getBigRoTx.Do(func() {
|
|
|
|
v, _ := os.LookupEnv("DEBUG_BIG_RO_TX_KB")
|
|
|
|
if v != "" {
|
|
|
|
i, err := strconv.Atoi(v)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
bigRoTx = uint(i)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
return bigRoTx
|
|
|
|
}
|
|
|
|
|
|
|
|
var (
|
|
|
|
bigRwTx uint
|
|
|
|
getBigRwTx sync.Once
|
|
|
|
)
|
|
|
|
|
|
|
|
func BigRwTxKb() uint {
|
|
|
|
getBigRwTx.Do(func() {
|
|
|
|
v, _ := os.LookupEnv("DEBUG_BIG_RW_TX_KB")
|
|
|
|
if v != "" {
|
|
|
|
i, err := strconv.Atoi(v)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
bigRwTx = uint(i)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
return bigRwTx
|
|
|
|
}
|
|
|
|
|
|
|
|
var (
|
|
|
|
slowCommit time.Duration
|
|
|
|
getSlowCommit sync.Once
|
|
|
|
)
|
|
|
|
|
|
|
|
func SlowCommit() time.Duration {
|
|
|
|
getSlowCommit.Do(func() {
|
|
|
|
v, _ := os.LookupEnv("DEBUG_SLOW_COMMIT_MS")
|
|
|
|
if v != "" {
|
|
|
|
i, err := strconv.Atoi(v)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
slowCommit = time.Duration(i) * time.Millisecond
|
|
|
|
}
|
|
|
|
})
|
|
|
|
return slowCommit
|
|
|
|
}
|
2021-06-07 11:01:54 +00:00
|
|
|
|
2021-06-19 09:01:33 +00:00
|
|
|
var (
|
|
|
|
stopBeforeStage string
|
|
|
|
stopBeforeStageFlag sync.Once
|
|
|
|
)
|
|
|
|
|
|
|
|
func StopBeforeStage() string {
|
|
|
|
f := func() {
|
|
|
|
v, _ := os.LookupEnv("STOP_BEFORE_STAGE") // see names in eth/stagedsync/stages/stages.go
|
|
|
|
if v != "" {
|
|
|
|
stopBeforeStage = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stopBeforeStageFlag.Do(f)
|
|
|
|
return stopBeforeStage
|
|
|
|
}
|