使用python-aiohttp搭建微信公众平台

aiohttp是一个基于asyncio的异步http框架,在高并发的情况下具有很好的性能,这也是我选择使用aiohttp来搭建微信公众平台的原因。但是由于网上关于aiohttp的资料较少,再加上自己对协程的相关概念理解不够深刻,导致在开发过程中吃到了一些苦头,所以在使用aiohttp之前,首先来介绍一下基本概念。

协程与线程、进程的关系

一说到协程,很容易就会联想到线程与进程,但协程与它们并不相同。我们知道一个进程可以包含多个线程,它们都由系统进行管理与维护。进程本身并不执行任何代码,当系统创建一个进程时,会自动为其创建一个线程(主线程),由主线程来执行相应代码或创建更多线程。当一个进程所包含的的线程数为0时,该进程也就没有存在的必要了。所以说,进程是线程的容器。

协程是指在一个线程的执行过程中,可以在一个子程序内部中断转而执行别的子程序,在适当的时候再返回来接着执行。但与线程的切换不同,子程序的切换并不由系统控制,而是通过程序来控制。在系统看来,协程还是只有一个线程,这样的好处就是节省了线程切换的开销,也不需要多线程的锁机制,但相应的也就无法利用cpu的多核优势。

打个比方,在多核cpu情况下,一个进程就相当于一间屋子,该进程若是包含两个线程就表示这间屋子里有两个人分别在做自己的事,如果其中一个人一会儿做这件事一会儿做那件事这样来回切换,我们就说在该线程中使用了协程。

asyncio

asyncio是python的一个异步协程框架,要使用asyncio需要先了解几个概念:

event loop: event负责I/O时间通知,loop负责循环处理I/O通知并在就绪时调用回调,当协程被加入到event loop后,event loop会在适当的时候调用该协程,需要注意的是,每个进程只有一个event loop
async/await: async def用来定义一个协程函数,在协程函数中调用嵌套协程时可以使用await关键字来挂起当前协程并等待嵌套协程的执行结果
task: task负责协程函数在event loop中的执行,在当前task挂起时,event loop会执行其他task,在event loop中,同一时刻只能执行一个task

下面举例说明:

import time
import asyncio
# hu 定义协程函数
async def compute(x, y):
    print("=>compute: x = %d,y = %d" % (x, y))
    await asyncio.sleep(1)  # hu 当前task挂起,event loop转而执行其他task
    pr
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值