1 Star 0 Fork 75

lstarby/yomo

forked from YoMo/yomo 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
zipper_notwindows.go 1.10 KB
一键复制 编辑 原始数据 按行查看 历史
//go:build !windows
// +build !windows
package yomo
import (
"fmt"
"os"
"os/signal"
"runtime"
"syscall"
"github.com/yomorun/yomo/pkg/logger"
)
// initialize when zipper running as server. support inspection:
// - `kill -SIGUSR1 <pid>` inspect state()
// - `kill -SIGTERM <pid>` graceful shutdown
// - `kill -SIGUSR2 <pid>` inspect golang GC
func (z *zipper) init() {
go func() {
c := make(chan os.Signal, 1)
signal.Notify(c, syscall.SIGTERM, syscall.SIGUSR2, syscall.SIGUSR1, syscall.SIGINT)
logger.Printf("%sListening SIGUSR1, SIGUSR2, SIGTERM/SIGINT...", zipperLogPrefix)
for p1 := range c {
logger.Printf("Received signal: %s", p1)
if p1 == syscall.SIGTERM || p1 == syscall.SIGINT {
logger.Printf("graceful shutting down ... %s", p1)
// waiting for the server to finish processing the current request
z.Close()
os.Exit(0)
// close(sgnl)
} else if p1 == syscall.SIGUSR2 {
var m runtime.MemStats
runtime.ReadMemStats(&m)
fmt.Printf("\tNumGC = %v\n", m.NumGC)
} else if p1 == syscall.SIGUSR1 {
logger.Printf("print zipper stats(): %d", z.Stats())
}
}
}()
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/lstarby/yomo.git
git@gitee.com:lstarby/yomo.git
lstarby
yomo
yomo
master

搜索帮助