草庐IT

消息中间件

全部标签

go - Golang 应用程序的可嵌入消息传递组件

我需要一个用于Golang应用程序的可嵌入消息传递组件。我研究了NSQ等分布式消息传递系统,但更喜欢一个更简单、稳定和可嵌入(没有单独的守护进程)的消息传递系统。像NSQ这样的系统对我的要求来说太过分了,我认为它不容易嵌入。我需要这样一个组件来在我的处理分布式引擎之间可靠地分发有效负载/数据(至少交付一次)并且可嵌入将使安装和配置变得容易。如有任何信息,我们将不胜感激。 最佳答案 我在生产中使用RabbitMQ和这个库https://github.com/streadway/amqp.这不是官方库,但实现非常好。我用它来提高IOT的

go - 如何在golang中发送电报的userleft消息

我正在使用golang编程语言编写电报机器人。如何在用户离开或加入时发送消息?我试试这个if(message.UserJoined==true){bot.SendMessage(message.Chat,"",nil)}但是它不起作用,我得到这个错误./main.go:291:invalidoperation:message.UserJoined==true(mismatchedtypestelebot.Userandbool) 最佳答案 UserJoined是定义的用户结构://UserJoined可能是机器人本身。UserJoi

email - 在 Go 中解析电子邮件消息头

我如何在Go中读取电子邮件中的一些标题?通常我会使用ReadMIMEHeader(),但遗憾的是,并不是每个人都阅读了所有相关的RFC,对于某些消息,我得到的输出如下:malformedMIMEheaderline:name="7DDA4_foo_9E5D72.zip"我缩小了罪魁祸首Content-Type:application/x-zip-compressed;x-unix-mode=0600;name="7DDA4_foo_9E5D72.zip"代替Content-Type:application/x-zip-compressed;x-unix-mode=0600;name="

google-app-engine - 中间件错误处理

我有一个链clawhttp.Handler中间件,我的第一个处理程序可能会在其中写入错误响应:http.Error(w,err.Error(),http.StatusUnauthorized)但是我的其他中间件继续执行,但我不希望它继续执行。最好的方法是什么?我尝试在调用http.Error()后检查状态header,看看它是否不是200:status:=w.Header().Get("Status")但是状态是一个空字符串。 最佳答案 您可以在错误发生后立即使用“裸”return来停止中间件链的执行。来自httpdocumenta

go - GO中不同的路径如何使用不同的中间件?

您好,我正在使用justinas/alice,我想根据路径创建不同的中间件。即,如果我有路径1和路径2,我想为路径1应用m1、m2、m3,为路径2应用m1、m2我试过:首先创建两个mux路由器:路由器:=mux.NewRouter()路由器2:=mux.NewRouter()为它们分配路径:router.HandleFunc(path1,Func1)router2.HandleFunc(path2,Func2)然后我想要这样的东西中间件:=alice.New(m1,m2).Then(router2)middlewares:=middlewares.Append(中间件)-然后:ifer

Golang Kafka 不消耗所有消息 offsetnewest

第一批:-我正在尝试从100个平面文件中提取数据并将其加载到一个数组中,然后将它们作为字节数组一个一个地插入到kafka生产者中。第二批:-我从kafka消费者消费,然后将它们插入NoSQL数据库。我在Kafka的shopifysaramagolang包的配置文件中使用了Offsetnewset。我可以接收消息并将消息插入到kafka,但在消费时我只收到第一条消息。因为我在sarama配置中提供了最新的Offset。我怎样才能得到这里的所有数据。 最佳答案 如果没有任何代码或关于如何配置kafka的更深入的解释(即:主题、分区等),

golang 从 net.TCPConn 中以 4 个字节作为消息分隔读取字节

我正在golang中开发SIPoverTCP模拟服务。传入的SIP消息由'\r\n\r\n'序列分隔(我现在不关心SDP)。我想根据该分隔符提取消息并将其发送到处理goroutine。通过golang标准库,我看不到实现它的简单方法。io和bufio包似乎没有一站式服务。目前我看到两个前进的选择(bufio):*Reader.ReadBytes函数,'/r'设置为分隔符。进一步的处理是通过使用ReadByte函数并将其与定界符的每个字节按顺序进行比较并在必要时取消读取它们来完成的(这看起来很乏味)将Scanner与自定义拆分功能结合使用,这看起来也不是太琐碎。我想知道是否还有其他更好的

amazon-web-services - 使用 aws-sdk-go/roleARN/queueARN (sqs) 获取消息

我创建了一个sqs队列(它有queueARN)。我还创建了一个IAM角色(它提供roleARN并具有对queueARN的访问权限)。我正在尝试使用此角色从队列中获取消息,但我找不到执行此操作的示例代码。有什么提示吗? 最佳答案 我认为这是一个很好的起点。https://github.com/aws/aws-sdk-go/blob/master/service/sqs/examples_test.go 关于amazon-web-services-使用aws-sdk-go/roleARN/q

go - 我可以将我的功能用作 `negroni` 中间件吗

我有一个函数,我将其用作每个GET请求的包装器:typeHandlerFuncfunc(whttp.ResponseWriter,req*http.Request)(interface{},error)funcWrapHandler(handlerHandlerFunc)http.HandlerFunc{returnfunc(whttp.ResponseWriter,req*http.Request){data,err:=handler(w,req)iferr!=nil{log.Println(err)w.WriteHeader(500)}else{w.Header().Add("Co

去代理中间件并修改响应

我正在尝试将来自Go后端的请求代理到微服务,并在将响应发送到客户端之前修改响应。请求链为:Client->Gobackend->microservice->Gobackend->client我正在使用GoGin框架。工作中间件:funcReverseProxy(targetstring)gin.HandlerFunc{log.Println(target)url,err:=url.Parse(target)iferr!=nil{log.Fatal(err)}proxy:=httputil.NewSingleHostReverseProxy(url)returnfunc(c*gin.Co