美文网首页
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

    SIGHUP 1 Term 终端控制进程结束(终端连接断开)SIGINT 2 Term 用...

  • 在线发信号

    在线发信号更改进程log级别 SIGUSR2 进程 PID kill -s SIGUS...

  • Easyswoole源码分析-6-reload

    1.知识点 1.主要看里面的SIGUSR1和SIGUSR2信号的作用2.向指定pid进程发送信号 2.代码分析

  • 【Golang】信号处理

    golang中对信号的处理主要使用os/signal包中的两个方法:一个是notify方法用来监听收到的信号;一个...

  • golang信号处理

    信号是IPC之一,下面是常用的信号列表 信号值动作说明SIGHUP1Term终端控制进程结束(终端连接断开)SIG...

  • Golang信号处理和优雅退出守护进程

    Golang中的信号处理 信号类型 在SUSv2和POSIX.1-2001标准中的信号列表: kill pid与k...

  • 实验室环境gdb调试

    打印单个线程的调用栈gdb attach tid handle SIGUSR2 nostop noprint se...

  • [iOS]转发异常信号

    背景:项目中有个SDK库(Golang),会抛出异常信号,第三方crash日志记录工具会分析这个信号而造成崩溃,我...

  • Golang信号signal的处理

    在实际项目中我们修改了配置文件后,希望在不重启进程的情况下重新加载配置文件,这时候就需要通过信号传递来进行处理了。...

  • go程

    golang里捕获进程信号实现优雅退出的方法 一、定时与 同步退出 二、锁 互斥锁Mutex Lock,UnLock

网友评论

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

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