数据同步
在用Servlet构建的Web应用时如果不注意线程安全的问题,会使所写的Servlet程序有难以发现的错误。其实所有web程序实现都需要注意这些问题。
1、实现 SingleThreadModel 接口(将引起大量的系统开销)
该接口指定了系统如何处理对同一个Servlet的调用。如果一个Servlet被这个接口指定,那么在这个Servlet中的service方法将不会有两个线程被同时执行,当然也就不存在线程安全的问题。这种方法只要继承这个接口就行了
2、同步对共享数据的操作:被同步的代码块在同一时刻只能有一个线程执行它,使得其同时处理客户请求的吞吐量降低,而且很多客户处于阻塞状态
使用synchronized 关键字能保证一次只有一个线程可以访问被保护的区段,在本论文中可以通过同步块操作来保证Servlet的线程安全。
3、避免使用实例变量。线程安全问题还有些是由实例变量造成的,只要在Servlet里面的任何方法里面都不使用实例变量,那么该Servlet就是线程安全的。
4、通过mysql,redis的锁来实现。乐观锁和悲观锁。
幂等性
同一个用户的多个请求结果一致。
比如通过IP,request id等进行请求过滤。