草庐IT

延迟消息

全部标签

go - Go 中的延迟似乎会增加延迟

我在Go中使用互斥体进行同步。下面是代码func(c*MyStruct)Put(keystring,valueinterface{}){c.mu.Lock()deferc.mu.Unlock()val,found:=c.items[key]iffound{item:=val.Value.(*Item)item.Value=valueitem.Expiration=time.Now().Add(c.ttl).UnixNano()return}ele:=c.list.PushFront(&Item{key,value,expirationTime})c.items[key]=ele}当我对

go - 如何在 Go 中从 netcat 打印 TCP 消息?

所以我需要用Go编写一个服务器来打印来自以下命令的消息:echo"MESSAGE"|nclocalhost8080它只需将“MESSAGE”作为字符串打印在标准输出上。我不能使用别的东西,它必须是这个命令。这是我到目前为止所拥有的:packagemainimport("fmt""net""os")funcmain(){ln,err:=net.Listen("tcp",":8080")check(err)for{conn,err:=ln.Accept()check(err)gohandleConnection(conn)}}funchandleConnection(connnet.Con

go - Go 中的 RabbitMQ : machinery worker cannot to connect to 0. 0.0.0:5672 消息 getsockopt: 连接被拒绝

RabbitMQ在wifi网络中运行良好,我在运行ArchLinux的笔记本电脑中设置了RabbitMQ。但是,当我在不同的wifi网络中使用同一台笔记本电脑时,出现以下错误:machinery:worker.go:42:Goingtoretrylaunchingtheworker.Error:Dial:dialtcp0.0.0.0:5672:getsockopt:connectionrefusedmachinery:retry.go:20:Retryinginxseconds我不知道为什么RabbitMQ在一个网络中工作而不在另一个网络中工作。我尝试更改/etc/rabbitmq/r

go - 为什么当我超时函数时不调用延迟?

当我在函数中添加延迟时,我希望它在函数结束时始终被调用。我注意到当函数超时时它不会发生。packagemainimport("context""fmt""time")funcservice1(ctxcontext.Context,r*Registry){ctx,cancel:=context.WithTimeout(ctx,100*time.Millisecond)deferfunc(){r.Unset("service1")}()r.Set("service1")goservice2(ctx,r)select{case%v\n",key,val)}}funcNewRegistry()

Golang protobuf 动态消息

我正在编写一个gotcp客户端来接收来自服务器的事件。服务器响应是以这种方式构造的字节:起始字节字节长度命令字节地址1字节地址2字节地址3字节地址4字节错误字节参数1字节...N.参数N字节我可以为此使用Protobufs吗?如果是,我应该如何构建消息?亲切的问候,于尔根 最佳答案 答案是:可以。它必须看起来像这样:原型(prototype)文件:syntax="proto3";messageEvent{bytesstart=1;byteslength=2;...repeatedbytesparam=9;}你的go结构将是:type

go - 在 Hyperledger fabric 中,如何打印出链代码函数的消息和日志?

我想通过Golang测试我的链代码,所以我使用了Hyperledgerfabricchaincodedev测试。链码的所有功能(调用、查询等)都有效,但控制台上没有链码的日志和消息。在每种情况下,日志记录都设置为“调试”。我想在控制台打印出调用、查询的结果消息,但只打印出消息:“myc”;“我的C”;“我的C”;...2019-03-1518:07:04.550UTC[shim]setupChaincodeLogging->INFO001Chaincodeloglevelnotprovided;defaultingto:INFO2019-03-1518:07:04.550UTC[shi

go - 将字符串解析为不同类型,并在 GO 中使用常见错误消息

这个问题在这里已经有了答案:GoErrorHandlingTechniques[closed](11个答案)关闭3年前。我想将[]string值解析为特定类型(例如int、float等),因此我必须对不同的行使用不同的解析函数。我的代码:value,err:=strconv.Atoi(line[1])value1,err:=strconv.ParseFloat(line[4],6)value2,err:=strconv.ParseFloat(line[5],6)value3,err:=strconv.Atoi(line[2])我必须确保每个值都被解析,所以对于每个值我都必须有err!=

go - 在延迟恢复时设置变量

根据示例(例如gettingpanic()argumentindeferfunctioninGOlang)我已经看到,我希望它能工作,但事实并非如此。强制错误时,err返回字符串保持空白,尽管打印err字符串显示预期的错误。我确定我遗漏了一些明显的东西,但找不到它。有一点帮助吗?//expectederrorexample://chk,err:=equal("a",map[string]string{"a"})//funcEqual(ainterface{},binterface{})(checkbool,errstring){deferfunc(){ifcatch:=recover(

go - 如何延迟函数返回的匿名函数

假设您有一个函数可以设置您的应用程序服务器并返回一个应该在您的应用程序退出之前立即运行的函数。funcmain(){deferapplicationExit()}funcapplicationExit()func(){fmt.Println("ApplicationSetupCall")returnfunc(){fmt.Println("ApplicationTearDownCall")}}您将获得以下输出。输出:应用程序设置调用出了什么问题?为什么我们看不到输出ApplicationTearDownCall 最佳答案 您的代码完全

go - 两个节点可以直接交换消息吗?

我正在研究基于Kademlia的去中心化网络。在启动一个新节点后,不是向最近的节点广播消息,而是可以将消息发送到由其ID标识的特定节点吗?(即使这意味着在到达目的地之前将消息中继到多个对等方)。 最佳答案 Kademlia是一种抽象路由算法,结合了构建分布式哈希表所需的一组操作。kademlia-as-algorithm中不存在广播的概念。但是具体的实现可以在此基础之上添加功能。由于kademlia提供迭代find_node过程(没有转发!),您可以找到一个节点,然后交换任何数量和类型的额外消息,它们相互支持。