用心跳检测死TCP连接

介绍

网络可能会以许多方式失败,有时会很细微(例如高比率的数据包丢失)。中断的TCP连接需要比较长时间(例如,在Linux上默认是大约11分钟)才能被操作系统检测到。AMQP 0-9-1 提供心跳功能,以确保应用层及时发现连接中断(以及完全无响应的对等体)。心跳也可以防御某些网络设备,当一段时间内没有任何活动时,可能会终止空闲的TCP连接。

心跳超时间隔

心跳超时值的定义为:在RabbitMQ与客户端之间应该将对等TCP连接视作为无法访问(down)的时间段之后。此值在连接时由客户端和RabbitMQ服务器之间协商。客户端必须配置请求心跳。在RabbitMQ 3.0或更高版本中,Broker 将会默认尝试心跳值(尽管客户端仍可否决)。超时时间的单位为秒,默认值为 60 (在3.5.5之前为 580)

每间隔大约 timeout/2 秒发送一次心跳帧。在两次丢失心跳后,TCP对等体就被认为是无法访问的。不同的客户端对此有不同的显示,但TCP连接将会被关闭。当客户端检测到由于心跳而无法访问 RabbitMQ 节点时,需要重新连接。

任何流量(例如协议操作、发布的消息、确认)会计数有效的心跳数。客户端可以选择发送心跳帧,而不管连接是否有其他流量,但有些只在必要时才进行。

可以通过将超时间隔设置为 0 来禁用心跳。这不是推荐的做法。

Java客户端开启心跳

要在 Java 客户端开启心跳超时,请在创建连接之前使用 ConnectionFactory#setRequestedHeartbeat 进行设置。

ConnectionFactory cf = new ConnectionFactory();

// set the heartbeat timeout to 60 seconds

cf.setRequestedHeartbeat(60);

请注意,如果 RabbitMQ 服务器配置了非零心跳超时值(在 3.6.x 版本开始为默认值),则客户端只能比该值低,而不能比它高。

.NET 客户端开启心跳

要在.NET客户端中配置心跳超时,请在创建连接之前使用 ConnectionFactory.RequestedHeartbeat 进行设置:

var cf = new ConnectionFactory();

// set the heartbeat timeout to 60 seconds

cf.RequestedHeartbeat = 60;

低超时值与错误判断

由于瞬时网络拥塞、短时间服务器流量控制等原因,将心跳超时值设置得太低可能导致错误的判断(对等体被认为不可用,但实际上它是可用的)。在选择超时值时,应该考虑这一点。

来自用户和客户端库维护者的这几年有价值的反馈表明,低于5秒的值很可能导致误报,1秒或更低的值则非常可能会这样子做。5到20秒范围内的值对大多数环境是最佳的选择。

在 STOMP 中的心跳

STOMP1.2 包含心跳 。在STOMP中,心跳超时可以是不对称的:也就是说,客户端和服务器可以使用不同的值。 RabbitMQ STOMP插件完全支持此功能。

STOMP中的心跳可以选择性加入。要开启它们,请在连接时,使用 heart-beat 头部。参见 STOMP 规范 的一个例子。

在 MQTT 中的心跳

MQTT 3.1.1 包含心跳 ,用不同的名称(keepalives)来表示。RabbitMQ MQTT插件完全支持此功能。

MQTT在 Keepalives 可以选择性加入。要开启它们,请在连接时设置 keepalive 间隔。请查看你的 MQTT 客户端文档来获取例子。

Shovel 和 Federation 插件中的心跳

Shovel 和 Federation 插件:用来进行 Erlang 客户端连接到 RabbitMQ 节点。因此,它们可以被配置为使用期望的心跳值。

心跳与TCP keepalives

TCP包含一个类似于心跳的(也称为 keepalive) 的机制,它覆盖上面的消息协议和 net tick 超时之上:TCP keepalives . 由于默认值不足,对于消息传输协议,TCP keepalive 并不适用,甚至是适得其反。然而,通过适当的调整,在不能期望应用程序开启心跳或使用合理值的环境下,它们可以作为额外的防御机制。详情请看 网络指南

JAVA调用mq时做心跳检测,[翻译]RabbitMQ 心跳相关推荐

  1. 心跳检测以及应用层心跳包机制设计

    博主联系方式: QQ:1540984562 微信:wxid_nz49532kbh9u22 QQ交流群:892023501(嵌入式方向) QQ交流群:856398158(后端方向) 目录 心跳检测应用场 ...

  2. php心跳检测实时数据,心跳检测 · swoole手册 · 看云

    # 心跳 注意:长链接应用必须加心跳,否则链接可能由于长时间未通讯被路由节点强行断开. 心跳作用主要有两个: 1.客户端定时给服务端发送点数据,防止连接由于长时间没有通讯而被某些节点的防火墙关闭导致连 ...

  3. 调用百度AipFace做人脸检测

    需要注意的几个问题: 1.需要在百度人脸识别云平台注册账号并登陆:https://login.bce.baidu.com/?account= 然后创建人脸检测应用,则会生成相应的APP_ID API_ ...

  4. java调用mq发送文件_谁有mq发送接收文件的java代码

    mq安装目录下有简单的发送和接收代码,具体在samp目录下有一些不同语言的源代码,可以借鉴. 类介绍: SendMSG:消息发送类. Main():主方法. SendMSG():消息发送方法. 方法描 ...

  5. java远程执行jmi,java调用matlab 时出现java.lang.NullPointerException错误

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 这是错误日志 Error occurred during initialization of VM Unable to load ZIP library: ...

  6. matlab斜杠报错,java调用matlab 时出现java.lang.NullPointerException错误

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 这是错误日志 Error occurred during initialization of VM Unable to load ZIP library: ...

  7. matlab java错误,java调用matlab 时出现java.lang.NullPointerException错误

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 这是错误日志 Error occurred during initialization of VM Unable to load ZIP library: ...

  8. Android通过WebSocket建立一个长连接(带心跳检测)从服务器端接收消息

    最近公司要做一款内部使用的工具类app,方便销售部门打电话(其实就是在后台有好多用户数据,之前销售部门同事拨打电话,需要自己从销售后台查看用户手机号等信息,然后自己拿自己手机拨号,然后打出去.现在想实 ...

  9. Netty学习(七):心跳检测机制

    一.什么是心跳检测机制 所谓心跳, 即在 TCP 长连接中, 客户端和服务器之间定期发送的一种特殊的数据包, 通知对方自己还在线, 以确保 TCP 连接的有效性. 心跳机制主要是客户端和服务端长时间连 ...

最新文章

  1. uvalive4842(AC自动机+DP)
  2. 使用绝对布局的方法创建一个登录密码验证的简易窗口
  3. Linux 监控命令 free
  4. python文本内容怎么转换成字典_怎么把照片上的文字转换成文本?照片转换文字神器来了...
  5. 功率曲线k值_特性曲线在参数计算中的应用
  6. Python库:Python OS库
  7. 第 2 章 MybatisPlus 通用 CRUD
  8. 【更新中…】Latex语法总结
  9. spss实现主成分分析
  10. html如何定义mime类型的作用,自定义mime类型、mime类型介绍
  11. 电路设计中发光二极管用作指示灯时的限流电阻如何选择
  12. mir2ei源码韩文乱码处理
  13. ContextCaptureMaster/Smart3D集群设置经验分享
  14. 神经网络的发展历史概述
  15. 智齿徐懿 | 一个“外行”眼中的呼叫中心系统未来
  16. Python网络爬虫:下载漫画的正确姿势
  17. 金融交易报文ISO8583协议
  18. matlab仿真动画,MATLAB图形及三维动画仿真设计.ppt
  19. 微信小程序嵌套iframe_H5嵌入微信小程序踩过的坑
  20. 【蓝桥杯选拔赛真题27】Scratch报数 少儿编程scratch蓝桥杯选拔赛真题讲解

热门文章

  1. iOS 13上传ipa报错
  2. C语言-大写字母查找
  3. 裸辞一时爽,断缴火葬场——细说社保的转移、续保与自缴
  4. pytorch 利用tensorboard显示loss,acc曲线等
  5. 提高用户量的3个套路
  6. 搭建DNS服务器做域名解析
  7. yii rules最全规则
  8. CefInitialize崩溃 Cef白屏
  9. 庞东升:我是如何从红杉融资的
  10. 国内外视频编解码标准体系-横向纵向对比全球三个体系标准