首先Servlet 是运行在服务器端的Java程序,能接收客户端的请求并且做出响应。
Servlet还是B/S架构,是学习Java不可缺少的一部分,servlet的优点很多,首先它客户端毫无维护成本,而且它与操作平台关系及小。但是它在响应速度和安全性上需要花费更多的成本。
下面我们来了解一下servlet的线程安全与不安全的问题:
servlet一般是单例的!如果你不针对同一个Servlet配置多个Servlet名称和映射的情况下,它都是单例的。
Servlet体系结构是建立在Java多线程机制之上的,它的生命周期是由Web容器负责的。当客户端第一次请求某个Servlet时,Servlet容器将会根据web.xml配置文件实例化这个Servlet类。当有新的客户端请求该Servlet时,一般不会再实例化该Servlet类,也就是有多个线程在使用这个实例。Servlet容器会自动使用线程池等技术来支持系统的运行,当两个或多个线程同时访问同一个Servlet时,可能会发生多个线程同时访问同一资源的情况,数据可能会变得不一致。所以在用Servlet构建的Web项目时如果不注意线程安全的问题,会使所写的Servlet程序有很难发现的错误。所所以Servlet的报错一般很难归根结底的找到。
总结:
Servlet的线程安全问题只有在大量的并发访问时才会显现出来,并且很难发现,因此在编写Servlet程序时要特别注意。线程安全问题主要是由实例变量造成的,因此在Servlet中应避免使用实例变量。