Z-Blog 留言评论显示IP地址和性能优化

所属分类: CMS教程 / z-blog 阅读数: 1415
收藏 0 赞 0 分享

经过对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地址。(原文)

更多精彩内容其他人还在看

zblog2.2实现首页显示指定的分类技巧

zblog2.2的技巧下文分享给大家
收藏 0 赞 0 分享

Z-Blog 使用Tmt主题时修改底部版权的方法

这篇文章主要介绍了Z-Blog 使用Tmt主题时修改底部版权的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

Nginx的Z-Blog的伪静态配置方法

这篇文章主要介绍了Nginx的Z-Blog的伪静态配置方法,需要的朋友可以参考下
收藏 0 赞 0 分享

zblog不显示表情的解决方法

关键字描述:方法 解决 表情 显示 文件 评论 程序 zblog ZBLOG JS 一位网友问我:zblog程序评论不显示表情该怎么办?,自己摸索了下,能够影响zblog程序评论表情不显示的大致有这么3个地方。 1、zblog模版文件 single.htm ,有段JS(
收藏 0 赞 0 分享

Z-blog自定义标签使用教程

关键字描述:教程 使用 标签 定义 < " > pclass 日期 CSS <!--自定义的标签--> <!--AD <divclass="function"id="divZAD">
收藏 0 赞 0 分享

z-blog简洁翻页条的CSS定义

关键字描述:定义 简洁 < 模板 文件 &rdquo &ldquo 如何 对应 留言 其中“更早的文章”和“之后的文章”分别由span标签的pagebar-previous和pagebar-next类定义,你可以用CSS
收藏 0 赞 0 分享

z-blog的目录、留言、引用标签教程

关键字描述:标签 教程 引用 留言 目录 < " /h3> ul> /ul> <!--网站目录 <divclass="function"id="divCatalog"> <h3
收藏 0 赞 0 分享

Z-Blog常用标签说明

关键字描述:说明 标签 常用 < " > id /h3> /ul> h3> <!--文章归档 <divclass="function"id="divArchives"> <h3
收藏 0 赞 0 分享

Z-Blog文章列表区标签与特殊标签说明

关键字描述:标签 说明 特殊 文章 < default.html catalog.html 文章列表区 多页排列的分页条: <#template:pagebar#>:由default.html和catalog.html引用 <#pageb
收藏 0 赞 0 分享

Z-Blog日历标签与控制面板标签说明

关键字描述:标签 说明 面板 控制 日历 < " > /div> /h3> <!--日历标签 <divclass="function"id="divCalendar"> <h3
收藏 0 赞 0 分享
查看更多