美文网首页
Linux-Signals信号 ,golang ,SIGUSR2

Linux-Signals信号 ,golang ,SIGUSR2

作者: 哆啦在这A梦在哪 | 来源:发表于2021-06-23 10:59 被阅读0次

    SIGHUP 1 Term 终端控制进程结束(终端连接断开)
    SIGINT 2 Term 用户发送INTR字符(Ctrl+C)触发
    SIGQUIT 3 Core 用户发送QUIT字符(Ctrl+/)触发
    SIGILL 4 Core 非法指令(程序错误、试图执行数据段、栈溢出等)
    SIGABRT 6 Core 调用abort函数触发
    SIGFPE 8 Core 算术运行错误(浮点运算错误、除数为零等)
    SIGKILL 9 Term 无条件结束程序(不能被捕获、阻塞或忽略)
    SIGSEGV 11 Core 无效内存引用(试图访问不属于自己的内存空间、对只读内存空间进行写操作)
    SIGPIPE 13 Term 消息管道损坏(FIFO/Socket通信时,管道未打开而进行写操作)
    SIGALRM 14 Term 时钟定时信号
    SIGTERM 15 Term 结束程序(可以被捕获、阻塞或忽略)
    SIGUSR1 30,10,16 Term 用户保留
    SIGUSR2 31,12,17 Term 用户保留
    SIGCHLD 20,17,18 Ign 子进程结束(由父进程接收)
    SIGCONT 19,18,25 Cont 继续执行已经停止的进程(不能被阻塞)
    SIGSTOP 17,19,23 Stop 停止进程(不能被捕获、阻塞或忽略)
    SIGTSTP 18,20,24 Stop 停止进程(可以被捕获、阻塞或忽略)
    SIGTTIN 21,21,26 Stop 后台程序从终端中读取数据时触发
    SIGTTOU 22,22,27 Stop 后台程序向终端中写数据时触发

    golang中的实际信号实际值在syscall包中查看

    比如:SIGUSR2的内容实用的是SIGUSR2 = Signal(0x1f),转化成十进制是31


    image.png

    实际golang信号使用

    func main() {
        ch := make(chan os.Signal, 1)
        signal.Notify(ch, syscall.SIGINT, syscall.SIGTERM, syscall.SIGUSR2)
        // ctx, _ := context.WithTimeout(context.Background(), 20*time.Second)
        for {
            sig := <-ch
            log.Printf("signal: %v", sig)
            // timeout context for shutdown
            switch sig {
            case syscall.SIGINT, syscall.SIGTERM:
                // stop
                log.Printf("stop")
                signal.Stop(ch)
                // server.Shutdown(ctx)
                log.Printf("server shutdown")
                return
            case syscall.SIGUSR2:
                log.Printf("reload")
                // err := reload()
                // if err != nil {
                //  log.Fatalf("graceful restart error: %v", err)
                // }
                // server.Shutdown(ctx)
                log.Printf("graceful reload")
                return
            }
        }
    }
    

    上述代码编译执行test.exe,使用ps输出pid进程号,如下,test的pid、为50422

    ps -ef|grep test  
      501 18210     1   0  8 621  ??         0:03.68 /Users/apple/Library/Application Support/ShadowsocksX-NG/ss-local-latest/ss-local -c ss-local-config.json --fast-open --reuse-port
      501 50422 50135   0 10:47上午 ttys000    0:00.07 ./test
      501 50424 46140   0 10:47上午 ttys004    0:00.00 grep --color=auto --exclude-dir=.bzr --exclude-dir=CVS --exclude-dir=.git --exclude-dir=.hg --exclude-dir=.svn --exclude-dir=.idea --exclude-dir=.tox test
    

    向test发送信号

    kill -SIGUSR2 50422
    或者
    kill -31 50422
    

    test退出并输出:
    2021/06/23 10:48:08 signal: user defined signal 2
    2021/06/23 10:48:08 reload
    2021/06/23 10:48:08 graceful reload

    相关文章

      网友评论

          本文标题:Linux-Signals信号 ,golang ,SIGUSR2

          本文链接:https://www.haomeiwen.com/subject/uvhosltx.html