微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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来避免第二个请求.通过同时执行第一个和第二个请求,可以节省一些传输时间,数据库可以选择适当的查询计划.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐