Nginx+Tomcat+Memcached共享session后一直报警告

Nginx+Tomcat+Memcached共享session后一直报警告,第1张

我这边在高并发的情况下也会报出此错误。

此时在程序里面获取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"/>

并且在处理业务逻辑的类上采用注解

@Service

public 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:等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/web/9335306.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-27
下一篇2023-04-27

发表评论

登录后才能评论

评论列表(0条)

    保存