今天,已经上线的项目,客户忽然那边报出一个bug来。
bug描述如下:
在PC1下以user1登录系统,接着以user2在PC2登录系统,之后user1的部分菜单变成了user2的菜单。
当时觉得这个bug很不可思议,因为系统是一个项目组的子项目,是一个web程序,菜单都是在用户登录系统的时候写进session里面的,在不同的PC上登录怎么会相互影响呢?查了很久还没找出原因。
后来想起不久前对系统做过一次压力测试,为了提高登录时的效率,对取菜单这部分做过优化。开始时系统的菜单是采用层次的方法划分的,也就是一级菜单、二级菜单,角色的分配是直接指定二级菜单,所以每次在登录取菜单时会直接取出所有的一级菜单,再根据用户的角色取出相应的二级菜单,接着把菜单组织成树型结构放入session中。优化的时候对取一级菜单加上了cache,就是因为加上了这个cache才导至了今天的bug。
ibatis配置文件中取一级菜单的代码:
<cacheModel id="module-level-cache" type="LRU" readOnly="true">
<flushInterval hours="5"/>
<flushOnExecute statement="insertModule"/>
<flushOnExecute statement="updateModule"/>
<flushOnExecute statement="deleteModule"/>
<property name="size" value="100" />
</cacheModel>
<select id="getModulesByLevel" parameterClass="ParamModuleHolder"
resultMap="ModuleResult" cacheModel="module-level-cache">
select * from MODULE
<dynamic prepend="where">
<isNotNull prepend="AND" property="moduleLevel">
MODULE_LEVEL = #moduleLevel#
</isNotNull>
</dynamic>
<isNotNull property="sortField">
order by $sortField$
</isNotNull>
<isNull property="sortField">
order by SHOW_SORT
</isNull>
</select>
分析一下,原因是这样的:user1登录系统时,从数据库中取出并组织好菜单,这时,一切正常;但当user2登录系统后,因为一级菜单已经在cache中,这时会直接从jvm中拿一级菜单这个list对象,并把user2的二级菜单放入这个list对象中相应的位置。虽然user1和user2有各自己的session,但是session中的菜单对象都指向了同一个对象,所以user1用户的部分菜单就变成user2的了。
把cache拿掉后,一切恢复正常。
分享到:
相关推荐
infinite_menus 下拉菜单软件infinite_menus 下拉菜单软件
FlyoutMenus Simple material-style flyout menus for Android. There are many flyout type menus for Android, but this one is mine. compile 'org.zakariya.flyoutmenus:flyoutmenu:0.5.3' minSdkVersion: 14 ...
“Dreamweaver从现存的menus.xml创建菜单时遇到问题。请删除现在的menus.xml文件并重命名menus.bak到menus.xml“,你只要安装一个出错,任何版本也不能避免,装了一样出错,这方法很容易解决你的问题。
您可以及时查看分析您的CPU和GPU,内存,磁盘,网络,传感器,电池或时间,别外还支持在mac的任务栏显示天气,iStat Menus 是用于监控系统状态的不二之选,装机必备,不容错过! Istat menu 6.4.1(1135) 官方版本 ...
支持istat menus 6登陆使用。分享账号使用,亲测可用。
是一个ajax菜单,转载别人,版权归作者所有
可针对Mac进行cpu、内存、能耗、传感器、风扇进行自定义设置以及监控,最新iStat Menus,授权码可用
Laravel开发-laravel-menus Laravel菜单管理
C1Menus 和 C1 Toolbars中文帮助文档
iStat Menus Mac版让您可以从菜单中监控系统。包括8个菜单附件,让您监控系统的各个方面。 功能: CPU - 监视CPU使用情况。 7种显示模式,多核心支持。 内存 - 监视内存使用情况。 4种显示模式,页面输入/输出和交换...
iStat Menus for Mac是一款Mac系统上优秀的系统监视器,能够在系统菜单栏实时监控CPU、GPU、内存、硬盘、网络、温度、电池以及系统时间等,通过iStat Menus 6for Mac我们可以时刻了解自己 Mac 电脑上发生各种情况,...
Laravel开发-menus 为Laravel设计但不依赖于Laravel的基本菜单。
CSS下拉菜单设计专家Visual _Infinite Menus 超级漂亮的下拉菜单 制件方便,做网页不可秒的工具
iStat Menus 4.0.2 ked 包含序列号
过渡很平滑的Infinite Menus
iStat Menus for mac 是一款用于检测Mac os电脑硬件信息的专业工具,常驻于电脑的开始菜单栏,istat menus 方便用户随时查看CPU、硬盘和内存的使用情形、温度、网速等。
CSS menus demo 博文链接:https://eric2007.iteye.com/blog/202755
CSS3 Animation Menus 鼠标经过