python – flask-security:最小化数据库命中

在我的应用程序中,我使用 flask-security添加了身份验证和授权主题. sqlAlchemy也用作数据提供者(MysqL作为后端).该应用程序运行正常.

然后,我做了一些MysqL跟踪,日志显示我在应用程序上请求的每个URL上,flask-security库发送两个数据库查询

> select user from user userid =’用户标识符’
> select from from role,roles_users …

我认为这是一个性能问题,我想尽量减少这些查询.
我不知道是否有我缺少的配置功能.

解决方法

无需进一步优化(比如使用Redis缓存sql响应或用户对象),我认为您无法避免第一个请求.在大多数情况下,您需要有关用户的数据,并且您不希望将这些数据存储在用户的会话cookie中.再次,您可以使用类似Redis的东西来存储这些信息服务器端,由会话ID索引.

但是,您可以使用JOIN来避免第二个请求.通过同时执行第一个和第二个请求,可以节省一些传输时间,数据库可以选择适当的查询计划.

相关文章

功能概要:(目前已实现功能)公共展示部分:1.网站首页展示...
大体上把Python中的数据类型分为如下几类: Number(数字) ...
开发之前第一步,就是构造整个的项目结构。这就好比作一幅画...
源码编译方式安装Apache首先下载Apache源码压缩包,地址为ht...
前面说完了此项目的创建及数据模型设计的过程。如果未看过,...
python中常用的写爬虫的库有urllib2、requests,对于大多数比...