Perforce(P4)pythonapi抱怨锁太多
我编写了一个打开多个子进程的应用程序,这些子进程分别启动到Perforce服务器的连接。过了一段时间,我在几乎所有这些子进程中都收到了此错误消息:Perforce(P4)pythonapi抱怨锁太多,python,perforce,Python,Perforce,我编写了一个打开多个子进程的应用程序,这些子进程分别启动到Perforce服务器的连接。过了一段时间,我在几乎所有这些子进程中都收到了此错误消息: Traceback (most recent call last): File "/Users/peter/Desktop/test_app/main.py", line 76, in p4_execute p4.run_login() File "/usr/local/lib/python3.7/site-packages/P4.py",
Traceback (most recent call last):
File "/Users/peter/Desktop/test_app/main.py", line 76, in p4_execute
p4.run_login()
File "/usr/local/lib/python3.7/site-packages/P4.py", line 665, in run_login
return self.run("login", *args, **kargs)
File "/usr/local/lib/python3.7/site-packages/P4.py", line 611, in run
raise e
File "/usr/local/lib/python3.7/site-packages/P4.py", line 605, in run
result = P4API.P4Adapter.run(self, *flatArgs)
P4.P4Exception: [P4#run] Errors during command execution( "p4 login" )
[Error]: "Fatal client error; disconnecting!
Operation 'client-SetPassword' failed.
Too many trys to get lock /Users/peter/.p4tickets.lck."
有人知道这是什么原因吗?我正确地打开连接,并通过disconnect
仔细检查所有与服务器正确断开连接的源位置
只有手动删除.p4tickets.lck才能工作,直到几秒钟后错误再次出现。相关代码如下:
您的脚本多久运行一次“p4登录”来刷新和重新写入票据?一秒钟很多次?如果您将他们更改为不这样做(例如,只有在没有票证的情况下才登录),问题是否仍然存在?您是我的英雄!在每个连接上(数百次),它执行
run\u login
+connect
,这显然是不必要的!非常感谢!如果存在某种竞争条件,我也不会感到惊讶(尽管理论上可能是本地文件锁阻止了竞争,并且这里存在flock()
问题);在“正常”使用情况下,客户端根本不运行并发的login
命令,更不用说写操作的速度快到可以并发进行了。对于其他阅读本文的人来说。。我以相同的连接方法执行了p4.run_login和p4.connect。仅使用凭据调用connect
即可