我正在为我工作的办公室开发内部电话系统软件。我们很高兴地使用 Twilio 来管理我们的电话树 - 但希望创建一种更好的方法来监控来电并在来电者与我们的一个人建立联系后转接电话。
我们处于混合(Windows 和 Mac)环境中,因此我选择使用 Python 运行来编写此应用程序的桌面部分。我(大部分时间)仍处于该项目的纸笔阶段。我有一些 Python/TKinter 经验和一些 TCP 套接字经验(使用 CakePHP,而不是 Python),并且有几个关于如何管理我们的服务器(向 Twilio 发出命令)和客户端应用程序之间的数据包传输的问题。
客户端应用程序将向用户显示调用队列中的调用者数量,并允许用户在他们的电话上接听调用,以及将调用者发送回队列(或另一个代理)。以下是我考虑过的两种方法:
方法一
客户端 (Python) 应用程序监听来 self 们 VPS 的 TCP 连接。这将是内存占用最少的,但是已经阅读了this post关于增益大小,特别是
In regards to: "if you have a protocol where the incoming packet length is exactly known, it is obviously preferrable to only read "at most" what is needed for the packet you are dealing with, otherwise you could potentially eat into the next packet and that would be irritating."
This may be preferable for the application developer, but is probably inefficient for the underlying network stack. First, it ties up socket buffer space that can be used for additional network I/Os. Second, each recv() you make means dipping into a system call/kernel space and there is a performance penalty for the transition. It is always preferable to get as much data as you can out of kernel space and into user space with as few system calls as possible and do your message parsing there. This adds more complexity to the application code and message handling but is probably the most efficient.
我真的很矛盾——吃下一包是一回事吗?我如何预测增益大小或我是否需要预测?
方法二
我可以让应用程序每隔 n 秒查询一次“state of the union”。但这似乎很浪费。
正确答案是什么。有什么我想念的吗?
最佳答案
您读过的关于缓冲区大小的帖子讨论了低级别的细节,这些细节对性能的影响很小。这不是您通常应该关心的东西,如果您只知道要使用的协议(protocol)是“tcp”,则更不用说。首先,您需要设计一个基于 TCP 的协议(protocol)。我的意思是您需要以某种方式格式化您的消息。
所以,关于你问的关于“吃下一个数据包”的问题——你忽略了一个事实,即这篇文章讨论了一个协议(protocol)(通过 TCP),该协议(protocol)将数据包长度作为流的一部分,或者每个数据包具有固定/可预测的大小。这些“数据包”只是您的应用程序想要处理的信息单元,您不应将 tcp 缓冲区大小视为问题的一部分。
“吃掉下一个数据包”如果你只是接收太多并且你阅读的部分内容属于下一个数据包 - 如果你决定忽略那个额外的部分,那么你就吃掉它。不过,没有什么能阻止您保存它以备后用。缓冲区大小可以是任何大小,只要您始终在代码中的某个点处理每个接收到的字节即可。
关于“方法 2”,如果我没看错的话那就是轮询,如果你不能做任何其他事情(HTTP 服务器的常见情况),这只是一个好主意
我对这个问题的建议是不要重新发明另一种协议(protocol)来传递消息并使用,例如 zeromq ,这是一个可移植的消息队列库,实际上只是一个使用精心设计的 TCP 协议(protocol)的套接字库。
关于python - 是否有必要传达(或预期)Python Socket TCP Buff 大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17016585/
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI
这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub