草庐IT

SpringBoot集成RabbitMQ

全部标签

go - 如何检查 channel 是否仍在 streadway/amqp RabbitMQ 客户端中工作?

这个问题在这里已经有了答案:HowtodetectdeadRabbitMQconnection?(4个答案)关闭9个月前。我正在使用github.com/streadway/amqp对于我的程序。在重新初始化之前,我应该如何确保用于消费和/或生产的channel仍在工作?例如,在ruby​​中,我可以简单地做:bunny_client=Bunny.new({....})bunny_client.start启动客户端,ifnotbunny_clientorbunny_client.status!=:connected#re-initializetheclient如何使用streadway

go - golang 消费者端超时 rabbitmq

我正在使用rabbitmq和golang,我在comsumer端创建了一个等待消息的线程,例如rabbitmq示例。我想主线程将等待kill信号并将信号发送到rabbitmq线程,但如果消息未推送到队列中,rabbitmq线程将永远等待,因此它不会处理kill信号消息。我发现rabbitmq在comsumer中有超时,但我刚刚在java中找到了代码,而不是golang。你能帮助我吗?谢谢。 最佳答案 如果我对您的问题的理解正确,您希望能够退出例行处理队列?超时设置在这里不起作用。这是针对服务器/客户端心跳的,只有在任何时候都没有收到

Springboot+mybatis+jsp实现简单的增删改查(详细步骤)

一、环境搭建1.创建一个springboot项目(勾选web)2.导入依赖org.springframework.bootspring-boot-starter-weborg.springframework.bootspring-boot-starter-testtestorg.springframework.bootspring-boot-starterorg.mybatis.spring.bootmybatis-spring-boot-starter1.3.2mysqlmysql-connector-javaruntimecom.alibabadruid1.1.12org.junit.ju

google-app-engine - 谷歌云引擎 : PubSub instead of RabbitMQ

我的项目采用在GoogleCloud中运行的微服务器架构。我正在考虑从使用RabbitMQ的容器迁移到PubSub引擎。问题是:是否可以一条一条的接收消息?我的代码是用Go和docs编写的说Thecallbackisinvokedconcurrentlybymultiplegoroutines,maximizingthroughput.但是可以调用多少个goroutines呢?如何设置允许的最大值?例如。我的一名工作人员使用第三方API,每个IP仅允许一个连接,因此我只能及时为该工作人员执行一项任务。 最佳答案 正确的解决方案是Ap

Go - 集成测试使用测试数据库连接

go程序使用连接字符串连接到数据库。目前该连接字符串存储在环境变量中。我的挑战是编写一个自动化测试,针对测试数据库运行程序。我想我会在测试的init()函数中设置连接字符串环境变量,但是在测试init()之前调用了主程序的init()函数,所以这不起作用。解决方法似乎是将连接字符串默认为测试数据库。如果没有定义环境变量,则使用test;如果已定义(生产),则改用它。有替代方案吗?有没有更好的方法? 最佳答案 我目前的解决方案是使连接成为未初始化的全局连接。该函数检查连接是否为nil-如果是,则将其初始化。该测试有一个setup()函

ssl - RabbitMQ TLS tls_connection :format_status/2 crashed

我正在尝试使用Go建立一个简单的TLS连接,RabbitMQ在尝试创建启用了TLS的连接(Go客户端)时报告了这个问题:rabbitmq_1|2018-04-1613:37:54.146[error]**Statemachineterminatingrabbitmq_1|**Lastevent={{call,{,#Ref}},{new_user,}}rabbitmq_1|**Whenserverstate={error,"tls_connection:format_status/2crashed"}rabbitmq_1|**Reasonfortermination=error:func

go - 作为发布者连接到 RabbitMQ 的频率

这个问题在这里已经有了答案:Whethertocreateconnectioneverytimewhenamqp.Dialisthreadsafeornotingolang(1个回答)关闭4年前。我实际上是在学习RabbitMQ的教程。我希望我的应用程序的微服务能够通过RabbitMQ进行通信。我创建了一个发布者库,每次我想从microservice_a向microservice_b发送消息时都会使用它。像这样的东西:发件人.go://SendEmail...func(s*MessageQueue)SendEmail(bodystring){conn,err:=amqp.Dial(fm

testing - Go gRPC 服务器使集成测试失败

我最近又开始玩go,我现在的任务是实现一个服务(将运行在k8s上),它应该充当gRPC服务器。根据要求,目前,为了满足k8s上的readinessProbe,我需要为我的服务实现一个健康检查端点,并且应该对其进行测试:我所做的是:funcmain(){server:=startHTTPServer()deferserver.Close()c:=make(chanos.Signal,1)signal.Notify(c,os.Interrupt,syscall.SIGTERM,syscall.SIGINT)我按照thisarticle这样测试的:funcTestMain(m*testing

go - 为什么 RabbitMQ 在不使用时不会保持连接打开?

我用过http://github.com/streadway/amqp在我的应用程序中打包,以便处理与远程RabbitMQ服务器的连接。一切正常并且工作正常但是当连接长时间空闲时f.g6小时它会关闭。我在我的go例程中一直检查NotifyClose(make(chan*amqp.Error))并返回:Exception(501)Reason:"writetcp192.168.133.53:55424->192.168.134.34:5672:write:brokenpipe"为什么会出现这个错误?(我的代码有什么问题吗?)连接可以空闲多长时间?如何预防这个问题?

ssl - RabbitMQ - Tls 连接 - Golang

我使用以下链接配置了RabbitMQ连接:https://github.com/streadway/amqp/blob/master/examples_test.go我根据此处的说明创建的证书:https://www.rabbitmq.com/ssl.html#enabling-tls-paths我使用安装在docker中的RabbitMQ3.7.0。调用amqp.DialTLS后,我在服务器端(在docker日志中)收到“证书错误”错误。我想问题是证书应该包含服务器名称,如果是这样,如果RabbitMQ安装在docker中,我应该在证书中设置哪个服务器名称?除此之外,还有什么想法吗?