多进程:
多线程和多进程的区别:
Python多线程不适合CPU操作密集型的任务,适合IO操作密集型的任务(IO操作不占用CPU)
Python折中解决多线程不能真正同步运算的方案是:起多个进程,每个进程中的线程都可以同时在多核中运行,缺点是不能共享内存数据。
协程:微线程,用户自己控制,CPU不切换。举例:yield就是协程的一种实现
遇到IO操作就切换
Gevent是一个第三方库,可以轻松通过gevent实现高效同步或异步编程。在Gevent中用到的主要模式是Greenlet。它是以C扩展模块形式接入Python的轻量级协程。Greenlet全部运行在主程序操作系统的进程内部。但他们被协作式的调度。
论事件驱动与异步IO:
通常,我们写服务器处理模型的程序时,有以下几种模型:
1 每收到一个请求,都启动一个进程
2 每收到一个请求,都启动一个线程
3 每收到一个请求,放入一个事件列表,让主进程通过非阻塞I/O方式来处理请求(协程)
上面几种方式:各有千秋:
1,由于创建新的进程的开销比较大,所以会导致服务器性能比较差,但实现比较简单。
2,由于要设计到线程的同步,有可能会面临死锁等问题。
3,在写应用程序代码是,逻辑比前两种都复杂。
综合考虑各方面因素,一般普通使用第三种方式进行网络服务器程序编写
在Linux下分析Socket多并发各种实现模型的效率分析:
1 阻塞模型 在数据接收时等待、等待数据从内核内存copy到用户内存中等待时会卡住
2 非阻塞模型 在等待数据从内核内存copy到用户内存中等待时会卡住
3 同步/O多路复用 就是我们说的select,poll,epoll,有些地方也成这种IO方式为event driven IO。select/epoll的好处就是在于单个process就可以同时处理多个网络连接的IO。它的基本原理就是select,poll,epoll这个function会不断的轮训所负责的所有socket,当某个socket有数据到达了,就通知用户进程。
4 信号驱动IO 在请求数据时,给予请求,不需要等待,可以做其他事情,带请求数据准备好了,回送一个信号以驱动再次过来取数据。
5 异步IO 其实用的很少,先看一下它的进程:
只需告知要求数据的请求,然后请求进程就可以去做自己的事情,服务器会帮助请求数据,数据从系统内核转存到用户内存,然后送给请求的进程,最后给进程发送一个完成的信号。效率达到最高。
异步IO实例:select解析Socket实例 请参见80180814
另一种实现:用selectors实现
本节作业: 用select或者selectors完成FTP上传下载的多并发效果
Python3.5 学习十的更多相关文章
-
Python3.5 学习十九 Django分模块讲解 MTV+URL
本节内容概述: 表单提交的Method使用规则:get 获取数据 post提交数据 单选使用get 多选使用getlist request.POST.getlist("favor" ...
-
Python3.5学习十八 Python之Web框架 Django
Python之Web框架: 本质:Socket 引用wsgiref创建web框架 根据web框架创建过程优化所得: 分目录管理 模板单独目录 执行不同函数单独存入一个方法py文件 Web框架的两种形式 ...
-
Python3.5 学习十二 数据库介绍
MYSQL介绍: 主流三种数据库:Oracle.Mysql.Sqlserver Mysql安装和启动: windows 1安装 2启动服务 3进入bin目录,打开命令行 4 mysqladmin -u ...
-
python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例
python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例 新浪爱彩双色球开奖数据URL:http://zst.aicai.com/ssq/openInfo/ 最终输出结果格 ...
-
从零开始学习PYTHON3讲义(十五)让画面动起来
<从零开始PYTHON3>第十五讲 虽然看起来绘图和音乐并不相关,但是听过了上一讲的内容你一定知道,这是游戏编程中四个需要处理内容的两部分,这两部分必须同时.并行的处理,不能因为某一项计算 ...
-
从零开始学习PYTHON3讲义(十四)写一个mp3播放器
<从零开始PYTHON3>第十四讲 通常来说,Python解释执行,运行速度慢,并不适合完整的开发游戏.随着电脑速度的快速提高,这种情况有所好转,但开发游戏仍然不是Python的重点工作. ...
-
从零开始学习PYTHON3讲义(十二)画一颗心送给你
(内容需要,本讲使用了大量在线公式,如果因为转帖网站不支持公式无法显示的情况,欢迎访问原始博客.) <从零开始PYTHON3>第十二讲 上一节课我们主要讲解了数值计算和符号计算.数值计算的 ...
-
从零开始学习PYTHON3讲义(十)自己做一个“电子记事本”
<从零开始PYTHON3>第十讲 截至上一讲,我们已经完成了Python语言的基本部分.我们用了三讲来讨论Python语言的控制结构,用了两讲来介绍Python的基本数据类型.可以说仅就语 ...
-
python3.4学习笔记(十八) pycharm 安装使用、注册码、显示行号和字体大小等常用设置
python3.4学习笔记(十八) pycharm 安装使用.注册码.显示行号和字体大小等常用设置Download JetBrains Python IDE :: PyCharmhttp://www. ...
随机推荐
-
Finding Nemo_BFS
Description Nemo is a naughty boy. One day he went into the deep sea all by himself. Unfortunately, ...
-
bzoj 4715
其实我并没有见过原题,只是因为...这被改编成了互测题... 题目中提到了一个序列,这个序列是很重要的,否则这个问题好像是没有合理的时间复杂度解法的 但正因为有了这个序列,这个问题的时间复杂度才让人能 ...
-
Window应急响应(一):FTP暴力破解
0x00 前言 FTP是一个文件传输协议,用户通过FTP可从客户机程序向远程主机上传或下载文件,常用于网站代码维护.日常源码备份等.如果攻击者通过FTP匿名访问或者弱口令获取FTP权限,可直接上传 ...
-
黑吃黑第四季/全集Banshee迅雷下载
英文全名Banshee,第5季(2015)Cinemax. 本季看点:<黑吃黑>Ana Ayora加盟第四季,将会饰演Nina Cruz,表面上是在镇里一个聪明而又强悍的新副警长,但实际是 ...
-
STL - 移除(remove)和释放(erase)集合元素
remove(移除): 这个操作并不是真正地删除元素,它会移除指定的元素,然后后面的元素依次前移,最后用别的元素来补充. erase(释放): 这个操作会指定释放区间的头和尾迭代器(iterator) ...
-
用pytesseract识别验证码报错
运行py文件出现下面报错 pytesseract.pytesseract.TesseractError: (1, 'Error opening data file \\Program Files\\T ...
-
HTML Forms(转)
内容来自HTML Dog:http://htmldog.com/guides/html/beginner/forms/ Forms Forms被用来收集用户的输入,它们通常被作为web应用的接口. 在 ...
-
在web.config中配置httpHandlers节点是的说明
<system.web> <httpHandlers> <add verb="*" path="*.lcj" type=" ...
-
auto用法
在C++11中,如果编译器在定义一个变量的时候可以推断出变量的类型,不用写变量的类型,你只需写auto即可. 第一种用法:自动推到内置类型 int x = 100; //C++ 11 auto x = ...
-
MySQL5.7源码安装问题汇总
编译安装mysql5.7版本,想试用一下新的版本特性,发现跟之前的5.6版本编译有了一些变化,总结一下避免以后继续入坑.5.6安装方式 cmake版本 5.7编译cmake要求版本最低为2.8,当前为 ...