特定のレート(QPS値を使用した例)でAPIリクエストを送信しようとしています。 次のコードを使用してリクエストを開始しています(web_requestsリストに格納されています)。複数のWebリクエストを送信
QPS = 10に設定すると、遅延は0.1秒または100ミリ秒になります。私はtime.sleep(0.1)を使用してリクエストを送信しますが、このコードは30ミリ秒程度のリモートエンドのHTTP応答を待っていますので、0.3秒の余分な遅延が発生します。 応答を待たずに秒間にX Webリクエストを送信できますか?
@gen.coroutine
def send_requests(campaign_instance):
...
http_client = httpclient.AsyncHTTPClient()
while True:
try:
web_request = web_requests.pop()
time.sleep(delay)
headers = {'Content-Type': 'application/json'}
request = httpclient.HTTPRequest(auth_username=settings.api_account,
auth_password=settings.api_password,
url=settings.api_web_request,
body=json.dumps(web_request),
headers=headers,
request_timeout=5,
method="POST")
yield http_client.fetch(request, callback=partial(handle_response, web_request["to"]))
gen_log.info("start_campaign() Requests in Queue: {}".format(len(web_requests)))
except httpclient.HTTPError, exception:
gen_log.info.exception("start_campaign() ".format(exception))
api_errors += 1
if handle_api_errors(api_errors):
break
except IndexError:
gen_log.info.info('start_campaign() Campaign web requests completed. API Errors: {}'.format(api_errors))
break
def start():
ioloop.IOLoop.current().run_sync(lambda: send_requests(campaign_instance))
log.info('process_campaign() Campaign completed')
campaign_instance.terminate()
あなたの助言の後に働いた。ありがとう – spicyramen