尝试从RabbitMQ接收应答时,我收到一个错误。
2015-07-03 09:31:12 [10.1.101.55][-][-][error][PhpAmqpLib\Exception\AMQPTimeoutException] exception 'PhpAmqpLib\Exception\AMQPTimeoutException' with message 'The connection timed out after 30 sec while awaiting incoming data' in /opt/www/site.ll/vendor/php-amqplib/PhpAmqpLib/Wire/AMQPReader.php:130
Stack trace:
#0 /opt/www/site.ll/vendor/php-amqplib/PhpAmqpLib/Wire/AMQPReader.php(147): PhpAmqpLib\Wire\AMQPReader->wait()
#1 /opt/www/site.ll/vendor/php-amqplib/PhpAmqpLib/Wire/AMQPReader.php(105): PhpAmqpLib\Wire\AMQPReader->rawread(7)
#2 /opt/www/site.ll/vendor/php-amqplib/PhpAmqpLib/Connection/AbstractConnection.php(528): PhpAmqpLib\Wire\AMQPReader->read(7)
#3 /opt/www/site.ll/vendor/php-amqplib/PhpAmqpLib/Connection/AbstractConnection.php(568): PhpAmqpLib\Connection\AbstractConnection->wait_frame(30)
#4 /opt/www/site.ll/vendor/php-amqplib/PhpAmqpLib/Channel/AbstractChannel.php(198): PhpAmqpLib\Connection\AbstractConnection->wait_channel(1, 30)
#5 /opt/www/site.ll/vendor/php-amqplib/PhpAmqpLib/Channel/AbstractChannel.php(332): PhpAmqpLib\Channel\AbstractChannel->next_frame(30)
当我尝试从本地pc接收答案时,它可以工作,但在生产服务器上-不能。
为什么,以及我怎样才能修复它。
谢谢!
发布于 2020-10-30 20:30:34
Connection
、Read
和Write
的默认超时时间为3s。在开发过程中,您的请求处理速度比生产过程快,所以您在开发过程中看不到此错误消息。
如果您需要更长的超时时间(例如我),可以在创建AMQPStreamConnection
实例时进行设置
$connection = new AMQPStreamConnection(
'localhost',
5672,
'guest',
'guest',
'/',
false,
'AMQPLAIN',
null,
'en_US',
30, //Connection Timeout
30 // Read/Write Timeout
);
上面的代码将Connection
、Read
和Write
超时设置为30s,这在我的例子中是合理的。
发布于 2021-12-08 14:22:47
确保设置了正确的端口。默认值为5672 (而不是web界面的15672 )。
https://stackoverflow.com/questions/31202756
复制相似问题