tornado和sqlalchemy结合使用
来源:互联网 发布:mac粉底液专柜价 编辑:程序博客网 时间:2024/05/17 15:02
sqlalchemy 和 tornado的结合
sqlalchemy 是python系用的最多的orm,我们的项目也选用了sqlalchemy 。在结合sqlalchemy 和tornado过程中,查阅了大量资料。
sqlalchemy 执行各种操作时,最基本的单元为session。sqlalchemy 官方文档建议,尽量适用框架的第三方扩展包来集成sqlalchemy,可以自动的管理session范围。根据sqlalchemy 文档,session的管理放在了每次的request请求中处理为最佳,及每次请求进来时,实例化session,请求结束后,将session关闭,见这里和 tornado的一个相关issues。
结合如下:
from sqlalchemy.orm import scoped_session, sessionmakerfrom models import * # import the engine to bindclass Application(tornado.web.Application):def __init__(self): handlers = [ (r"/users", UsersHandler), ] settings = dict( cookie_secret="some_long_secret_and_other_settins" ) tornado.web.Application.__init__(self, handlers, **settings) # Have one global connection. self.session = scoped_session(sessionmaker(bind=engine))class BaseHandler(tornado.web.RequestHandler): def prepare(self): self.session = self.application.session def get_current_user(self): user_id = self.get_secure_cookie("user") if not user_id: return None return self.db.query(User).get(user_id) def on_finish(self): self.session.remove()
此处的scoped_session, 可理解为session的注册表,从中取用和交还,并保证多次取用的为统一session。详见官方文档,这里
另外需要注意,此处的sqlalchemy的数据库查询,并不是异步,当使用tornado 的异步特性时,遇到查询数据库慢时,还是会阻塞的,此时我们更多的需要考虑的
是去优化我们的sql,而不是异步查询数据库。因为,当数据库的查询慢到可以阻塞进程时,说明确实是有问题了。除非我们确实是有这种长时间查询数据库的需求。
tornado 本身并没有提供数据库层的异步,看了许多异步查询数据库的三方库,都不是特别成熟。还有另一种解决方案,是使用其他异步任务库来完成长时间查询数据库的需求,如celery。
阅读全文
0 0
- tornado和sqlalchemy结合使用
- 在Python3下使用tornado和SQLAlchemy实现一个简单的MVC网站
- tornado框架SQLAlchemy的操作
- sqlalchemy在pythonweb中开发的使用(基于tornado的基础上)
- 使用 SQLAlchemy
- sqlalchemy使用
- 使用sqlalchemy
- 使用SQLAlchemy
- 使用SQLAlchemy
- 使用 sqlalchemy
- 使用SQLAlchemy
- tornado协程使用和原理
- Tornado使用
- 使用sqlAlchemy和mysqldb时unicode的设置问题
- Python程序和Flask框架中使用SQLAlchemy的教程
- tornado用户指引(二)------------tornado协程实现使用和原理(一)
- tornado用户指引(三)------tornado协程使用和原理(二)
- tornado用户指引(四)------tornado协程使用和原理(三)
- poj3311 状态压缩dp
- 判断页面鼠标滚动的方向
- CentOS7开机启动管理systemd简介及使用
- Linux 6上使用UDEV绑定共享存储
- 二叉搜索树的基本操作
- tornado和sqlalchemy结合使用
- Fragment系列之Can not perform this action after onSaveInstanceState
- jquery treeview初始化时收缩全部节点并显示指定节点
- NodeJS、NPM安装配置步骤(windows版本)
- DoTween的使用与详解
- tensorflow1.1/autoencoder人脸识别
- 谷歌搜索技巧
- Web服务器使用JSP来创建网页的步骤
- Centos 6.5 安装Oracle 12C RAC