JSP高访问量下的计数程序
JSP高访问量下的计数程序
有时要为每一篇文章统计其点击次数,假设每一次阅读都要更新一次库的话,那功能在访问量很大的情况下,服务器的压力就会很大了,比较好一点的方法就是先将要更新的数据缓存起来,然后每隔一段工夫再应用数据库的批量解决,批量更新库。源码如下:
CountBean.java
/*
*CountData.java
*
*Createdon2006年10月18日,下午4:44
*
*Tochangethistemplate,chooseTools|Optionsandlocatethetemplateunder
*theSourceCreationandManagementnode.Right-clickthetemplateandchoose
*Open.YoucanthenmakechangestothetemplateintheSourceEditor.
*/
packagecom.tot.count;
/**
*
*@author
*/
publicclassCountBean{
privateStringcountType;
intcountId;
/**CreatesanewinstanceofCountData*/
publicCountBean(){
}
publicvoidsetCountType(StringcountTypes){
this.countType=countTypes;
}
publicvoidsetCountId(intcountIds){
this.countId=countIds;
}
publicStringgetCountType(){
returncountType;
}
publicintgetCountId(){
returncountId;
}
}
CountCache.java
/*
*CountCache.java
*
*Createdon2006年10月18日,下午5:01
*
*Tochangethistemplate,chooseTools|Optionsandlocatethetemplateunder
*theSourceCreationandManagementnode.Right-clickthetemplateandchoose
*Open.YoucanthenmakechangestothetemplateintheSourceEditor.
*/
packagecom.tot.count;
importjava.util.*;
/**
*
*@author
*/
publicclassCountCache{
publicstaticLinkedListlist=newLinkedList();
/**CreatesanewinstanceofCountCache*/
publicCountCache(){
}
publicstaticvoidadd(CountBeancb){
if(cb!=null){
list.add(cb);
}
}
}
CountControl.java
/*
*CountThread.java
*
*Createdon2006年10月18日,下午4:57
*
*Tochangethistemplate,chooseTools|Optionsandlocatethetemplateunder
*theSourceCreationandManagementnode.Right-clickthetemplateandchoose
*Open.YoucanthenmakechangestothetemplateintheSourceEditor.
*/
packagecom.tot.count;
importtot.db.DBUtils;
importjava.sql.*;
/**
*
*@author
*/
publicclassCountControl{
privatestaticlonglastExecuteTime=0;//上次更新工夫
privatestaticlongexecuteSep=60000;//定义更新间隔工夫,单位毫秒
/**CreatesanewinstanceofCountThread*/
publicCountControl(){
}
publicsynchronizedvoidexecuteUpdate(){
Connectionconn=null;
PreparedStatementps=null;
try{
conn=DBUtils.getConnection();
conn.setAutoCommit(false);
ps=conn.prepareStatement("updatet_newssethits=hits+1whereid=?");
for(inti=0;i<CountCache.list.size();i++){
CountBeancb=(CountBean)CountCache.list.getFirst();
CountCache.list.removeFirst();
ps.setInt(1,cb.getCountId());
ps.executeUpdate();⑴
//ps.addBatch();⑵
}
//int[]counts=ps.executeBatch();⑶
conn.commit();
}catch(Exceptione){
e.printStackTrace();
}finally{
try{
if(ps!=null){
ps.clearParameters();
ps.close();
ps=null;
}
}catch(SQLExceptione){}
DBUtils.closeConnection(conn);
}
}
publiclonggetLast(){
returnlastExecuteTime;
}
publicvoidrun(){
longnow=System.currentTimeMillis();
if((now-lastExecuteTime)>executeSep){
//System.out.print("lastExecuteTime:"+lastExecuteTime);
//System.out.print("now:"+now+"\n");
//System.out.print("sep="+(now-lastExecuteTime)+"\n");
lastExecuteTime=now;
executeUpdate();
}
else{
//System.out.print("waitfor"+(now-lastExecuteTime)+"seconds:"+"\n");
}
}
}
//注:假设你的数据库驱动支持批解决,那么可能将⑵,⑶标记的代码前的注释去掉,同时在代码⑴前加上注释
类写好了,下面是在JSP中如下调用。
<%
CountBeancb=newCountBean();
cb.setCountId(Integer.parseInt(request.getParameter("cid")));
CountCache.add(cb);
out.print(CountCache.list.size()+"<br>");
CountControlc=newCountControl();
c.run();
out.print(CountCache.list.size()+"<br>");
%>