aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJimmy Hu <jimmy.hu@dexon.org>2018-11-10 00:30:39 +0800
committerWei-Ning Huang <w@dexon.org>2019-03-12 12:19:09 +0800
commitc0bd41b4341f5d305067526f4783c54ae572f122 (patch)
tree0d4b2cb1a90b13a4ee1b4722f8a849266ccb40e0
parentf57bee543a52cbcb32664f371239dba61745cbb3 (diff)
downloaddexon-c0bd41b4341f5d305067526f4783c54ae572f122.tar
dexon-c0bd41b4341f5d305067526f4783c54ae572f122.tar.gz
dexon-c0bd41b4341f5d305067526f4783c54ae572f122.tar.bz2
dexon-c0bd41b4341f5d305067526f4783c54ae572f122.tar.lz
dexon-c0bd41b4341f5d305067526f4783c54ae572f122.tar.xz
dexon-c0bd41b4341f5d305067526f4783c54ae572f122.tar.zst
dexon-c0bd41b4341f5d305067526f4783c54ae572f122.zip
cmd: gdex: SIGUSR1 to dump stack (#6)
-rw-r--r--cmd/gdex/stack.go44
1 files changed, 44 insertions, 0 deletions
diff --git a/cmd/gdex/stack.go b/cmd/gdex/stack.go
new file mode 100644
index 000000000..7fc81d52b
--- /dev/null
+++ b/cmd/gdex/stack.go
@@ -0,0 +1,44 @@
+// Copyright 2018 The dexon-consensus Authors
+// This file is part of the dexon-consensus library.
+//
+// The dexon-consensus library is free software: you can redistribute it
+// and/or modify it under the terms of the GNU Lesser General Public License as
+// published by the Free Software Foundation, either version 3 of the License,
+// or (at your option) any later version.
+//
+// The dexon-consensus library is distributed in the hope that it will be
+// useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
+// General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public License
+// along with the dexon-consensus library. If not, see
+// <http://www.gnu.org/licenses/>.
+
+package main
+
+import (
+ "fmt"
+ "io/ioutil"
+ "os"
+ "os/signal"
+ "runtime"
+ "syscall"
+)
+
+func init() {
+ sigChan := make(chan os.Signal, 1)
+ signal.Notify(sigChan, syscall.SIGUSR1)
+ fmt.Printf("Listening on SIGUSR1\n")
+ go func() {
+ for range sigChan {
+ fmt.Printf("Receive SIGUSR1\n")
+ // Dump stack.
+ buf := make([]byte, 4*1024*1024)
+ buf = buf[:runtime.Stack(buf, true)]
+ if err := ioutil.WriteFile("stack.log", buf, 0644); err != nil {
+ fmt.Printf("Unable to dump stack trace: %s\n", err)
+ }
+ }
+ }()
+}