toB 业务,老板让优化首页展示速度,请教大神帮忙

2023-03-02 14:40:27 +08:00
 wholve

具体说一下我们的业务,我们的主要业务是低代码表单。表单的可见范围来自多个维度 1.指定人员 2.指定部门,子部门 3.通过外部接口(指定规则) 4.全员可见

根据以上的维度,我去判断每个人的权限时,需要根据当前登录人与每个表单去比对,是否有权限,这样造成的结果就是表单的数量越多,就会造成查询速度越慢

现在已经优化过一版: 全部表单加缓存 并且通过异步去匹配部门,异步去匹配规则 虽然有些成效,但还是不能满足 200ms 以内返回

有想过一下两个方案 1.定时任务异步去执行每个人的可见表单,但是公司员工众多,很耗费资源 2.通过异步缓存,首次加载时用上次的表单权限,此时异步执行可见逻辑,执行完之后保存到缓存;然后该用户刷新页面再次调用时,即可看到最新权限

大神们还有更好的解决思路吗,欢迎探讨~

1266 次点击
所在节点    问与答
21 条回复
wholve
2023-03-03 10:29:45 +08:00
@Chad0000 看你的回答 你还没理解我说的为啥规则要当做一个 http 接口
你提供这个思路的前提是需要构建一个规则接口与用户表权限映射关系
但是不只是从表单可以改可见权限
也可以通过改规则逻辑去改可见权限,规则确实复杂,假如一个规则接口设置了正则,大于 20 岁的男生,入职公司满 5 年等等你就需要实时去查规则,一个规则对应一个几十万的用户表这样不现实吧,这样类似的场景很多,根本构建不出规则权限与用户的表,这样举例你能明白我说的吗?
不过你提供的思路已经是很贴合我们的业务来提供解决方案了,就差这一点有理解偏差

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/920508

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX