草庐IT

延迟消息

全部标签

go - Zap 堆栈跟踪与谷歌云上的错误消息

我正在使用zapp在谷歌云上托管的服务上记录错误消息,我看到虽然成功记录了错误,但存储在谷歌云日志“消息”字段中的文本是堆栈跟踪,并且不是我记录的错误消息。示例代码:varlog*zap.Loggeriferr:=doStuff();err!=nil{log.Error(,zap.Error(err))}除了谷歌云日志记录和堆栈驱动程序将使用调用结构化日志的message字段中的zap.Error捕获的堆栈跟踪外,这工作得很好。我定义的消息出现在msg字段中,但前者似乎是主要显示在日志记录控制台中并被stackdriver用于索引错误的消息。这意味着当通过控制台浏览日志和错误时,我只能

go - 如何通过 AMQP 1.0 在 Azure Event Hub 中批量接收多条消息

我使用QpidProton的ApacheQpidElectronGo包装器设置了一个仅包含路径和过滤器的AMQP1.0链接,如下所示:amqpConnection.Receiver(//thepathcontainingtheconsumergroup//andthepartitionIdelectron.Source(""),//thefiltermapcontainssomeannotationsfilters//fortheEventHuboffsetelectron.Filter(filterMap),)我按照此文档设置了AMQP链接选项:https://godoc.org/q

go - 在 GO 中解析时间时出现奇怪的错误消息

我尝试在go中将字符串解析为时间,这是我所做的:dateTime:=fmt.Sprintf("%s%sCST",dateValue,timeValue)date,err:=time.Parse("2006-1-2150405MST",dateTime)我收到以下错误信息:解析时间“2012-4-9174031CST”为“2006-1-2150405MST”:无法将“2012-4-9174031CST”解析为“2006”从报错信息来看,我传入的dateTime值是正确的。我还尝试执行以下操作,效果很好:dateTime:="2012-4-9174031CST"date,err:=time

go - emersion/go-imap - 如何检索和列出看不见的消息

我正在尝试使用IMAP协议(protocol)的实现,但似乎无法从邮箱中检索看不见的邮件。这是我的代码。packagemainimport("emailmonitor/util""fmt")funcmain(){serverGmail:=util.NewServerGmail()serverGmail.Connect()serverGmail.Login()serverGmail.ListUnseenMessages()}//-----------------------------------------packageutilimport("io/ioutil""log""net/m

go - 如何确保消息平均发送给所有消费者

在我们公司,我们用Go构建了一个推送服务,我们把它放在四台机器上以保证传输速度,当我们需要发送通知时,我们将消息发送到rabbitMQ,然后推送服务会从队列中获取消息,但有时我们发现只有一台机器收到消息。这里是rabbitMQ消费者的配置:msgs,err:=ch.Consume(q.Name,//queueconsumerTag,//consumertrue,//auto-ackfalse,//exclusivefalse,//no-localfalse,//no-waitnil,//args)我应该如何设置配置以确保每个消费者获得相同数量的消息? 最佳答

go - 递归定义 SNMP 消息

我在Go中弄乱了一个SNMP库,并提出了一个Field类型,它根据thisdocument定义了一个SNMPBER编码字段。.每个字段由类型、长度和值组成,其中类型是ASN.1类型,长度是字段值的长度,值可以是另一个字段、字段序列或字节序列。这让我想到了递归定义SNMP消息的可能性。这是我想出的一些代码,但我一直在尝试将其转换为递归结构:packagemainimport"fmt"//ASN.1BERencodedtypes.typeASN1BERbyteconst(IntegerASN1BER=0x02BitString=0x03OctetString=0x04Null=0x05Ob

go - 如何构建一个可以使用 Go 向多个客户端接收和发送消息的服务器?

我是Go的新手,我正在尝试创建一个服务器,它可以从客户端接收消息并将其发送到其他客户端或任何其他特定客户端。我尝试了很多聊天示例,但我想做的是创建两个文件,一个用于服务器,另一个用于客户端。这是我到目前为止尝试过的代码。server.gopackagemainimport"net"import"fmt"import"bufio"import"strings"funcsend(cnet.Conn){netData,err:=bufio.NewReader(c).ReadString('\n')iferr!=nil{fmt.Println(err)return}temp:=strings.

go - 在 golang 中更新 grpc 的接收和发送消息大小

我有一个用Go编写的grpc服务器,我正在尝试使用以下代码将接收和发送消息的大小更新为20MB而不是默认的4MBvars*grpc.Servers=grpc.NewServer(grpc.MaxRecvMsgSize(1024*1024*20),grpc.MaxSendMsgSize(1024*1024*20))pb.RegisterProductServer(s,mysrv)但上面的方法似乎不起作用,因为当我尝试从客户端调用receivedmessagelargerthanmax(5807570vs.4194304)时我仍然收到错误消息”不确定是什么覆盖了大小

azure - 从服务总线队列检索消息时出错

我尝试使用Go从Azure服务总线队列中提取消息,但在运行代码时出现错误。这是我的代码。funcExample_queue_receive(){ctx,cancel:=context.WithTimeout(context.Background(),10*time.Second)defercancel()connectionString:="Endpoint=sb://{my_service_name}.servicebus.windows.net/;SharedAccessKeyName=RootManageSharedAccessKey;SharedAccessKey={my_sh

go - WebSocket 客户端如何知道消息已被完整读取?

我曾经这样做过:...ws,err:=websocket.Dial(url,"",origin)...varbuffer=make([]byte,512)varrs=make([]byte,0,512)L:for{m,err:=ws.Read(buffer)iferr!=nil{iferr==io.EOF{breakL}fmt.Println(err.Error())return}rs=append(rs,buffer[:m]...)ifm这有一个错误:如果消息的长度恰好是512或1024或2048...循环永远不会中断;它将停留在ws.Read()并等待而不抛出io.EOF。后来我观