- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个设计问题:
我有两个线程,一个心跳/控制线程和一个消息处理程序线程。
两者共享同一个套接字,但是 messageHandler 线程只发送消息而从不接收消息。心跳线程发送和接收(接收消息并对心跳使用react)。
问题是我不确定这是否安全。我自己没有实现机制来查看套接字是否正在使用。 那么通过 python 共享套接字是否自动线程安全?
此外,如果不是,我将它们放在单独的线程中的原因是心跳比消息处理更重要。这意味着如果它被消息淹没,它仍然需要进行心跳。因此,如果我必须实现 bolt ,如果我的心跳/控制线程需要发送心跳,我是否可以确定优先级?
最佳答案
代替使用第三个线程的更好方法是使用 threading.Lock()
来保护套接字资源,因为这消除了对第三个线程的需要。与拥有第三个线程相比,您的开销和延迟更少。
import threading
lock = threading.Lock()
def sendfunction(sock, data):
with lock:
sock.send(data)
您可以从任一线程调用它,但一次只允许一个线程调用 sock.send
。当一个线程到达已被另一个线程锁定的锁时,它会休眠直到另一个线程释放锁,然后它会获取锁并重复该过程。
threading 模块包含Lock
、RLock
和Condition
,它们在处理多线程时都非常有用,您将发现花时间熟悉它们及其用法非常值得。
在处理每条消息之前,您可以通过检查当前时间与上次发送心跳的时间来将心跳合并到消息处理中,这样可以防止被消息淹没导致无法发送心跳。问题是如果您的消息处理代码没有运行,则不会发送心跳。您可以通过让您的消息处理代码按时间间隔获取虚拟消息以允许它检查是否需要发送心跳并忽略该虚拟消息来缓解这种情况。
您应该尽量少使用线程(以单线程为目标),但在您的情况下,线程可能没问题,因为它大部分时间都在休眠。但是,您不应使用守护线程,因为它们无法正确关闭。尽管如果没有正确关闭,在您的情况下可能不存在损坏,但它仍然可能引发某种看起来很糟糕的故障(错误消息)。
我不同意多套接字方法,因为我认为它实际上会使情况复杂化。您会发现许多类型的网络服务/应用程序将心跳和消息合并到单个套接字字节流中。
关于Python:套接字和线程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11177018/
我使用下拉菜单提供一些不同的链接,但我希望这些链接在同一选项卡中打开,而不是在新选项卡中打开。这是我找到的代码,但我对 Javascript 非常缺乏知识 var urlmenu = docume
我对 javascript 不太了解。但我需要一个垂直菜单上的下拉菜单,它是纯 JavaScript,所以我从 W3 复制/粘贴脚本:https://www.w3schools.com/howto/t
我已经坐了 4 个小时,试图让我的导航显示下 zipper 接垂直,但它继续水平显示它们。我无法弄清楚为什么会发生这种情况或如何解决它。 如果有人能告诉我我做错了什么,我将不胜感激。我有一个潜移默化的
我正在尝试创建选项卡式 Accordion 样式下拉菜单。我使用 jQuery 有一段时间了,但无法使事件状态达到 100%。 我很确定这是我搞砸的 JS。 $('.service-button').
对于那些从未访问过 Dropbox 的人,这里是链接 https://www.dropbox.com/ 查看“登录”的下拉菜单链接。我如何创建这样的下 zipper 接? 最佳答案 这是 fiddle
我正在制作一个 Liferay 主题,但我在尝试设计导航菜单的样式时遇到了很多麻烦。我已经为那些没有像这样下拉的人改变了导航链接上的经典主题悬停功能: .aui #navigation .nav li
如果您将鼠标悬停在 li 上,则会出现一个下拉菜单。如果您将指针向下移至悬停时出现的 ul,我希望链接仍然带有下划线,直到您将箭头从 ul 或链接移开。这样你就知道当菜单下拉时你悬停在哪个菜单上。 知
我有一个带有多个下拉菜单的导航栏。因此,当我单击第一个链接时,它会打开下拉菜单,但是当我单击第二个链接时,第一个下拉菜单不会关闭。 (所以如果用户点击第二个链接我想关闭下拉菜单) // main.js
我正在尝试制作一个导航下拉菜单(使用 Bootstrap 3),其中链接文本在同一行上有多个不同的对齐方式。 在下面的代码中,下拉列表 A 中的链接在 HTML 中有空格字符来对齐它们,但是空白被忽略
我希望有人能帮我解决这个 Bootstrap 问题,因为我很困惑。 有人要求我在底部垂直对齐图像和其中包含图像的链接。 我面临的问题是他们还希望链接在链接/图像组合上具有 pull-right,这会杀
我正在构建一个 Rails 应用程序,并希望指向我的类的每个实例的“显示”页面的链接显示在“索引”页面的下拉列表中。我目前正在使用带有 options_from_collection_for_sele
我有以下 Bootstrap3 导航菜单 ( fiddle here )。我想设置“突出显示”项及其子链接与下拉列表 1 和 2 链接不同的链接文本(和悬停)的样式。我还希望能够以不同于 Highli
我对导航栏中的下拉菜单有疑问。对于普通的导航链接(无下拉菜单),我将菜单文本放在 H3 中,但是当我尝试对下 zipper 接执行相同操作时,箭头不在标题旁边,而是在标题下方。我决定用 span 替换
我是一名优秀的程序员,十分优秀!