健康检查

TCP健康检查

注意:本文是为v1 API编写的,但这些概念也适用于v2 API。它将在未来版本中使用v2 API重写。

执行的匹配类型如下(这是MongoDB运行健康检查请求和响应):

  1. {
  2. "send": [
  3. {"binary": "39000000"},
  4. {"binary": "EEEEEEEE"},
  5. {"binary": "00000000"},
  6. {"binary": "d4070000"},
  7. {"binary": "00000000"},
  8. {"binary": "746573742e"},
  9. {"binary": "24636d6400"},
  10. {"binary": "00000000"},
  11. {"binary": "FFFFFFFF"},
  12. {"binary": "13000000"},
  13. {"binary": "01"},
  14. {"binary": "70696e6700"},
  15. {"binary": "000000000000f03f"},
  16. {"binary": "00"}
  17. ],
  18. "receive": [
  19. {"binary": "EEEEEEEE"},
  20. {"binary": "01000000"},
  21. {"binary": "00000000"},
  22. {"binary": "0000000000000000"},
  23. {"binary": "00000000"},
  24. {"binary": "11000000"},
  25. {"binary": "01"},
  26. {"binary": "6f6b"},
  27. {"binary": "00000000000000f03f"},
  28. {"binary": "00"}
  29. ]
  30. }

在每个健康检查周期中,所有“发送”字节都会发送到目标服务器。每个二进制块可以是任意长度的,并且在发送时只是连接在一起。(分成多个块用于可读性)。

在检查响应时,执行“模糊”匹配,使得必须找到每个二进制块,并且按照指定的顺序,但不必是连续的。因此,在上面的例子中,在“EEEEEEEE”和“01000000”之间的响应中可以插入“FFFFFFFF”,并且检查仍然通过。这样做是为了支持在响应中插入非确定性数据(如时间)的协议。

若需要一个更复杂的健康检查模式,如发送/接收/发送/接收目前还不支持。

如果“接收”是一个空数组,则Envoy将执行“仅连接”TCP健康检查。在每个周期中,Envoy将尝试连接到上游主机,并且如果连接成功,则认为它是成功的。为每个健康检查周期创建一个新的连接。

返回