AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 401713
Accepted
dogglebones
dogglebones
Asked: 2012-06-24 21:56:27 +0800 CST2012-06-24 21:56:27 +0800 CST 2012-06-24 21:56:27 +0800 CST

设计持久异步 TCP 协议

  • 772

我收集了一些网站,这些网站需要将时间敏感的消息发送到我都市区的主机,每个主机都有自己的一般动态 IP。直到现在,我一直在按照脚本小子的方式这样做:

  1. 每台主机运行一个(s)FTP服务器,或者一个HTTP(s)服务器,并相应地有一个由其网关开放的特定端口。

  2. 每台主机都运行一个程序,该程序监视某个文件夹并在出现给定扩展名的新文件时自动打开或打印或执行()。使用动态 DNS 服务提供动态 IP 地址。

  3. 每个网站都执行 cURL 或 fsockopen 或其他任何操作,并根据需要直接与其接收者通信。


这种方法非常可靠,但是出现了明显的问题并且需要解决这种情况。

如前所述,这些消息对时间很敏感,需要在最终用户提交后的几分钟内检测到故障。我正在做的是构建一个消息传递协议。它将在我控制的机器和连接上运行。就服务而言,网站和主机之间没有区别——只有一个设备向另一个设备发送消息。

这就是我现在所处的位置。我有一个骨架服务器和一个骨架客户端。他们可以协商高质量的身份验证和加密。(TCP) 连接是持久的和异步的,并且可以处理定界(即,读到\r\n或其他)以及长度前缀(即,恰好读取n字节)的消息。除非有人给我更好的主意,否则我想我会将消息作为字节数组处理。


所以我正在寻找有关如何在应用程序级别对协议本身进行建模的建议。我将主要传输 XML 和 DLM 类型的文件,以及诸如“握手”和“某某人在线吗?”之类的控制消息。等等。我的思路真的有什么愚蠢的地方吗?或者我在开始之前应该阅读的任何内容?诸如此类的事情——请和谢谢。


更新:

@mrdenny's 是我最终采用的方法,所以他得到了答案。@Henrik 的 ZeroMQ 建议也适用,但我基本上已经编写了代码并且将我的代码切换为第 3 方框架并没有真正帮助设计应用程序层。最后,我发现了 HTTP 的用途是多么的多,而且真的不需要自己开发协议。除了它们已经在做的 text/html 之外,只需让网站呈现内容类型 application/json(或 xml,如果需要),并让收件人发出出站 Web 请求,而不是监听和响应文件系统更新。消除了上面描述的所有“脚本小子”开销,工作更可靠,实现更好的错误处理,易于构建等等。

security tcp web-applications network-design network-protocols
  • 3 3 个回答
  • 661 Views

3 个回答

  • Voted
  1. Henrik
    2012-06-25T08:43:34+08:002012-06-25T08:43:34+08:00

    ZeroMQ被设计为异步传输/消息协议。

    如果您的一个节点出现故障,它将重新建立 ZMQ-Socket 并在到目标端点的路由恢复时继续发送其消息。性能很好,根据其 IRC 频道,它现在经过充分测试,可以在 WAN 上使用。

    • 3
  2. Best Answer
    mrdenny
    2012-06-25T08:21:49+08:002012-06-25T08:21:49+08:00

    您不能只使用 Web 方法和 HTTP(或 HTTPS)调用来在机器之间传输数据的原因是什么?

    • 1
  3. TomTom
    2012-06-25T08:34:47+08:002012-06-25T08:34:47+08:00

    查看 FIX(如 FIX 协议)以获取此类协议的示例。您可以只使用 FIX 和一个开源库并自己定义所有字段。FIX 用于金融交易。

    但它应该给你一个不错的主意。如果需要,FIX 还可以/确实处理诸如持久消息之类的项目,以防连接中断。

    • 0

相关问题

  • OpenSSH 漏洞 [重复]

  • 选择什么安全套件?

  • 安全地授予对 SQL 2005 复制监视器的访问权限以创建快照

  • SSH 服务器零日漏洞利用 - 保护自己的建议

  • 如何将安全组添加到正在运行的 EC2 实例?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve