java+flex项目的性能问题? 400 报错
对您的回复,小弟不胜感激。。。
该问题是:关于java+flex的性能问题,虽然帖子的内容比较多,但挺简单的,请精通java+flex的大牛们,帮我诊断下、。。。非常感谢!!!
交互的配置文件是(下面的四个):
一:下面的代码是:前台(flex开发的)启动的时候向后台请求数据,后台把一个集合(集合中大概有3百个实例)给前台,不启动前台是不会调用该方法的。下面的方法位于前台和后台交互的接口类
/* * 查询应急预案 */ public IResult queryPrecautionPlan() { LOG.error("查询应急预案"); IResult result = new ListResult<T>(); try { result.setResult(precautionService.queryPrecautionPlan()); result.setExtraMessage("查询成功!"); } catch (Exception e) { result.setResult(null); result.setExtraMessage("查询过程中出现异常,请记录下当前时间并告知管理员!"); String err = "Error occurred while QueryPrecautionPlan, Administrated"; LOG.error(err, e); } return result; }
二:通过上面的代码前台可以展示一个数据列表,然后针对列表中的每条数据,可以发布事件,下面的代码是具体的处理流程
/* * 发布预案模型通知、通告 */ public void publishPlanModelNotification(PrecautionPlanModel planModel, PFUser user){ LOG.error("数据删除"); try { // System.err.println(FlexContext.getFlexClient().getId()); user.setIP(FlexContext.getHttpRequest().getRemoteAddr()); precautionService.notifyPlanCheck(planModel, user); } catch (Exception e) { LOG.error("exception occured when publishing PlanModel Notification", e); } } @Override public void notifyPlanCheck(PrecautionPlanModel planModel, PFUser user) throws Exception { NotificationResult result = new NotificationResult(); List<Object> list = new ArrayList<Object>(2); list.add(0,planModel); list.add(1,user);//in order for flex, don't change result.setResult(list); new DataSender().javaToFlex(result); } import flex.messaging.MessageBroker; import flex.messaging.messages.AsyncMessage; @Component public class DataSender { private static Logger log = Logger.getLogger(DataSender.class); public boolean javaToFlex(Object obj) { // log.error("发送一次数据"); MessageBroker msgBroker = MessageBroker.getMessageBroker(null); if (null != msgBroker) { try { String clientID = UUIDUtils.createUUID(); AsyncMessage msg = new AsyncMessage(); msg.setDestination("javaToFlex"); msg.setClientId(clientID); msg.setMessageId(UUIDUtils.createUUID()); msg.setTimestamp(System.currentTimeMillis()); msg.setBody(obj); msgBroker.routeMessageToService(msg, null); log.debug("push data to flex: " + obj); return true; } catch (Exception e) { log.error("Error occurred while push to Flex, Administrated", e); return false; } } return false; } }
现在不明白的是:在1处,前台会向后台请求数据,后台会把大概300个实例传给前台。当前台对个别的实例操作,也就是发事件的时候会调用2处的代码,2处会把该实例发给前台。对实例进行发事件的操作很少。进行测试的结果是:1处查询出来的数据会增加,并且2处发给前台的AsyncMessage也会增加,6天后,tomcat的内存从1G增到3G,最后内存溢出。为什么后台传给前台的数据不释放呢?后台很少发事件给前台,进过5 6天后,AsyncMessage bean怎么会那么多呢? java+flex的项目,怎么优化内存的释放呢?
这个我遇到过,但记不太清了,应该在 DataSender 里做文章。我看看再说######@站在巨人的肩膀上奋斗 AsyncMessage msg提升为类变量######回复 @站在巨人的肩膀上奋斗 : 这个类是第三方提供的######回复 @站在巨人的肩膀上奋斗 : AsyncMessage msg = new AsyncMessage();这个弄成单例的试试######帅哥,我这个问题有结果了吗?期待您的回复######谢谢,麻烦您了######看那个对象多,然后一层一层找######PrecautionPlanModel 这个对象多,但就是前台打开页面的时候才会生成该对象的集合,当下次打开的时候会不会释放呢? AsyncMessage也多,但很少发事件,它怎么也多呢?######new DataSender().javaToFlex(result);这个为啥是new的######也可以不new的,使用注入,不是这的问题吧?###### @红薯 帮帮忙呀,没人回复呀 伤心呀
######不会,帮顶######既然是java做后台,可以使用java的一些监测工具 ######自测就用的监控,我已经给出结果了呀######代码看起来没多大问题,看你的样子,JVM的内存设置比较大,只有到达一定比例,JVM才会回收内存。你的报错信息也是可以贴出来的。######是的,设置了3g,跑起来就用了1g,据说是按比例分配的。你说的达到一定的比例才会释放,什么意思?快3g的时候,手动释放都不行。最后看到有两个map和一个message相当占内存######吧所有new出来的局部变量改为全局的一个个的试。 AsyncMessage NotificationResult我记得就是那个对象没释放,具体的记不得了######大哥,帮我再回忆下,怎么释放呢?######java里面的对象没释放?试试在操作后把对象设置为null。######java虚拟机没有那么脆弱吧######这是什么通信?######我负责后台,通信的方式见图片,相信flex的朋友会知道的
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。