Python学习---Python的异步IO[all]

1.1.1. 前期环境准备和基础知识

安装:

pip3 install aiohttp

pip3 install grequests

pip3 install wheel

pip3 install scrapy

注意:

windows上scrapy依赖 https://sourceforge.net/projects/pywin32/files/

安装Twisted

a. http://www.lfd.uci.edu/~gohlke/pythonlibs/#twisted,

b. 下载:Twisted-17.1.0-cp35-cp35m-win_amd64.whl

c. 进入文件所在目录

d. pip3 install Twisted-17.1.0-cp35-cp35m-win_amd64.whl

 

实现IO操作的方式

 

为什么需要异步请求呢?

如果是正常的请求,一个请求结束后才能开启下一个请求[串行请求],如果期间有一个请求一次,则后面的请求都会终止。

如果是类似多线程的异步请求,则由多个线程同时开启多个请求,一个请求的异常不会影响其他

实现IO操作有3种方式:

同步  【串行操作】
多进程【更消耗资源,有操作系统调用】 --> 更适合计算密集型操作因为需要并发操作,消耗CPU
       线程是计算机工作的最小单元
多线程【有CPU进行调用,节省资源】    --> 更适合多IO操作,因为发送请求后不消耗CPU资源
       进程中至少有一个线程,默认都有一个主线程且共享进程的内部资源
多协程 --> 一个进程内一个线程完成多个任务【可以同时接收多个请求,然后在一个一个的处理请求】
       如果遇到阻塞则执行下一个请求,如果阻塞的请求收到回复后执行刚才阻塞的那个请求【回调实现】,效率比多线程还高.

注:线程里面有GIL【global Interpreter lock】,Python里面有个GIL锁[该锁保障同时间1个进程内只允许1个线程操作],不允许CPU操作多个线程,不允许CPU调用资源[也就是限制了CPU,即限制了多线程]。但是线程可以进行IO操作,多个线程可以同时进行多个IO操作[URL 请求等,因为CPU的只需要发送一下即可,发送后不消耗cpu资源],

利用多线程实现IO的异步操作:

import requests
from concurrent.futures.thread import ThreadPoolExecutor
pool = ThreadPoolExecutor(5) # 创建线程池,也可以理解为多线程了这里
url_list = [
    ‘https://www.baidu.com/‘,
    ‘https://www.taobao.com/‘,
    ‘https://www.google.com/search‘,
    ‘https://hao.360.cn/‘,
]
def async_url(url):
    try:
        response = requests.get(url)
        print(‘正常请求:‘, ‘【‘, url, ‘】‘, response.content)
    except Exception as e:
        print(‘异常请求:‘, e)
for url in url_list:
    print(‘请求开始:‘, url)
    pool.submit(async_url, url)
pool.shutdown()   # 关闭线程

后台显示结果:

利用多进程实现IO的异步操作:

[其他同上]
from concurrent.futures.process import ProcessPoolExecutor
import requests
pool = ProcessPoolExecutor(5) # 创建进程池,也可以理解为多线程了这里
pool.submit(async_url, url)   # async_url是个方法,url是传递过去参数
pool.shutdown()   # 关闭进程

异步IO_1---asyncio模块(no-http)

Python学习---IO的异步[asyncio模块(no-http)]

异步IO_2---gevent+Grequests

Python学习---IO的异步[gevent+Grequests模块]

异步IO_3---twisted模块

Python学习---IO的异步[twisted模块]

异步IO_4---tornado模块

Python学习---IO的异步[tornado模块]

自定义异步IO

Python学习---IO的异步[自定义异步IO]

原文地址:https://www.cnblogs.com/ftl1012/p/9424733.html

时间: 2024-10-13 16:11:44

Python学习---Python的异步IO[all]的相关文章

Python高级编程和异步IO并发编程

Python高级编程和异步IO并发编程网盘地址:https://pan.baidu.com/s/1eB-BsUacBRhKxh7qXwndMQ 密码: tgba备用地址(腾讯微云):https://share.weiyun.com/5Z3x9V0 密码:7cdnb2 针对Python高级编程和异步IO并发编程,把每个Python高级知识点从起因到原理讲透的课程全网难寻 第1章 课程简介第2章 python中一切皆对象第3章 魔法函数第4章 深入类和对象第5章 自定义序列类第6章 深入python

Python学习笔记__9章 IO编程

# 这是学习廖雪峰老师python教程的学习笔记 1.概览 IO在计算机中指Input/Output,也就是输入和输出. 由于程序和运行时数据是在内存中驻留,由CPU这个超快的计算核心来执行,所以涉及到数据交换的地方,通常是磁盘.网络等,这些地方就需要IO接口. 数据从内存往外发是Output 数据从外往内存发是Iutput 2.同步IO和异步IO 同步IO:发起IO请求后,等到IO的返回结果,在接着往下执行 异步IO:发起IO请求后,可以去做其他事.IO结果返回后,会通知调用者. 注:本章所讲

Python学习---Python的异步---asyncio模块(no-http)

Asyncio进行异步IO请求操作: 1. @asyncio.coroutine  装饰任务函数 2. 函数内配合yield from 和装饰器@asyncio.coroutine 配合使用[固定格式] 3. loop = asyncio.get_event_loop() loop.run_until_complete(asyncio.gather(*tasks)) # 接受异步IO的任务并异步执行任务 实例一: 异步IO: 协程机制 + 回调函数 import asyncio @asyncio

Python学习--Python基础语法

第一个Python程序 交互式编程 交互式编程不需要创建脚本文件,是通过 Python 解释器的交互模式进来编写代码. linux上你只需要在命令行中输入 Python 命令即可启动交互式编程,提示窗口如下: Window上在安装Python时已经已经安装了默认的交互式编程客户端,提示窗口如下: 在Python提示符中输入一下文本,然后按回车查看运行结果: print 'hello world'; 输出: hello world 脚本式编程 让我们来写一个简单的Python脚本,所有的Pytho

Python学习_06_文件、IO

文件对象 python中的文件操作和c语言比较类似,包括一些缓冲.偏移量的方式. 文件对象可以通过open().file()两个内建方法创建,两个方法并没有什么不同,使用方法和c语言中的fopen()类似: file_object = open(file_name, access_mode='r', buffering=-1) 其中access_mode表示打开方式,r表示只读,w表示只写,r+,w+表示读写,a表示追加等:buffering表示缓冲方式,负值表示默认缓冲方式,0表示不缓冲,1表

Python学习(九)IO 编程 —— 文件夹及文件操作

Python 文件夹及文件操作 我们经常会与文件和目录打交道,对于这些操作,python可以使用 os 及 shutill 模块,其中包含了很多操作文件和目录的函数.这边,仅介绍通常会用到的方法. os 可以操作简单的文件夹及文件操作,引入用  import os,可用  help(os)  或是  dir(os)  查看其用法.注意有些函数在os模块中,有的是在os.path模块中. shutil 模块提供了大量的文件的高级操作.特别针对文件拷贝和删除,主要功能为目录和文件操作以及压缩操作.须

Python学习:并发编程之IO模型

本节内容: I/O模型介绍 阻塞I/O(blocking IO) 非阻塞I/O(non-blocking IO) 多路复用I/O(IO multiplexing) 异步I/O(Asynchronous I/O) IO模型比较分析 selectors模块 一 IO模型介绍 同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别?这个问题其实不同的人给出的答案都可能不同,比如wik

Python学习 - python基础

目录: 一. Python的安装 二. Hello World程序 三. 变量 四. 注释 五. 用户输入 六. 流控语句之 if 判断 七. 流控语句之 for 循环 八. 流控语句之 while 循环 一.  Python的安装 windows 1. 通过官网下载Python安装包: https://www.python.org/downloads/2. 安装下载的包, 一路next. 安装过程中可自定义安装路径等...3. 为计算机添加安装目录到环境变量, 以 安装路径 -> "C:

002.[python学习]python编码规范pep8学习——PEP8第一部分代码布局

关于PEP8的详细说明可以参考官方原文:http://legacy.python.org/dev/peps/pep-0008/ 我参考官方文档及其他文章,摘出相关内容而得此文章,具体参考其他文章见文中最后参考资料处. 当想要让自己所写的代码为更多人使用.交流学习时,不能写出只有机器认识的代码,而是对于人而言具有良好的可读性,此时就需要遵从一个公共的约束来规范自己的代码,那么<Style Guide for Python Code(PEP8)>是个很好的选择. 首先PEP8中声明,有以下有理由忽