当前位置:始祖网址提交 » 站长资讯 » 免费资源 » 技术文章 » 文章详细

提高Z-Blog博客性能优化、增加评论IP显示功能

来源:站长分类目录 浏览:332次 时间:2014-10-26

前些天有用Z-Blog做博客的站长使用发现,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地址。

推荐站点

  • 快速提升门_医用门_卷帘防火门快速提升门_医用门_卷帘防火门

    衢州玖亿门业有限公司是集生产销售维护为一体的现代化企业:主要产品有:电动伸缩门、电动感应门、PV快速门、电动抗风门、电动车库门、电动卷闸门、电动水晶门、电动防火门、快速提升门、停车系统、智能道闸等产品。 本公司有多名资深技术工程安装师傅,还培养了一批熟练的技工,员工具有丰富的安装经验,强大的安装工程队伍,让您的工程安装和后期的维护,有更好的保障。 只要您一个电话联系到玖亿,我们会有专业人员上门为您服务,不论您是工程、企业或个人,安装新的门还是维修门,我们都会根据施工现场的实际情况和您的要求给出专业合理的方案供您选择。 企业的宗旨:以人为本客户至上的原则, 与客户真诚合作,和客户建立长期友好的合作关系,用高质量的产品赢得客户满意。给客户提供专业、及时、便捷的服务! 产品造型美观大方、新颖独特,价位合理,安全实用 ,欢迎广大新老客户来电详询。

    www.f58f.com
  • 衢州感应门_衢州快速门_衢州玖亿门业有限公司衢州感应门_衢州快速门_衢州玖亿门业有限公司

    衢州感应门厂家,专业定制、安装、维修各种感应门,为您解决感应门相关的任何疑难杂症。衢州玖亿门业是明智的选择,本公司产品大部分都是定制产品,按照贵司的需求样式尺寸定做,感应门、快速门、伸缩门,电卷闸门以及工厂和小区配套使用的岗亭、道闸、车牌识别、门禁电锁等,本公司一应俱全,一站式服务,解决您的售后顾虑问题。企业的宗旨:用高质量的产品赢得客户满意。给客户提供专业、及时、便捷的服务!

    http://www.door-industry-cn.com/
  • 免费发布信息网站大全_大中国商业信息网免费发布信息网站大全_大中国商业信息网

    大中国商业信息网免费发布不限制条数,大中国商业信息网是一个可以免费发布分类信息的B2B平台。可免费发布您的产品信息!便捷免费的B2B供求信息发布平台

    www.greatcnb2b.com
  • 大中华电子商务网大中华电子商务网

    大中华电子商务网免费发布不限制条数,大中华电子商务网是一个可以免费发布分类信息的B2B平台。可免费发布您的产品信息!便捷免费的B2B供求信息发布平台

    www.greatercnb2b.com
  • 全球商务信息网_中国分类信息网站大全_免费的网络推广平台全球商务信息网_中国分类信息网站大全_免费的网络推广平台

    欢迎访问全球商务信息网,这里有各行业信息网/B2B电子商务网站,是最方便的免费网络推广平台,已成为无数商家网络营销/网络推广的首选网站!

    www.globalb2bcn.com