github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/internal/debug/trace.go (about) 1 2 //此源码被清华学神尹成大魔王专业翻译分析并修改 3 //尹成QQ77025077 4 //尹成微信18510341407 5 //尹成所在QQ群721929980 6 //尹成邮箱 yinc13@mails.tsinghua.edu.cn 7 //尹成毕业于清华大学,微软区块链领域全球最有价值专家 8 //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620 9 //版权所有2016 Go Ethereum作者 10 //此文件是Go以太坊库的一部分。 11 // 12 //Go-Ethereum库是免费软件:您可以重新分发它和/或修改 13 //根据GNU发布的较低通用公共许可证的条款 14 //自由软件基金会,或者许可证的第3版,或者 15 //(由您选择)任何更高版本。 16 // 17 //Go以太坊图书馆的发行目的是希望它会有用, 18 //但没有任何保证;甚至没有 19 //适销性或特定用途的适用性。见 20 //GNU较低的通用公共许可证,了解更多详细信息。 21 // 22 //你应该收到一份GNU较低级别的公共许可证副本 23 //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。 24 25 //+建立GO1.5 26 27 package debug 28 29 import ( 30 "errors" 31 "os" 32 "runtime/trace" 33 34 "github.com/ethereum/go-ethereum/log" 35 ) 36 37 //startgotrace打开跟踪,写入给定文件。 38 func (h *HandlerT) StartGoTrace(file string) error { 39 h.mu.Lock() 40 defer h.mu.Unlock() 41 if h.traceW != nil { 42 return errors.New("trace already in progress") 43 } 44 f, err := os.Create(expandHome(file)) 45 if err != nil { 46 return err 47 } 48 if err := trace.Start(f); err != nil { 49 f.Close() 50 return err 51 } 52 h.traceW = f 53 h.traceFile = file 54 log.Info("Go tracing started", "dump", h.traceFile) 55 return nil 56 } 57 58 //StopTrace停止正在进行的跟踪。 59 func (h *HandlerT) StopGoTrace() error { 60 h.mu.Lock() 61 defer h.mu.Unlock() 62 trace.Stop() 63 if h.traceW == nil { 64 return errors.New("trace not in progress") 65 } 66 log.Info("Done writing Go trace", "dump", h.traceFile) 67 h.traceW.Close() 68 h.traceW = nil 69 h.traceFile = "" 70 return nil 71 }