Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/three.js/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Go 如何设置SA_ONSTACK标志_Go_Ibm Mq - Fatal编程技术网

Go 如何设置SA_ONSTACK标志

Go 如何设置SA_ONSTACK标志,go,ibm-mq,Go,Ibm Mq,我的Go应用程序连接到IBM MQ 当我的应用程序抛出分段冲突错误(signal SIGSEGV)时,IBM MQ注册的信号处理程序使我的应用程序抛出“不带SAU ONSTACK标志的非Go代码设置信号处理程序” 那我怎么设置那个标志呢 我的代码 裁判 完全错误 接收到信号11,但处理程序不在信号堆栈上 致命错误:不带SA_ONSTACK标志的非Go代码设置信号处理程序 运行时堆栈: runtime:从0x7f60f6e9a517调用runtime.sigtram的意外返回pc 堆栈:帧={

我的Go应用程序连接到IBM MQ

当我的应用程序抛出分段冲突错误(signal SIGSEGV)时,IBM MQ注册的信号处理程序使我的应用程序抛出“不带SAU ONSTACK标志的非Go代码设置信号处理程序”

那我怎么设置那个标志呢

我的代码 裁判

完全错误
接收到信号11,但处理程序不在信号堆栈上
致命错误:不带SA_ONSTACK标志的非Go代码设置信号处理程序
运行时堆栈:
runtime:从0x7f60f6e9a517调用runtime.sigtram的意外返回pc
堆栈:帧={sp:0xc000046628,fp:0xc000046680}堆栈=[0xc00003e578,0xc000046978)
000000 C000046528:000000 C000046530 0000000000 4549A0
000000 C000046538:0000000000 4E2C3B 00000000000000 39
000000 C000046548:000000 C000046568 0000000000 4415DF
000000 C000046558:0000000000 4E2C3B 00000000000000 39
000000 C000046568:000000 C000046618 0000000000 440C6D
000000 C000046578:000000000000000 B 000000 C000046600
000000 C000046588:000000 C000046880 0000000000000000
000000 C000046598:000000000000000000000000 C000046628
000000 C0000465A8:0000000000000000000000000000000000
000000 C0000465B8:0000000000000000000000000000000000
000000 C0000465C8:000000000000000000000000 C000000180
000000 C0000465D8:0000000000000000 FFFFFFFFFFFFFF
000000 C0000465E8:0000000000000000000000000000000000
000000 C0000465F8:000000000000000000000000 C000002000
000000 C000046608:0000000000000000000000008000
000000 C000046618:000000 C000046670 0000000000 459A33
000000 C000046628:000000 C000046690
000000 C000046688:8e26f8f48c919100 0000000000000000
000000c000046698:0000000000000000000000000000008
000000 C0000466A8:000000000000000000000000 C000000180
000000 C0000466B8:0000000000000000000000000000000000
000000 C0000466C8:0000000000000000000000000000000000
000000 C0000466D8:0000000000000000000000000000000000
000000 C0000466E8:0000000000000000000000000000000000
000000c0000466f8:0000000000000000000000000000000000
000000 C000046708:0000000000000000000000000000000000
000000 C000046718:000000000000000000000000 C000046F88
000000 C000046728:000000000000000 4 00000000000000 12
000000 C000046738:0000000000 4F21E1 0000000000000000
000000 C000046748:00007f60f6e9b45a 0000000000000000
000000 C000046758:0000000000000000000000000000
000000 C000046768:0000000000000000000000000000000000
000000 C000046778:0000000000000000
runtime.throw(0x4e2c3b,0x39)
/usr/local/go/src/runtime/panic.go:617+0x72
runtime.sigNotOnStack(0xb)
/usr/local/go/src/runtime/signal_unix.go:576+0x7f
runtime.sigtranggo(0xb,0xc0000469b0,0xc000046880)
/usr/local/go/src/runtime/signal_unix.go:334+0x2ed
runtime:从0x7f60f6e9a517调用runtime.sigtram的意外返回pc
堆栈:帧={sp:0xc000046628,fp:0xc000046680}堆栈=[0xc00003e578,0xc000046978)
000000 C000046528:000000 C000046530 0000000000 4549A0
000000 C000046538:0000000000 4E2C3B 00000000000000 39
000000 C000046548:000000 C000046568 0000000000 4415DF
000000 C000046558:0000000000 4E2C3B 00000000000000 39
000000 C000046568:000000 C000046618 0000000000 440C6D
000000 C000046578:000000000000000 B 000000 C000046600
000000 C000046588:000000 C000046880 0000000000000000
000000 C000046598:000000000000000000000000 C000046628
000000 C0000465A8:0000000000000000000000000000000000
000000 C0000465B8:0000000000000000000000000000000000
000000 C0000465C8:000000000000000000000000 C000000180
000000 C0000465D8:0000000000000000 FFFFFFFFFFFFFF
000000 C0000465E8:0000000000000000000000000000000000
000000 C0000465F8:000000000000000000000000 C000002000
000000 C000046608:0000000000000000000000008000
000000 C000046618:000000 C000046670 0000000000 459A33
000000 C000046628:000000 C000046690
000000 C000046688:8e26f8f48c919100 0000000000000000
000000c000046698:0000000000000000000000000000008
000000 C0000466A8:000000000000000000000000 C000000180
000000 C0000466B8:0000000000000000000000000000000000
000000 C0000466C8:0000000000000000000000000000000000
000000 C0000466D8:0000000000000000000000000000000000
000000 C0000466E8:0000000000000000000000000000000000
000000c0000466f8:0000000000000000000000000000000000
000000 C000046708:0000000000000000000000000000000000
000000 C000046718:000000000000000000000000 C000046F88
000000 C000046728:000000000000000 4 00000000000000 12
000000 C000046738:0000000000 4F21E1 0000000000000000
000000 C000046748:00007f60f6e9b45a 0000000000000000
000000 C000046758:0000000000000000000000000000
000000 C000046768:0000000000000000000000000000000000
000000 C000046778:0000000000000000
sigtramp(0xc000046690,0x8e26f8f48c919100,0x0,0x0,0x8,0x0,0xc000000180,0x0,0x0,0x0,…)
/usr/local/go/src/runtime/sys_linux_amd64.s:357+0x43
goroutine 17[系统调用,锁定到线程]:
runtime.goexit()
/usr/local/go/src/runtime/asm_amd64.s:1337+0x1 fp=0xc0004afe8 sp=0xc0004afe0 pc=0x457e41
goroutine 1[正在运行]:
goroutine在其他线程上运行;堆栈不可用

您可以尝试设置环境变量“MQS\u NO\u SYNC\u SIGNAL\u HANDLING=true”禁用MQ的一些信号设置。这至少可以更好地了解SEGV来自何处。

您可以提供您的代码以更好地理解您的问题吗?嗨@creyD,我的代码很简单:我从IBM MQ中添加了一个参考,假设所讨论的cgo代码是您正在使用的任何客户端库的一部分或者IBM MQ,这就是问题所在,也是必须解决的问题。您实际上没有在链接中显示任何MQ代码,这很可能是您出现编码错误的地方。您可以使用MQ的go示例:和
package main

import (
    "fmt"
    "github.com/ibm-messaging/mq-golang/ibmmq"
)

type A struct {
    Str string
}

type B struct {
    Apointer *A
}

func main() {
    connectIBMMQ()

    b := B{}
    fmt.Println(b.Apointer.Str)
}

const (
    QMgrName       = `QMgrName`
    ChannelName    = `ChannelName`
    ConnectionName = `0.0.0.0(1416)`
    Username       = `username`
    Password       = `password`
)

func connectIBMMQ() {
    mqcd := ibmmq.NewMQCD()
    mqcd.ChannelName = ChannelName
    mqcd.ConnectionName = ConnectionName

    csp := ibmmq.NewMQCSP()
    csp.AuthenticationType = ibmmq.MQCSP_AUTH_USER_ID_AND_PWD
    csp.UserId = Username
    csp.Password = Password

    cno := ibmmq.NewMQCNO()
    cno.ClientConn = mqcd
    cno.Options = ibmmq.MQCNO_CLIENT_BINDING + ibmmq.MQCNO_RECONNECT + ibmmq.MQCNO_HANDLE_SHARE_BLOCK
    cno.SecurityParms = csp

    ibmmq.Connx(QMgrName, cno)
}

signal 11 received but handler not on signal stack
fatal error: non-Go code set up signal handler without SA_ONSTACK flag

runtime stack:
runtime: unexpected return pc for runtime.sigtramp called from 0x7f60f6e9a517
stack: frame={sp:0xc000046628, fp:0xc000046680} stack=[0xc00003e578,0xc000046978)
000000c000046528:  000000c000046530  00000000004549a0 <runtime.throw.func1+0> 
000000c000046538:  00000000004e2c3b  0000000000000039 
000000c000046548:  000000c000046568  00000000004415df <runtime.sigNotOnStack+127> 
000000c000046558:  00000000004e2c3b  0000000000000039 
000000c000046568:  000000c000046618  0000000000440c6d <runtime.sigtrampgo+749> 
000000c000046578:  000000000000000b  000000c000046600 
000000c000046588:  000000c000046880  0000000000000000 
000000c000046598:  0000000000000000  000000c000046628 
000000c0000465a8:  0000000000000000  0000000000000000 
000000c0000465b8:  0000000000000000  0000000000000000 
000000c0000465c8:  0000000000000000  000000c000000180 
000000c0000465d8:  0000000000000000  ffffffffffffffff 
000000c0000465e8:  0000000000000000  0000000000000000 
000000c0000465f8:  0000000000000000  000000c000002000 
000000c000046608:  0000000000000000  0000000000008000 
000000c000046618:  000000c000046670  0000000000459a33 <runtime.sigtramp+67> 
000000c000046628: <000000000000000b  000000c0000469b0 
000000c000046638:  000000c000046880  000000c000046880 
000000c000046648:  000000c0000469b0  0000000000000000 
000000c000046658:  000000000000000b  000000c000046670 
000000c000046668:  00007f60f78213c0  000000000262e400 
000000c000046678: !00007f60f6e9a517 >000000c000046690 
000000c000046688:  8e26f8f48c919100  0000000000000000 
000000c000046698:  0000000000000000  0000000000000008 
000000c0000466a8:  0000000000000000  000000c000000180 
000000c0000466b8:  0000000000000000  0000000000000000 
000000c0000466c8:  0000000000000000  0000000000000000 
000000c0000466d8:  0000000000000000  0000000000000000 
000000c0000466e8:  0000000000000000  0000000000000000 
000000c0000466f8:  0000000000000000  0000000000000000 
000000c000046708:  0000000000000000  0000000000000000 
000000c000046718:  0000000000000000  000000c000046f88 
000000c000046728:  0000000000000004  0000000000000012 
000000c000046738:  00000000004f21e1  0000000000000000 
000000c000046748:  00007f60f6e9b45a  0000000000000000 
000000c000046758:  0000000000000000  0000000000000000 
000000c000046768:  0000000000000000  0000000000000000 
000000c000046778:  0000000000000000 
runtime.throw(0x4e2c3b, 0x39)
    /usr/local/go/src/runtime/panic.go:617 +0x72
runtime.sigNotOnStack(0xb)
    /usr/local/go/src/runtime/signal_unix.go:576 +0x7f
runtime.sigtrampgo(0xb, 0xc0000469b0, 0xc000046880)
    /usr/local/go/src/runtime/signal_unix.go:334 +0x2ed
runtime: unexpected return pc for runtime.sigtramp called from 0x7f60f6e9a517
stack: frame={sp:0xc000046628, fp:0xc000046680} stack=[0xc00003e578,0xc000046978)
000000c000046528:  000000c000046530  00000000004549a0 <runtime.throw.func1+0> 
000000c000046538:  00000000004e2c3b  0000000000000039 
000000c000046548:  000000c000046568  00000000004415df <runtime.sigNotOnStack+127> 
000000c000046558:  00000000004e2c3b  0000000000000039 
000000c000046568:  000000c000046618  0000000000440c6d <runtime.sigtrampgo+749> 
000000c000046578:  000000000000000b  000000c000046600 
000000c000046588:  000000c000046880  0000000000000000 
000000c000046598:  0000000000000000  000000c000046628 
000000c0000465a8:  0000000000000000  0000000000000000 
000000c0000465b8:  0000000000000000  0000000000000000 
000000c0000465c8:  0000000000000000  000000c000000180 
000000c0000465d8:  0000000000000000  ffffffffffffffff 
000000c0000465e8:  0000000000000000  0000000000000000 
000000c0000465f8:  0000000000000000  000000c000002000 
000000c000046608:  0000000000000000  0000000000008000 
000000c000046618:  000000c000046670  0000000000459a33 <runtime.sigtramp+67> 
000000c000046628: <000000000000000b  000000c0000469b0 
000000c000046638:  000000c000046880  000000c000046880 
000000c000046648:  000000c0000469b0  0000000000000000 
000000c000046658:  000000000000000b  000000c000046670 
000000c000046668:  00007f60f78213c0  000000000262e400 
000000c000046678: !00007f60f6e9a517 >000000c000046690 
000000c000046688:  8e26f8f48c919100  0000000000000000 
000000c000046698:  0000000000000000  0000000000000008 
000000c0000466a8:  0000000000000000  000000c000000180 
000000c0000466b8:  0000000000000000  0000000000000000 
000000c0000466c8:  0000000000000000  0000000000000000 
000000c0000466d8:  0000000000000000  0000000000000000 
000000c0000466e8:  0000000000000000  0000000000000000 
000000c0000466f8:  0000000000000000  0000000000000000 
000000c000046708:  0000000000000000  0000000000000000 
000000c000046718:  0000000000000000  000000c000046f88 
000000c000046728:  0000000000000004  0000000000000012 
000000c000046738:  00000000004f21e1  0000000000000000 
000000c000046748:  00007f60f6e9b45a  0000000000000000 
000000c000046758:  0000000000000000  0000000000000000 
000000c000046768:  0000000000000000  0000000000000000 
000000c000046778:  0000000000000000 
runtime.sigtramp(0xc000046690, 0x8e26f8f48c919100, 0x0, 0x0, 0x8, 0x0, 0xc000000180, 0x0, 0x0, 0x0, ...)
    /usr/local/go/src/runtime/sys_linux_amd64.s:357 +0x43

goroutine 17 [syscall, locked to thread]:
runtime.goexit()
    /usr/local/go/src/runtime/asm_amd64.s:1337 +0x1 fp=0xc00004afe8 sp=0xc00004afe0 pc=0x457e41

goroutine 1 [running]:
    goroutine running on other thread; stack unavailable