java+flex项目的性能问题

站在巨人的肩膀上奋斗 发布于 2013/04/27 20:58
阅读 1K+
收藏 1

对您的回复,小弟不胜感激。。。

该问题是:关于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;
	}
}


DataSender,该类的作用是:自己写的用于把java数据传给前台flex的类。

现在不明白的是:在1处,前台会向后台请求数据,后台会把大概300个实例传给前台。当前台对个别的实例操作,也就是发事件的时候会调用2处的代码,2处会把该实例发给前台。对实例进行发事件的操作很少。进行测试的结果是:1处查询出来的数据会增加,并且2处发给前台的AsyncMessage也会增加,6天后,tomcat的内存从1G增到3G,最后内存溢出。为什么后台传给前台的数据不释放呢?后台很少发事件给前台,进过5 6天后,AsyncMessage bean怎么会那么多呢? java+flex的项目,怎么优化内存的释放呢?

加载中
0
noday
noday
这个我遇到过,但记不太清了,应该在 DataSender 里做文章。我看看再说
noday
noday
@站在巨人的肩膀上奋斗 AsyncMessage msg提升为类变量
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
回复 @站在巨人的肩膀上奋斗 : 这个类是第三方提供的
noday
noday
回复 @站在巨人的肩膀上奋斗 : AsyncMessage msg = new AsyncMessage();这个弄成单例的试试
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
帅哥,我这个问题有结果了吗?期待您的回复
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
谢谢,麻烦您了
0
noday
noday
看那个对象多,然后一层一层找
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
PrecautionPlanModel 这个对象多,但就是前台打开页面的时候才会生成该对象的集合,当下次打开的时候会不会释放呢? AsyncMessage也多,但很少发事件,它怎么也多呢?
0
noday
noday
new  DataSender().javaToFlex(result);这个为啥是new的
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
也可以不new的,使用注入,不是这的问题吧?
0
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
@红薯 帮帮忙呀,没人回复呀 伤心呀
0
南湖船老大
南湖船老大
不会,帮顶
0
星爷
星爷
既然是java做后台,可以使用java的一些监测工具 
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
自测就用的监控,我已经给出结果了呀
0
星爷
星爷
代码看起来没多大问题,看你的样子,JVM的内存设置比较大,只有到达一定比例,JVM才会回收内存。你的报错信息也是可以贴出来的。
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
是的,设置了3g,跑起来就用了1g,据说是按比例分配的。你说的达到一定的比例才会释放,什么意思?快3g的时候,手动释放都不行。最后看到有两个map和一个message相当占内存
0
noday
noday
吧所有new出来的局部变量改为全局的一个个的试。 AsyncMessage  NotificationResult我记得就是那个对象没释放,具体的记不得了
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
大哥,帮我再回忆下,怎么释放呢?
0
amonxu
amonxu
java里面的对象没释放?试试在操作后把对象设置为null。
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
java虚拟机没有那么脆弱吧
0
vvtf
vvtf
这是什么通信?
站在巨人的肩膀上奋斗
站在巨人的肩膀上奋斗
我负责后台,通信的方式见图片,相信flex的朋友会知道的
返回顶部
顶部