jsp+java做的网站如何考虑并发量问题

jsp+java做的网站如何考虑并发量问题,第1张

一般采用动静结合的方式,如按条件查询或提交什么表单数据到服务器的,这类动态请求就用servlet(或struts/spring mvc)处理。内容不会再改变的页面可以用Freemarker等将页面静态化,生成html页面。服务器端采用tomcat + nginx来部署。tomcat处理动态请求,并生成静态页面到nginx下,nginx对静态页面的处理一般每台服务器可以达到每秒几万的吞吐量。tomcat由于要处理动态请求,处理并发能力较弱,一般在500-2000左右,具体支持数量视硬件性能、业务复杂度和系统优化配置而定。另外为了减轻数据库压力,还可以采用ehcache或memecached等缓存。以上只是大概说了一下思路,具体实现起来一两句话很难说清的。

使用乐观锁,增加一个时间戳字段,读取该条数据之后,如果用户A准备买该票,那么更新售出字段的同时检查时间戳字段,如果更新的时候时间戳不同,表示有别的用户先抢到了该票。则A用户抢票失败,具体的你可以度娘下

JSP工作原理 JSP

在一个JSP文件第一次被请求时,JSP引擎把该JSP文件转换成为一个servlet。而这个引擎本身也是一个servlet,在JSWDK或WEBLOGIC中,它就是JspServlet。 JSP引擎先把该JSP文件转换成一个Java源文件,在转换时如果发现jsp文件有任何语法错误,转换过程将中断,并向服务端和客户端输出出错信息;如果转换成功, JSP引擎用javac把该Java源文件编译成相应的class文件。然后创建一个该SERVLET的实例,该SERVLET的jspInit()方法被执行,jspInit()方法在servlet的生命周期中只被执行一次。然后jspService()方法被调用来处理客户端的请求。对每一个请求,JSP引擎创建一个新的线程来处理该请求。如果有多个客户端同时请求该JSP文件,则JSP引擎会创建多个线程。每个客户端请求对应一个线程。以多线程方式执行可大大降低对系统的资源需求,提高系统的并发量及响应时间.但应该注意多线程的编程限制,由于该servlet始终驻于内存,所以响应是非常快的。如果.jsp文件被修改了,服务器将根据设置决定是否对该文件重新编译,如果需要重新编译,则将编译结果取代内存中的servlet,并继续上述处理过程。虽然JSP效率很高,但在第一次调用时由于需要转换和编译而有一些轻微的延迟。此外,如果在任何时候如果由于系统资源不足的原因,JSP引擎将以某种不确定的方式将servlet从内存中移去。当这种情况发生时jspDestroy()方法首先被调用, 然后servlet实例便被标记加入"垃圾收集"处理。 jspInit()及jspDestory()格式如下:可在jspInit()中进行一些初始化工作,如建立与数据库的连接,或建立网络连接,从配置文件中取一些参数等,在jspDestory()中释放相应的资源。

<%!

public void jspInit()

{

System.out.println("jspinit")

}

%>

<%!

public void jspDestory()

{

System.out.println("jspDestory")

}

%>


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/53857.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存