草庐IT

RabbitMQ消息队列

全部标签

go - 递归定义 SNMP 消息

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

go - 如何处理可以无阻塞增长的队列

如果队列可以从处理函数本身增长,我正在尝试了解如何在Go中处理队列。请参见下面的代码。在这个伪代码中,我想将我创建的处理程序数量限制为10。因此我创建了10个处理队列的处理程序。然后我用一个url开始排队。我的问题是,根据文档,channel的sender将阻塞,直到接收者接收到数据。在下面的代码中,每个进程都是一个处理新url的接收器。然而,很容易看出,如果一个进程向队列发送11个链接,它将阻塞,直到所有接收者都处理完这些新链接。如果这些接收者每个都有1个链接,那么它们也会在将新的1个链接发送到队列时阻塞。由于每个人都被阻止,所以什么都没有完成。我想知道go的一般解决方案是什么,用于

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。后来我观

go - 使用 nats-streaming 发送大于 1MB 的消息?

我正在尝试使用nats消息服务发送文件。文件的大小可能会有所不同。有没有办法在消息正文中发送超过1MB的数据,或者可能中断并加入消息正文? 最佳答案 2022-09-19更新根据文档(https://docs.nats.io/reference/faq#is-there-a-message-size-limitation-in-nats),默认大小为1M,最多可增加到64M。(另请参阅其他答案)过时的信息根据NATSFAQ,您不能发送大小超过1M的消息(https://docs.nats.io/reference/faq#is-th

go - 如何覆盖 DefaultHTTPErrorHandler 格式消息

我正在使用Echo框架。如何将此格式响应更改为我自己的格式它来自JWT库的错误https://github.com/dgrijalva/jwt-go{"message":"invalidorexpiredjwt"}我想改变这样的东西{"meta":{"status":false,"message":"Unauthorized","messages":null},"result":null}我找不到如何覆盖DefaultHTTPErrorHandler这个自定义的HttpErrorHandlere:=echo.New()e.HTTPErrorHandler=func(errerror,c

go - 如何编写在 goroutine 中执行的函数来发送和接收消息?

我必须编写一个客户端代码,它以字符串的形式从服务器接收消息,并从控制台获取输入以结束发送到服务器的消息。这两个操作应该同时运行。我编写了一个代码来执行这些操作,但不是同时执行这些操作。这是我当前的代码:funcSocketClient(){conn,err:=net.Dial("tcp",":9000")iferr!=nil{log.Fatal(err)}deferconn.Close()server_reader:=bufio.NewReader(conn)input_reader:=bufio.NewReader(os.Stdin)for{//forsendingmessagesb

google-app-engine - App Engine 任务队列创建一批队列项并在 go lang 中每 10 秒执行一次

由于使用内部代码的第三方API的某些限制(第三方API每分钟有1000个API调用),我想创建一批队列项并每10秒执行一次。但我不知道如何使用任务队列在AppEngine中实现给定的要求。或者可以使用任务队列推送创建批处理吗? 最佳答案 TaskQueueTask有一个Delaytime.Duration以及ETAtime.Time字段,可用于创建和延迟任务.相信你可以重用thetopexample但在调用taskqueue.Add(c,t,"")之前设置其中一个字段 关于google-