- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个控制电话系统的服务器端协议(protocol),我已经实现了一个与其通信的客户端库,该库现在正在生产中,但是目前我的系统存在一些问题,所以我正在考虑重写它。
我的客户端库目前是用 Java 编写的,但我正在考虑用 C# 和 Java 重写它,以允许不同的客户端访问相同的后端。
消息以关键字开头,包含多个字节的元数据,然后是一些数据。消息始终以消息结束字符结束。
客户端和服务器之间的通信是双工的,通常采用客户端请求的形式,该请求会引发服务器的多个响应,但也可以是通知。这些消息被标记为位于:
C:命令
P:待处理(服务器仍在处理请求)
D:数据数据作为响应
R:响应
B:繁忙(服务器太忙,目前无法处理响应)
N:通知
我当前的体系结构会解析每条消息并生成一个线程来处理它,但是我发现某些通知的处理顺序不正确,这给我带来了一些麻烦,因为它们必须以相同的顺序处理他们到达了。
双工消息往往采用以下消息格式:客户端 -> 服务器:命令服务器 -> 客户端:待定(可选)服务器 -> 客户端:数据(可选)服务器 -> 客户端:响应(消息数据中的第二个条目表示这是否是错误)
我已经使用该协议(protocol)一年多了,我从未见过忙碌消息,但这并不意味着它们不会发生。
服务器还可以向客户端发送通知,并且有一些响应消息是由服务器上的事件自动触发的,因此无需发出相应的命令即可发送它们。
一些通知消息将作为消息序列的一部分到达,这些消息是相关的,例如:
通知名称 M00001通知名称 M00001通知名称 M00000
字符串 M0000X 表示要么还有更多数据即将到来,要么消息已结束。
目前 tcp 客户端相当愚蠢,它只是生成一个线程,通知订阅者消息已收到的事件,该事件特定于消息关键字和消息类型(因此数据、响应和通知单独处理)这对于数据和响应消息相当有效,但与通知消息一起失败,因为它们似乎以快速顺序到达,并且竞争条件有时似乎导致消息端在具有数据的消息端之前被处理被处理,导致消息数据丢失。
鉴于这个关于系统如何工作的描述非常糟糕,您将如何编写客户端传输代码?
元数据没有消息号,而且我无法控制底层协议(protocol),因为它是由供应商提供的。
最佳答案
消息必须按照接收顺序进行处理的要求几乎强制了生产者/消费者设计,其中监听器从客户端获取请求,解析它们,然后将解析后的请求放入队列中。一个单独的线程(消费者)按顺序从队列中获取每条消息,对其进行处理,并向客户端发送响应。
或者,消费者可以将结果放入队列中,以便另一个线程(可能是监听器线程?)可以将结果发送到客户端。在这种情况下,您将有两个生产者/消费者关系:
Listener -> event queue -> processing thread -> output queue -> output thread
在.NET中,使用BlockingCollection
来处理队列,这种事情很容易实现。不知道Java中是否有类似的东西。
多消息请求的可能性使事情变得有点复杂,因为监听器似乎必须缓冲消息,直到请求的最后一部分进入,然后才能将整个事物放入队列。
对我来说,生产者/消费者设计的美妙之处在于,它强制程序的不同部分之间进行硬分离,使每个部分更容易调试,并最大限度地减少共享状态导致问题的可能性。这里唯一稍微复杂的部分是,您必须将连接(套接字或其他)作为在队列中共享的消息的一部分包含在内,以便输出线程知道将响应发送到哪里。
我不清楚您是否必须按照收到的顺序处理所有消息,或者您是否只需要按照正确的顺序处理任何特定客户端的消息。例如,如果您有:
Client 1 message A
Client 1 message B
Client 2 message A
在处理来自客户端 1 的第二条消息之前,可以先处理来自客户端 2 的第一条消息吗?如果是这样,那么您可以通过使用逻辑上的多个队列(每个客户端一个)来提高吞吐量。然后你的“消费者”就变成了多线程。您只需确保每个客户端在任何时候只处理一条消息。
关于c# - 开发基于 TCP/IP 的消息客户端的建议,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5043814/
给定的输入是192.168.3.78/27 输入可以是任意C类ip地址,以上ip为例进行尝试 预期输出应显示从 192.168.3.65 到 192.168.3.94 的所有 IP如下 192.168
您好,我是一名 javascript 菜鸟,正在为 IP 范围编写验证器。例如,1.1.1.1-2.2.2.2 是一个有效范围,但我想确保第一个 IP 不大于第二个 IP。 2.2.2.2-1.1.1
在 MySQL 数据库中存储多种 IP 类型的最佳方式是什么: - 单一 IP (123.123.123.123) - IP 范围 (123.123.123.1 - 123.123.123.121)
所以我有一个带有子网的 IP:8.8.8.0/24 我如何将其转换为 8.8.8.0 和 8.8.8.255(实际上是它们的 ip2long 结果) 在 PHP 和 JavaScript 中 最佳答案
我有 Windows7 作为我的基本操作系统。最重要的是,我在 Ubuntu 上安装了 Virtual Box。我希望 ubuntu 获得与我的基本操作系统(Win7)相同的 IP 地址。我如何实现这
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
阅读后List of IP Space used by Facebook : “真实”列表是最后一个答案,但我想知道 Igy(答案标记为解决方案)如何通过将连续的类添加到更大的类中来大幅缩小列表(通过
我正在开发一个 web 应用程序,我已经在我的本地主机中创建了这个项目,但是网络用户需要访问我的项目,我不想给他们一个不友好的 ip 地址,所以我想用户访问一个名称例子 http://myprojec
有人可以向我解释 Azure 在逻辑应用程序的出站 IP 地址之间不同的新方式之间的区别。 我认为文档在对该问题的正确解释方面非常精简。读起来听起来好像 IP 地址在逻辑应用程序中具有完全相同的作用。
我正在尝试熟悉一个项目中java中的数据报系统,目前,我们只使用UDP包。 为了发送消息,我们在 DatagramPacket 上设置目标 IP。 /* * The fields o
我有一个 Java 服务器,当我获得连接时,我需要检查 IP 是本地 IP 还是公共(public) IP。当它是我自己的本地 IP 时,我可以检测到它,但我在使用其他本地 IP 时遇到了一些问题。J
所以我在网上看到了很多例子,这些例子展示了如果你知道起始 IP 和结束 IP 如何获得完整的 IP,但我需要的是在提供后告诉我完整的 IP 范围带有起始 IP 和所需 IP 地址数的代码。 因此,例如
我创建了一个 python 项目,用于扫描 IP 范围(即 x.y.z.0/24)并返回在线主机列表。它将在线主机列表保存到仅包含 IP 的文件中(即 ['192.168.0.1'、'192.168.
如果用户的 ip 在某个 IP 范围之间,我正在使用重定向。但是,我正在使用多个 ip 范围,所以我想知道执行此操作的最佳方法。我目前正在使用它来重定向, 但是如果 IP 范围是 72.122.166
好的,现在是星期五下午,我度过了漫长的一周,希望能得到一些帮助!目前,我有一个 IP 范围列表,如下所示: List ipRanges = new List(); ipRanges.Add(new I
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
下面是我的 CloudFormation 模板的片段,用于将弹性 IP 地址与网络接口(interface)的主 IP 相关联: "MyInterfaceSelfEipAssociat
我在 Azure 上创建了 Python 函数,该函数调用外部 API 服务,该服务仅允许访问白名单 IP。 根据 Microsoft 文档 ( https://learn.microsoft.com
我在 Azure 上创建了 Python 函数,该函数调用外部 API 服务,该服务仅允许访问白名单 IP。 根据 Microsoft 文档 ( https://learn.microsoft.com
我在我的 CentOS 5 x86_64 中使用 IP 别名。为简化此示例:IP 地址 A 是 eth0 地址,IP 地址 B 是 eth0:0地址。我有 2 个 Apache 实例(版本 2.2.3
我是一名优秀的程序员,十分优秀!