草庐IT

springcloud消息驱动

全部标签

go - 具有自定义消息编码器的 Uber zap 日志记录

我正在使用以下代码使用Uberzap记录器将日志转储到控制台和日志文件中。我如何拥有自定义消息编码器,以便消息的输出格式如下所示?{"severity":"DEBUG","message":"Dec12,201819:52:39[log.go:77]Sampledebugforlogfileandconsole"}下面是我用来在控​​制台上转储日志的代码。packagemainimport("os""time""go.uber.org/zap""go.uber.org/zap/zapcore""gopkg.in/natefinch/lumberjack.v2""path/filepat

go - Golang Consumer连接Kafka后延迟接收Kafka消息

我是Golang和Kafa的新手,所以这似乎是一个愚蠢的问题。在我的Kafka消费者首次连接到Kafka服务器后,为什么在与Kafka服务器建立连接和接收第一条消息之间存在延迟(约20秒)?它在consumer.Messages()之前打印一条消息,并为收到的每条消息打印另一条消息。大约20秒的延迟在第一个fmt.Println和第二个fmt.Println之间。packagemainimport("fmt""github.com/Shopify/sarama"cluster"github.com/bsm/sarama-cluster")funcmain(){//Createtheco

go - 如何使用 golang 在编译时不知道其类型的情况下解析 protobuf3 消息?

这是一个场景:您正在golang中实现一个通用组件,该组件可以与任何类型的原型(prototype)消息(二进制序列化)一起使用,并且需要在编译时不知道其类型的情况下反序列化二进制原型(prototype)数据。例如,我在编写一个通用的kafkajsonarchiver时遇到了这个问题,该组件将:从配置中接收消息类型(字符串)和kafka主题的名称需要在运行时创建二进制->内存反序列化器和内存->json序列化器。如何从消息名称中获取二进制字节的反序列化器? 最佳答案 golang原型(prototype)库有一个用于此目的的辅助实

go - ZMQ 无法接收来自多个发布者的消息

我正在实现ZMQ的Espresso模式。我想连接很多订阅者代理很多发布者但是,代理中的监听器只接收来自一个发布者的消息。因此,订阅者只能从那个特定的发布者那里接收。我无法弄清楚我的代码有什么问题。packageplaygroundimport(zmq"github.com/pebbe/zmq4""fmt""math/rand""time""testing")funcsubscriber_thread(idint){subscriber,_:=zmq.NewSocket(zmq.SUB)subscriber.Connect("tcp://localhost:6001")subscribe

go - 如何将 prpBytes(描述​​中的链接 src)(ProposalResponsePayload protobuf 消息)反序列化为原始对象

我对plugin.go中的方法有疑问,发现here在Hyperledger结构库中。//Endorsesignsthegivenpayload(ProposalResponsePayloadbytes),andoptionallymutatesit.//Returns://TheEndorsement:Asignatureoverthepayload,andanidentitythatisusedtoverifythesignature//Thepayloadthatwasgivenasinput(couldbemodifiedwithinthisfunction)//Orerroro

go - 使用 Cassandra GOCQL 驱动程序 (Golang) 确定页面状态

我一直在努力思考如何使用Golang中的驱动程序在ApacheCassandra中进行分页。我有以下用于获取行的代码///Assumeallotherprerequisites.session,_:=cluster.CreateSession()session.SetPageSize(100)varpagestate[]bytequery:=session.Query(`select*fromkeyspace.my_table`)query=query.PageState(pagestate)iferr:=query.Exec();!=nil{panic(err)}iter:=quer

go - 如何在使用 Golang 提交表单后正确获取 JSON 中的消息

使用Golang提交表单后,如何正确获取JSON格式的消息?我今天第一次尝试Golang。这是我试图实现的目标:例如,在PHP中,我可以在用户提交表单后回显/打印JSON消息,然后可以从前端访问它。例如。if($everything=='ok'){$messages=['message'=>'UserRegisteredsuccessfully'];echojson_encode($messages);exit();}我如何使用Golang做到这一点?下面的代码通过将记录插入数据库来正常工作。成功插入后,它会在下面的代码中显示一条成功消息,一切正常。res.Write([]byte("

mongodb - 用MongoDB官方Golang驱动可以查到一条记录,但是记录是空的

我正在尝试学习Go,我写了一些代码来处理MongoDB测试数据库,插入一些通用的“项目”。这是代码:https://pastebin.com/ptNwKbk2我可以毫无问题地插入和更新记录,但是当我尝试FindOne或查找记录时,出现的是一些空壳,它找到了记录,但记录仅显示其ID。首先找到[第89行]:err=collection.FindOne(context.TODO(),filter).Decode(&resultItem)结果:Foundasingledocument:{ID:ObjectID("5cb488c30eeb652e64ecdaeb")itemID:priority

unit-testing - 表驱动测试中的竞争检测

我有一个表驱动测试和表循环外的initvar(worker)。我使用gotest-raсe运行测试并添加了t.Parallel()并且没有检测到竞争条件。我可以假设我的测试没有竞争条件吗://Thismockcouldbeinaseparatefile.typemockWorkerstruct{}//implmentourWorkeriterfacefunc(mdmockWorker)Work()error{returnnil}typemockDoerstruct{ErrorerrorWorkerworker}//implmentourDoeriterfacefunc(mdmockDo

mongodb - map[string]interface{} 自切换到新的 go mongo 驱动程序后未被正确解析

我正在切换到新的mongogo驱动程序(mongo-go-driver),远离mgo尽管解码方法没有改变(变成map[string]interface{}),但我们的一个函数不再工作我相信正在发生的事情是返回的数据没有作为map[string]接口(interface)正确处理{}摄取的数据是一个mongo聚合查询:result=map[query_key:procedure_on_citiesquery_type:runprocedurequery_value:map[aggregate:[map[£match:map[Source:Cities]]map[£sort:map[Ord