Z-Blog性能优化和评论IP显示

来源:月光博客 时间:2010-01-22 16:24:00 

前些天的一些突发事件,使得我发现了Z-Blog存在的一个很严重的性能问题,就是当单篇文章日访问量数万的时候,会有大量并发用户同时写Access数据库,会导致数据库死锁,之后的外在表现就是CPU占用猛增。

经过对Z-Blog的代码进行分析,我发现其原因是大并发用户同时写数据库产生的原因。

我这里想到了一个针对这个问题的解决方案,就是时间缓存,定时写数据库,在一定时间内,数据只写入内存,不写入数据库,当缓存时间到了以后,再把内存的数据写入数据库。这样,即使再大的并发量,也不会再发生数据库死锁的问题了。

经过初步的代码修改和测试,发现修改完了以后就没有这个问题了。

修改方法是,打开FUNCTION目录下的c_html_js.asp文件,修改UpdateCountInfo函数为以下代码即可。

Function UpdateCountInfo(id)

 Dim strLastUpdate
 Dim intArticleCount
 Dim aryArticleCount
 Dim objRS

 Application.Lock
 strLastUpdate=Application(ZC_BLOG_CLSID&"LAST_UPDATE")
 aryArticleCount=Application(ZC_BLOG_CLSID&"CACHE_ARTICLE_VIEWCOUNT")
 aryArticleCount(id)=aryArticleCount(id)+1
 Application(ZC_BLOG_CLSID&"CACHE_ARTICLE_VIEWCOUNT")=aryArticleCount
 Application.UnLock

 If IsEmpty(strLastUpdate) Or Not IsDate(strLastUpdate) Then
  Application.Lock
  Application(ZC_BLOG_CLSID&"LAST_UPDATE") = Now()
  strLastUpdate = Application(ZC_BLOG_CLSID&"LAST_UPDATE")
  Application.UnLock
 End If

 If DateDiff("s",strLastUpdate,Now()) > 30 Then
 '如果当前时间与上次保存计数值的时间差大于设定的时间间隔,则把计数值重新写入数据库
  Call OpenConnect()

  Set objRS=objConn.Execute("SELECT [log_ID],[log_ViewNums] FROM [blog_Article] WHERE [log_ID] =" & id)
  If (not objRS.bof) And (not objRS.eof) Then
   intArticleCount=objRS("log_ViewNums")
  Else
   intArticleCount=0
  End If
  objRS.Close
  Set objRS=Nothing

  If aryArticleCount(id) > intArticleCount Then
   objConn.Execute("UPDATE [blog_Article] SET [log_ViewNums]=" & CStr(aryArticleCount(id)) & " WHERE [log_ID] =" & id)
   Application.Lock
   Application(ZC_BLOG_CLSID&"LAST_UPDATE") = Now()
   Application.UnLock
  Else
   aryArticleCount(id) = intArticleCount
   Application.Lock
   Application(ZC_BLOG_CLSID&"CACHE_ARTICLE_VIEWCOUNT")=aryArticleCount
   Application.UnLock
  End If

  Call CloseConnect()
 End If

End Function

另外,默认的Z-Blog留言评论是没有用户IP地址显示的,通过一些修改,可以在留言中增加用户IP地址前三位的显示功能,具体实现方法如下。

修改c_system_lib.asp文件的Public Function MakeTemplate(strC)函数,加入下面语句:

 ReDim aryTemplateTagsName(12)
  ReDim aryTemplateTagsValue(12)

  aryTemplateTagsName( 12)="article/comment/ip"
  if AuthorID=1  then
   aryTemplateTagsValue(12)=""
  else
   aryTemplateTagsValue(12)="ip:" + Left(IP, InStrRev(IP, ".")) + "*"
  end if

  修改TArticle的Function Export_CMTandTB()函数,将 objComment.LoadInfoByArray(Array(objRS("comm_ID"),objRS("log_ID"),objRS("comm_AuthorID"),objRS("comm_Author"),objRS("comm_Content"),objRS("comm_Email"),objRS("comm_HomePage"),objRS("comm_PostTime"),"","")) 改为 objComment.LoadInfoByArray(Array(objRS("comm_ID"),objRS("log_ID"),objRS("comm_AuthorID"),objRS("comm_Author"),objRS("comm_Content"),objRS("comm_Email"),objRS("comm_HomePage"),objRS("comm_PostTime"),objRS("comm_IP"),""))

  修改 b_article_comment.html ,增加 <#article/comment/ip#>标签。

之后,文章评论就会出现评论者的IP地址栏,不过有个问题是,当评论有人回复的是时候,只能留下最后一个回复者的IP地址。

标签:z-blog,性能,优化,access数据库
0
投稿

猜你喜欢

  • 冲浪DDoS(拒绝服务)攻击的趋势与防御

    2009-12-08 14:14:00
  • 对毕业一二年的站长朋友的一些话

    2007-12-23 17:34:00
  • Linux系统下利用C程序输出某进程的内存占用信息

    2023-11-03 03:39:27
  • 关于最近百度大更新的一些思考

    2009-09-11 13:11:00
  • 在VMware Workstation中搭建VMware vSphere(图文教程)

    2023-11-04 03:32:53
  • 关于Linux下conda安装caffe与pb转caffe问题

    2023-01-29 19:15:23
  • 调整Windows参数提高数据库服务器性能

    2009-06-15 10:46:00
  • 详解linux软连接和硬链接

    2023-03-27 09:19:36
  • Twitter官方开测Retweet功能 或明年推广

    2009-11-09 08:47:00
  • 在 awk 中使用循环

    2021-10-17 23:46:40
  • 提高单价:只针对搜索引擎显示Adsense广告

    2009-03-31 16:20:00
  • 虚拟主机如何解决电信网通间互联互通

    2007-06-26 16:33:00
  • YouTube称下周起将支持1080p全高清视频播放

    2009-11-13 11:43:00
  • 就像谈恋爱结婚样 对关键词也要非诚勿扰

    2009-01-03 15:18:00
  • 新版火狐3浏览器首日下载量突破800万

    2008-06-19 13:45:00
  • PHPWind7.3特色功能推荐

    2009-04-19 18:37:00
  • 授予对Web内容的Web服务器权限

    2009-07-23 16:09:00
  • 远程也能修改FTP用户密码

    2009-05-19 09:43:00
  • linux下vsftpd的安装及配置使用详细步骤(推荐)

    2023-11-02 17:02:57
  • 分享购买ixwebhosting主机的过程

    2010-03-23 13:40:00
  • asp之家 网站运营 m.aspxhome.com