想使用gevent、mysql、sqlalchemy实现python项目协程异步达到并发的效果
如题,但是查看了很多资料,都说python这边的mysql不支持异步并发,只能阻塞进行,心塞30秒,暂时放弃这方面的研究
如果不操作数据库的化,比如请求url、操作文件,还是可以用gevent来异步实现并发的:https://zhuanlan.zhihu.com/p/21465564
有资料说豆瓣通过修改基础库实现了,参考:https://github.com/douban/greenify,看了半天,不觉得适合自己的项目
python的最佳实践是:http://san-yun.iteye.com/blog/1890784
1. gunicorn 同步模式+ 多开线程
2. gunicorn + gevent,前提把mysql的坑补上
有资料说:通过安装MySQL-connector可以实现:http://blog.csdn.net/liukeforever/article/details/7013545
再看看廖雪峰的:https://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/00140262673295076f525af00734a8e924c5fc6ff5b6091000,里面讲到,反正如此做了,不知道效果如何:
部署方式
在本地开发时,我们可以用Python自带的WSGI服务器,但是,在服务器上,显然不能用自带的这个开发版服务器。可以选择的WSGI服务器很多,我们选gunicorn:它用类似Nginx的Master-Worker模式,同时可以提供gevent的支持,不用修改代码,就能获得极高的性能。
-
gevent:把Python同步代码变成异步协程的库;
-
gunicorn --bind 127.0.0.1:9000 --workers 1 --worker-class gevent wsgiapp:application