
我这边在高并发的情况下也会报出此错误。
此时在程序里面获取session的时候,session明显异常了,从session里面拿出来的用户也不对。
然后从这里面拿出来的对象的值去构造字符串信息发送给iframe,此时就不对了。
发送下去的串,肯定的不行了。
当Worker创建Executor的时候,会启动一个线程来创建这个Executor,并且等待获取Executor进程的退出状态。
如果Executor异常退出,这个线程就会知道,然后就会发信息告知Worker。
Worker收到消息后,就会把这个消息转发给Master。这个消息会携带Application的ID和Executor的ID。
Master收到消息后,就会根据Application的ID和Executor的ID找到Master内存中Application和Executor信息,并告知Application。
然后把ApplicationInfo中对应的Executor以及WorkerInfo对应的Executor移除掉。
ApplicationInfo移除Executor时,会记录被移除的Executor,把Executor从executors中移除,并且把申请到的CPU资源扣减回去。
WorkerInfo移除Executor时,会把Executor占用的CPU、内存资源扣减回去。
由于Executor已经退出,以及Master保存的申请的资源也还原,所以Master会重新给Application进行资源调度。
你的代码有三个问题:
1,数组越界问题 ,sidOnLineListremove(studentgetSid()); // 移除
这个E remove(int index);是位置,还不是学生的号码,这直接导至这个异常。
2,多线程并发问题,List<Integer> sidOnLineList 这列表如果选用非线程安全实现,那当多个用户并发登录注消就会有问题 。如果选用线程安全实现,则性能会有问题 。推荐使用ConcurrentHashMap。
3,内容泄漏问题,如果用户不是主动退出(如超时或直接关掉浏览器),则会有内存溢出问题 。所以队列需要有超时或先进先出机制。
把你的LiuyanDAO整个类贴上来看看,还有你的session是调用父类的getSession()方法得来的,那么你的父类是什么?LiuyanDAO和其他几个DAO都是继承或实现的一个类或接口吗? 框架上的问题仅看出错的地方有可能看不出来的。
还有,我想父类的getSession()方法中有个sessionFactory的bean吧,通过这个sessionFactory才能得到session,看看你的sessionFactory的类,不过你的其他的Dao都是通过它得来的,估计这里问题不大。
Hibernate4 与 spring3 集成之后, 如果在取得session 的地方使用了getCurrentSession, 可能会报一个错:“No Session found for current thread”, 这个错误的原因,网上有很多解决办法, 但具体原因的分析,却没有多少, 这里一个原理分析:
SessionFactory的getCurrentSession并不能保证在没有当前Session的情况下会自动创建一个新的,这取决于CurrentSessionContext的实现,SessionFactory将调用CurrentSessionContext的currentSession()方法来获得Session。在Spring中,如果我们在没有配置TransactionManager并且没有事先调用SessionFactoryopenSession()的情况直接调用getCurrentSession(),那么程序将抛出“No Session found for current thread”异常。如果配置了TranactionManager并且通过@Transactional或者声明的方式配置的事务边界,那么Spring会在开始事务之前通过AOP的方式为当前线程创建Session,此时调用getCurrentSession()将得到正确结果。
然而,产生以上异常的原因在于Spring提供了自己的CurrentSessionContext实现,如果我们不打算使用Spring,而是自己直接从hibernatecfgxml创建SessionFactory,并且为在hibernatecfgxml
中设置current_session_context_class为thread,也即使用了ThreadLocalSessionContext,那么我们在调用getCurrentSession()时,如果当前线程没有Session存在,则会创建一个绑定到当前线程。
Hibernate在默认情况下会使用JTASessionContext,Spring提供了自己SpringSessionContext,因此我们不用配置current_session_context_class,当Hibernate与Spring集成时,将使用该SessionContext,故此时调用getCurrentSession()的效果完全依赖于SpringSessionContext的实现。
在没有Spring的情况下使用Hibernate,如果没有在hibernatecfgxml中配置current_session_context_class,有没有JTA的话,那么程序将抛出"No CurrentSessionContext configured!"异常。此时的解决办法是在hibernatecfgxml中将current_session_context_class配置成thread。
在Spring中使用Hibernate,如果我们配置了TransactionManager,那么我们就不应该调用SessionFactory的openSession()来获得Sessioin,因为这样获得的Session并没有被事务管理。
至于解决的办法,可以采用如下方式:
1 在spring 配置文件中加入
<tx:annotation-driven transaction-manager="transactionManager"/>并且在处理业务逻辑的类上采用注解
@Servicepublic class CustomerServiceImpl implements CustomerService {
@Transactional
public void saveCustomer(Customer customer) {
customerDaoImplsaveCustomer(customer);
}
}
另外在 hibernate 的配置文件中,也可以增加这样的配置来避免这个错误:
<property name="current_session_context_class">thread</property>以上就是关于Nginx+Tomcat+Memcached共享session后一直报警告全部的内容,包括:Nginx+Tomcat+Memcached共享session后一直报警告、sparksession异常退出、java.lang.IndexOutOfBoundsException:等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)