- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在连接到一个服务器,该服务器将向我发送需要逐行处理的流数据。所以我必须解析出单独的行,然后处理每一行。下面的代码似乎工作得很好,但我想知道是否有任何标准的设计模式来做这种事情。或者这是要走的路吗?
队列会引入任何严重的开销吗?我需要它尽可能快速和高效,这也是我远离像 twisted 这样的库的原因。
import socket, multiprocessing
def receive_proc(s, q):
data = ''
while True:
data += s.recv(4096)
if '\n' in data:
lines = data.split('\n')[:-1]
for line in lines:
if len(line) > 0:
q.put(line)
data = data.replace(line+'\n', '', 1)
q = multiprocessing.Queue()
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('127.0.0.1', 1234))
p = multiprocessing.Process(target=receive_proc, args=(s,q))
p.start()
while True:
line = q.get()
# do your processing here
最佳答案
想要远离 twisted 这样的东西肯定有正当理由,但我认为效率不在其中 - 我怀疑它们更有可能以正确的方式进行优化.性能是一头棘手的野兽,瓶颈通常并不在您的想象中,这就是为什么您需要在适当优化之前进行概要分析的原因。例如,框架可能已经努力将更多代码推送到 C 扩展中,这肯定有助于提高性能。如果性能是您的关键动力,那么第三方产品可能是更安全的选择。此外,使用其他人针对各种不同的用例和环境测试和调整的代码存在很大争议 - 如果您最终重新发明了太多的轮子,总会有可能遗漏一些辐条的风险。
但是,您需要做的事情看起来很简单,因此安装和学习框架以及向代码添加另一个运行时依赖项的开销可能不合理。此外,如果您主要受 IO 限制,那么在处理过程中消耗一些额外的 CPU 也不会产生太大影响。在过去,我肯定会避免像扭曲这样的事情,因为我知道自己编写它会更快(就我的时间而言)并且性能会“足够好”。我一直发现 twisted 的回调系统使调试有点棘手——例如,访问错误消息可能有点令人担忧。这绝不是不可能的,许多人都非常成功地使用它,但我个人觉得它太“笨拙”,不适合简单的任务。
我认为在这种情况下,您将接收和处理拆分到它们自己的进程中的想法可能是错误的经济 - 从套接字接收数据非常快,如果您在纯 Python 中进行大量处理,则可能成为主导性能因素。但是,如果不知道你在做什么处理,我不能肯定地说。如果这将是耗时和/或 CPU 密集型的,并且您可以独立于前几行处理每一行,那么这可能是合理的,但您可能希望将处理工作分配给一整套工作进程。根据您现有的代码,这非常简单 - 只需让主进程成为接收方而不是“从属”进程,并创建一个共享一个 Queue
的工作池。每个 worker 都经历一个循环,选择下一个项目并产生结果。每项花费多长时间并不重要,他们只会在下一项可用时获取下一项(Queue
将为您处理)。
但是,如果您的处理循环也主要受 IO 限制(例如写入文件),那么您可能会发现单个进程实际上比将所有内容都插入管道的开销要好。这取决于许多因素,包括您的 CPU 架构(某些系统使 CPU 内核之间的传输比其他系统更昂贵),但最终您不想使用多个进程,除非您非常有信心它会给您带来性能上的胜利。
无论如何,如果循环是 IO 绑定(bind),您可能会发现具有非阻塞 IO 的单个进程是可行的方法。您可以使用 Python 的 select模块来自己做这个,或者你会发现使用像 eventlet 这样的库会更干净或 gevent .
撇开无关 - 你从缓冲区中剥离开始的方法效率很低 - 你不需要使用 replace()
你可以只使用你现有的 split()
,像这样:
while True:
data += s.recv(4096)
if '\n' in data:
lines = data.split('\n')
for line in lines[:-1]:
if len(line) > 0:
q.put(line)
data = lines[-1]
关于python - 这是 python 客户端的有效 TCP/IP 套接字循环吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14490607/
给定的输入是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
我是一名优秀的程序员,十分优秀!