通过下面这张图你就能看清楚了,进程、线程和携程的关系
进程:
多个进程是可以运行在多个CPU当中的,比如你的电脑是4核,可以同时并行运行四个进程,这是真正物理上的并行运行。
线程:
每个进程又可以有多个线程,线程是轮询执行的,因为轮询的速度很快,所以可以看成是并行。
微线程:
携程是微线程,一个线程可以分为多个携程,同样也是轮询执行,这样的好处是减少CPU的资源消耗,一些比较多而且小的事件可以用携程去处理,减少资源的开销。
协程原理
生成器器
def fun1():
print(100)
print(200)
yield # 暂停代码 保存断点状态
print(100)
print(100)
yield
eventlet
print(100)
print(100)
def fun2():
print(100)
print(200)
yield
print(100)
print(100)
yield
print(100)
print(100)
gen_obj1 = fun1() # 创建了生成器器对象
gen_obj2 = fun2()
next(gen_obj1)
next(gen_obj2)
next(gen_obj1)
next(gen_obj2)
通常采用协程库(扩展库)来完成协程开发
协程库能够自动帮助完成协程的执行切换
eventlet
from multiprocessing import Process
p = Processs()
p.start()
from threading import Thread
t = Thread()
t.start()
from eventlet import Eventlet
e1 = Eventlet()
e1.start()
e2 = Eventlet()
e2.start()
协程运行socketio服务器器的⽅方式
pip install eventlet
import eventlet
eventlet.monkey_patch()
import socketio
import eventlet.wsgi
# Server对象理理解为Flask⾥里里⾯面的应⽤用对象就可以
# sio对象是⽤用来管理理socketio即时通讯业务的
sio = socketio.Server(async_mode='eventlet') #
指明在evenlet模式下
app = socketio.Middleware(sio)
eventlet.wsgi.server(eventlet.listen(('',
8000)), app)