- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建一种使用UNIX域套接字在多个进程之间进行通信以传输数据的方法。有2个程序(progserv.py和progclient.py),每个程序都有N个线程(此示例有4个),每个线程在另一个进程上与相应的线程通信。 progclient.py发送datetime.datetime对象的“挑剔”形式。 progserv.py接收数据并确定通信延迟。这里的想法是找到进程间数据传输中的通信延迟。
我面临的问题是,随着N值的增加,延迟从不到1毫秒增加到有时超过250毫秒。延迟时间不一致,并且波动很大。
progserv.py代码:
import string
import random
import threading
import time
import os
import traceback
import socket
import pickle
from datetime import datetime
def worker(num):
addr = './tmp'+str(num)
logstr = "SERVER"+str(num)+":"
if os.path.exists(addr):
os.unlink(addr)
try:
msock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM, 0)
msock.bind(addr)
msock.listen(1)
sock,_ = msock.accept()
sock.setblocking(0)
msock.close()
except:
print (logstr,"Error opening the socket for listening.Trace:", traceback.format_exc())
return
print (logstr,"Socket connection with client done")
buf=list()
count=1
while True:
try:
data = sock.recv(1500)
if len(data)<=0:
print (logstr,"Peer end probably closed down the connection")
break
else:
try:
d=(datetime.now()-pickle.loads(data)).total_seconds()*1000
buf.append((count,d))
count+=1
#print (logstr,"Received ",str(count-1),"packets")
except:
pass
except socket.error:
if len(buf)>0:
c,data=buf.pop(0)
print (logstr,"COUNTER=",c," DELTA=",data,"msec")
except:
print (logstr,"Exception in receiving data. Trace:", traceback.format_exc())
break
if isinstance(sock, socket.socket):
sock.close()
if isinstance(msock, socket.socket):
msock.close()
def main():
server_count=5
threads=list()
for i in range(server_count):
t=threading.Thread(target=worker, args=(i,))
threads.append(t)
t.start()
print ("MAIN: Started thread index",i)
time.sleep(0.1)
for t in threads:
t.join()
if __name__=='__main__':
main()
import traceback, os, time, random, socket
import threading, pickle
from datetime import datetime
def worker(num):
addr = './tmp'+str(num)
logstr="CLIENT"+str(num)+":"
try:
sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM, 0)
sock.connect(addr)
sock.setblocking(0)
except:
print (logstr,"Error opening the socket for connection. Trace:", traceback.format_exc())
return
while True:
try:
d=datetime.now()
bytes=sock.send(pickle.dumps(d))
if bytes<=0:
print (logstr,"Peer end probably closed down the connection")
break
else:
print (logstr,"Sent",bytes,"bytes")
except socket.error:
pass
except:
print (logstr,"Exception during sending. Trace:", traceback.format_exc())
break
time.sleep(1)
if isinstance(sock, socket.socket):
sock.close()
def main():
client_count=5
threads=list()
for i in range(client_count):
t=threading.Thread(target=worker, args=(i,))
threads.append(t)
t.start()
print ("CLIENT : Started thread index",i)
time.sleep(0.1)
for t in threads:
t.join()
if __name__=='__main__':
main()
MAIN: Started thread index 0
MAIN: Started thread index 1
MAIN: Started thread index 2
MAIN: Started thread index 3
MAIN: Started thread index 4
SERVER0: Socket connection with client done
SERVER0: COUNTER= 1 DELTA= 0.7969999999999999 msec
SERVER1: Socket connection with client done
SERVER1: COUNTER= 1 DELTA= 0.28200000000000003 msec
SERVER2: Socket connection with client done
SERVER3: Socket connection with client done
SERVER2: COUNTER= 1 DELTA= 258.839 msec
SERVER4: Socket connection with client done
SERVER3: COUNTER= 1 DELTA= 238.006 msec
SERVER4: COUNTER= 1 DELTA= 477.099 msec
SERVER0: COUNTER= 2 DELTA= 0.175 msec
SERVER2: COUNTER= 2 DELTA= 0.174 msec
SERVER1: COUNTER= 2 DELTA= 108.28 msec
SERVER4: COUNTER= 2 DELTA= 35.966 msec
SERVER3: COUNTER= 2 DELTA= 146.63899999999998 msec
SERVER1: COUNTER= 3 DELTA= 76.92 msec
SERVER2: COUNTER= 3 DELTA= 116.096 msec
SERVER0: COUNTER= 3 DELTA= 317.726 msec
SERVER3: COUNTER= 3 DELTA= 15.792 msec
SERVER4: COUNTER= 3 DELTA= 294.577 msec
SERVER0: COUNTER= 4 DELTA= 6.123 msec
SERVER1: COUNTER= 4 DELTA= 95.69999999999999 msec
SERVER2: COUNTER= 4 DELTA= 0.434 msec
SERVER4: COUNTER= 4 DELTA= 63.32599999999999 msec
SERVER3: COUNTER= 4 DELTA= 322.351 msec
SERVER0: COUNTER= 5 DELTA= 185.03300000000002 msec
SERVER1: COUNTER= 5 DELTA= 84.869 msec
SERVER2: COUNTER= 5 DELTA= 33.532 msec
SERVER3: COUNTER= 5 DELTA= 101.01400000000001 msec
SERVER4: COUNTER= 5 DELTA= 152.035 msec
SERVER0: COUNTER= 6 DELTA= 33.533 msec
SERVER2: COUNTER= 6 DELTA= 0.501 msec
SERVER1: COUNTER= 6 DELTA= 101.59400000000001 msec
SERVER3: COUNTER= 6 DELTA= 91.584 msec
SERVER4: COUNTER= 6 DELTA= 32.779999999999994 msec
SERVER1: COUNTER= 7 DELTA= 42.009 msec
SERVER0: COUNTER= 7 DELTA= 142.716 msec
SERVER2: COUNTER= 7 DELTA= 137.214 msec
SERVER3: COUNTER= 7 DELTA= 124.629 msec
SERVER4: COUNTER= 7 DELTA= 190.025 msec
SERVER0: COUNTER= 8 DELTA= 0.9859999999999999 msec
SERVER1: COUNTER= 8 DELTA= 160.696 msec
SERVER2: COUNTER= 8 DELTA= 60.282000000000004 msec
SERVER4: COUNTER= 8 DELTA= 0.617 msec
SERVER3: COUNTER= 8 DELTA= 169.09 msec
SERVER0: COUNTER= 9 DELTA= 129.679 msec
SERVER1: COUNTER= 9 DELTA= 107.504 msec
SERVER2: COUNTER= 9 DELTA= 8.319999999999999 msec
SERVER3: COUNTER= 9 DELTA= 97.829 msec
SERVER4: COUNTER= 9 DELTA= 262.472 msec
SERVER0: COUNTER= 10 DELTA= 188.364 msec
SERVER2: COUNTER= 10 DELTA= 101.07 msec
SERVER3: COUNTER= 10 DELTA= 116.54100000000001 msec
SERVER1: COUNTER= 10 DELTA= 318.44899999999996 msec
SERVER4: COUNTER= 10 DELTA= 16.676 msec
SERVER0: COUNTER= 11 DELTA= 7.071 msec
SERVER1: COUNTER= 11 DELTA= 60.224 msec
SERVER2: COUNTER= 11 DELTA= 101.07199999999999 msec
SERVER3: COUNTER= 11 DELTA= 45.32 msec
SERVER4: COUNTER= 11 DELTA= 11.719999999999999 msec
SERVER0: COUNTER= 12 DELTA= 125.88199999999999 msec
SERVER1: COUNTER= 12 DELTA= 75.607 msec
SERVER2: COUNTER= 12 DELTA= 84.648 msec
SERVER3: COUNTER= 12 DELTA= 44.051 msec
SERVER4: COUNTER= 12 DELTA= 290.6 msec
SERVER0: COUNTER= 13 DELTA= 0.306 msec
SERVER1: COUNTER= 13 DELTA= 58.865 msec
SERVER2: COUNTER= 13 DELTA= 101.007 msec
SERVER3: COUNTER= 13 DELTA= 12.927 msec
SERVER4: COUNTER= 13 DELTA= 212.348 msec
SERVER0: COUNTER= 14 DELTA= 53.222 msec
SERVER1: COUNTER= 14 DELTA= 63.087 msec
SERVER2: COUNTER= 14 DELTA= 112.285 msec
SERVER4: COUNTER= 14 DELTA= 0.192 msec
SERVER3: COUNTER= 14 DELTA= 111.608 msec
SERVER0: COUNTER= 15 DELTA= 41.897999999999996 msec
SERVER2: COUNTER= 15 DELTA= 0.514 msec
SERVER3: COUNTER= 15 DELTA= 30.408 msec
SERVER1: COUNTER= 15 DELTA= 261.84499999999997 msec
SERVER4: COUNTER= 15 DELTA= 69.785 msec
SERVER0: COUNTER= 16 DELTA= 88.022 msec
SERVER2: COUNTER= 16 DELTA= 19.599999999999998 msec
SERVER1: COUNTER= 16 DELTA= 201.69500000000002 msec
SERVER3: COUNTER= 16 DELTA= 52.805 msec
SERVER4: COUNTER= 16 DELTA= 8.53 msec
SERVER0: COUNTER= 17 DELTA= 0.324 msec
SERVER1: COUNTER= 17 DELTA= 159.975 msec
SERVER2: COUNTER= 17 DELTA= 58.62 msec
SERVER4: COUNTER= 17 DELTA= 0.462 msec
SERVER3: COUNTER= 17 DELTA= 100.717 msec
SERVER0: COUNTER= 18 DELTA= 68.68100000000001 msec
SERVER1: COUNTER= 18 DELTA= 8.701 msec
SERVER2: COUNTER= 18 DELTA= 16.889999999999997 msec
SERVER3: COUNTER= 18 DELTA= 156.637 msec
SERVER4: COUNTER= 18 DELTA= 56.296 msec
SERVER0: COUNTER= 19 DELTA= 29.073 msec
SERVER2: COUNTER= 19 DELTA= 30.326999999999998 msec
SERVER3: COUNTER= 19 DELTA= 0.155 msec
SERVER1: COUNTER= 19 DELTA= 251.63200000000003 msec
SERVER4: COUNTER= 19 DELTA= 5.305 msec
最佳答案
这是由于Python's Global Interpreter Lock (GIL)
造成的,只能限制并发处理速度。来源:https://jeffknupp.com/blog/2013/06/30/pythons-hardest-problem-revisited/
为了获得更快的机会或完成一项任务,您将不得不执行另一个进程(非线程),或者只是移至诸如c++之类的语言,该语言将启用并发线程和处理,而不会在线程限制上“锁定”。
关于python-3.x - python : multithreaded unix socket transfers are very slow,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46309322/
下面的代码应该淡入淡出。我究竟做错了什么? $(window).scroll(function(){ if ($(window).scrollTop() > 910){ $('
我正在 java swing applet 上创建一个 whack a mole 游戏,但我在计时 mole 出现时遇到了问题。我似乎无法避免 paint () 在我身上循环,从而过快地随机化地鼠的坐
如果我从solaris服务器ssh到美国服务器,ssh连接很快,比如删除一个文件很快就可以完成。 但是为什么powershell远程处理这么慢,我进入远程 session 后,然后删除一个项目,需要1
我正在获取一个 Java 小程序来填充数据库。 我在 HP i3 ram6gb 上使用 JDK 1.7 和 XAMPP 3.2.1 32 位。我的数据库很大并且具有以下结构: [TABLE] attr
我正在使用 OpenGL 在 C++ 中制作塔防游戏。当尝试使用 Windows.H 中的“ sleep ”功能时,它会导致我的 OpenGL 窗口打开我输休眠眠的任何值的总时间,然后打开窗口。有什么
我有以下代码,它可以工作,但在每个切换操作结束时变得有点跳动。 切换段落会不会更流畅?我正在尝试获取该段落,但我不知道该怎么做。 body {width: 660px; margin: 0 aut
我在想这个。我创建了一个 Complex 类只是为了好玩(用于存储复数)并习惯于 TDD。 并且我编写了以下测试: [TestMethod] [TestCategory("COMPLE
我正在开发一款每 30 秒向互联网发布一次的应用程序。一切正常,直到屏幕熄灭。计时器似乎变慢了。发布需要大约 5 分钟。我已经尝试获取唤醒锁和 setforegroundactivity 但没有任何效
我有一个很大的表,我决定通过从另一个表中引入一个带有 ID 的新列并删除另外两个列来减小它的大小。以下是表格: Table tests: +---------------+--------------
每次我想对一些代码进行快速测试时,android studio 需要 20-40 分钟来加载一个模拟器,这导致我的笔记本电脑崩溃或运行速度非常慢。有什么方法可以只使用系统日志而不加载整个应用程序,类似
我正在尝试查看(主要是)阿拉伯语句子列表,并删除那些不是阿拉伯语的句子。我有一个判断字符是否为阿拉伯语的技巧:阿拉伯语没有大小写,所以如果字符是字母但不是大写或小写,它就是阿拉伯语。 我有下面的代码,
我有一个问题,我不知道怎么解释好,但我会尝试......例如,在某些游戏中,文本输出“慢”,一个接一个地写char,而不是所有的一次短语......那么,我怎样才能复制这种行为? 我想这样......
基于 Java 反射慢的名声,我一直避免使用它。我在当前项目的设计中达到了一个点,能够使用它会使我的代码更具可读性和优雅,所以我决定试一试。 我只是对差异感到惊讶,我注意到有时运行时间几乎长了 100
一个普通WEB站点的页面常常需要查询N条SQL语句后才能得出页面结果,当网站访问速度慢而前端做了大量优化工作以后,数据库瓶颈的查找也是WEB优化的一个重要部分。 MySQL中提供了一个
启用 slow log 有两种启用方式: 1, 在my.cnf 里 通过 log-slow-queries[=file_name] 2, 在mysqld进程启动时,指定--lo
scipy.special 中的 expit 函数是一个向量化的 sigmoid 函数。它计算 1/(1+e^(-x)),这很复杂,可能涉及泰勒级数。 我了解了“快速 sigmoid”,1/(1 +
我使用 PyCharm,我是 python 的新手。 经过 2 天弄清楚 tensorflow 的工作原理后,我成功了,但启动时间很慢。在句子之前一切正常:'Adding visible gpu de
因此,我们从一家安全公司获得了此报告,称我们在IIS 8.0上运行的MVC网站容易受到缓慢的HTTP post DoS攻击的攻击。报告说我们应该 限制请求属性是通过元素实现的, 特别是maxAllow
(请提供这个重复的问题。我很失望我找不到它。) 我的开发机器“慢”。我等待它“很多”。 想要帮助公平、准确地衡量那个时间的决策者曾问过我。您如何量化您在计算机上等待的时间(在编译期间,每天等待应用程序
我正在使用 jquery fadein fadeout 和慢速选项,但它对我来说仍然有点太快了。现在我读到你只能在快和慢之间进行选择,但是有没有办法让它变慢呢? 最佳答案 你有两个选择。第一种是在调用
我是一名优秀的程序员,十分优秀!