python异步requests_asyncio异步使用requests

以下内容为原创,转载请注明出处!

python requests是同步请求,由于我们在编写代码的时候用的是async异步,异步中应该避免使用同步代码,所以需要修改requests,让他支持异步请求。如下(以下代码主要是在Django中使用):import asyncio

import functools

import requests

async def _get_requests(self, url, key):

loop = asyncio.get_event_loop()

# 需要用参数使用functools,不需要的话可以这样写:

# r = await loop.run_in_executor(None, requests.get, url)

r = await loop.run_in_executor(None, functools.partial(requests.get, url=url, auth=(settings.HARBOR_USERNAME, settings.HARBOR_PSW)))

return r, key

async def _get_docker_index_info(self, context):

tasks = []

tasks.append(asyncio.ensure_future(self._get_requests(settings.HARBOR_URL + 'repositories?project_id=3', 'repositories')))

tasks.append(asyncio.ensure_future(self._get_requests(settings.HARBOR_URL + 'projects/3/members', 'members')))

tasks.append(asyncio.ensure_future(self._get_requests(settings.HARBOR_URL + 'projects/3/logs', 'logs')))

for task in asyncio.as_completed(tasks):

r, key = await task

if r.status_code == 200:

context[key] = r.json()

return context

def get_context_data(self, **kwargs):

context = super(DockerIndexView, self).get_context_data(**kwargs)

loop = asyncio.new_event_loop()

task = loop.create_task(self._get_docker_index_info(context))

loop.run_until_complete(task)

context = task.result()

return context

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值