amqp协议链接异常怎么排查

发布时间:2022-02-24 16:39:28 作者:iii
来源:亿速云 阅读:201

这篇文章主要介绍“amqp协议链接异常怎么排查”,在日常操作中,相信很多人在amqp协议链接异常怎么排查问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”amqp协议链接异常怎么排查”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

amqp协议链接异常怎么排查

前言

amqp是一种通用的消息队列数据传输协议,典型的MQ应用RabbitMQ就实现了amqp协议,所以,我们在使用amqp-client链接rabbitmq时,可以使用amqp的链接协议连接rabbitmq。但是博主在尝试使用amqp协议链接时,碰到了一个隐藏的连接协议规范问题,故记录在此。

问题背景

异常信息

异常一:

11:49:12.329 [AMQP Connection 192.168.1.226:5672] ERROR com.rabbitmq.client.impl.ForgivingExceptionHandler - An unexpected connection driver error occured
java.net.SocketException: socket closed
	at java.net.SocketInputStream.socketRead0(Native Method) ~[?:1.8.0_77]
	at java.net.SocketInputStream.socketRead(SocketInputStream.java:116) ~[?:1.8.0_77]
	at java.net.SocketInputStream.read(SocketInputStream.java:170) ~[?:1.8.0_77]
	at java.net.SocketInputStream.read(SocketInputStream.java:141) ~[?:1.8.0_77]
	at java.io.BufferedInputStream.fill(BufferedInputStream.java:246) ~[?:1.8.0_77]
	at java.io.BufferedInputStream.read(BufferedInputStream.java:265) ~[?:1.8.0_77]
	at java.io.DataInputStream.readUnsignedByte(DataInputStream.java:288) ~[?:1.8.0_77]
	at com.rabbitmq.client.impl.Frame.readFrom(Frame.java:91) ~[amqp-client-5.4.3.jar:5.4.3]
	at com.rabbitmq.client.impl.SocketFrameHandler.readFrame(SocketFrameHandler.java:164) ~[amqp-client-5.4.3.jar:5.4.3]
	at com.rabbitmq.client.impl.AMQConnection$MainLoop.run(AMQConnection.java:596) [amqp-client-5.4.3.jar:5.4.3]
	at java.lang.Thread.run(Thread.java:745) [?:1.8.0_77]
Disconnected from the target VM, address: '127.0.0.1:0', transport: 'socket'

异常二:

java.lang.IllegalArgumentException: Multiple segments in path of AMQP URI: /%2Fapp/kl
	at com.rabbitmq.client.ConnectionFactory.setUri(ConnectionFactory.java:348)
	at com.rabbitmq.client.ConnectionFactory.setUri(ConnectionFactory.java:370)
	at com.jd.blockchain.consensus.mq.factory.RabbitFactory.initConnectionFactory(RabbitFactory.java:42)
	at com.jd.blockchain.consensus.mq.factory.RabbitFactory.main(RabbitFactory.java:52)

原因分析

异常一分析:

首先抛出上面异常,是因为rabbitmq服务器拒绝了你的操作,中断了你的连接,所以一般应用在刚启动建立连接时并不会报错,而是在发送数据时报链接的错误。拒绝操作的原因是当前链接的账号没有vhost的操作权限。那么基于这个原因,很可能是如下的问题:

1、当前账号没有权限

2、当前账号没有操作具体的vhost的权限

网上很多人的问题都是第一个,忘记给账号赋值权限了,博主的问题是因为amqp的连接串有问题,导致链接了错误的vhost,所以表象就是没有权限。rabbitmq默认的vhost是“/”,amqp://keking:kk123456@192.168.1.226:5672/连接串代表的vhost并不是“/”,而是“”。

异常二分析:

针对异常二的问题,在amqp链接协议中,vhost部分的斜杆目录需要使用%2f代替,不然客户端在解析URI的时候,分割链接时就会抛出协议不正确的异常

解决问题

amqp链接协议详情如下:

amqp协议链接异常怎么排查

所以,要链接到“/”的vhost,正确的链接应该要在尾部加上“%2f”,如

“amqp://keking:kk123456@192.168.1.226:5672/%2f”

到此,关于“amqp协议链接异常怎么排查”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

推荐阅读:
  1. 深入剖析 RabbitMQ —— Spring 框架下实现 AMQP 高级消息队列协议
  2. AMQP——Advanced Message Queuing Protocol(高级消息队列协议)小结

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

amqp

上一篇:Java中怎么用策略模式实现条件判断

下一篇:php中字符串如何去掉括号

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》