4

我使用 APScheduler 来安排每分钟调用一次 API 的作业。我现在收到一个巨大的错误,其结尾是:

  File "/usr/lib/python2.7/httplib.py", line 1045, in getresponse
    response.begin()
  File "/usr/lib/python2.7/httplib.py", line 409, in begin
    version, status, reason = self._read_status()
  File "/usr/lib/python2.7/httplib.py", line 365, in _read_status
    line = self.fp.readline(_MAXLINE + 1)
  File "/usr/lib/python2.7/socket.py", line 476, in readline
    data = self._sock.recv(self._rbufsize)
  File "/usr/lib/python2.7/ssl.py", line 341, in recv
    return self.read(buflen)
  File "/usr/lib/python2.7/ssl.py", line 260, in read
    return self._sslobj.read(len)
SSLError: The read operation timed out
WARNING:apscheduler.scheduler:Execution of job "getAndStoreAPICallResult 
(trigger: cron[minute='*'], next run at: 2014-07-08 15:37:00)" skipped: maximum 
number of running instances reached (1)

所以我猜API调用不知何故没有得到响应,因此永远不会完成。这会阻止运行下一个作业,因为第一个作业从未结束。因此,它以某种方式无法开始运行新作业。

我当然可以增加允许的并发运行实例的数量,但这并不能真正解决问题。我想如果在一定秒数后(比如说 5 秒)还没有完成,我需要结束工作。

因为我有几个其他的 API 调用作业,我从 APScheduler 开始,如果我能以某种方式使用 APScheduler 解决这个问题,那就太棒了。有人知道 APScheduler 是否可以终止运行时间过长的作业,还是我需要以其他方式解决这个问题?

欢迎所有提示!

4

1 回答 1

0

由于无法从外部终止线程,请考虑设置更短的 SSL 超时。

于 2014-07-10T11:21:26.373 回答