服务器之家:专注于服务器技术及软件下载分享
分类导航

DEDECMS|帝国CMS|Discuz|PHPCMS|Wordpress|ZBLOG|ECSHOP|苹果CMS|极致CMS|CMS系统|

服务器之家 - 建站程序 - ZBLOG - Z-Blog 留言评论显示IP地址和性能优化

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

2019-10-09 16:09ZBlog建站网 ZBLOG

前些天的一些突发事件,使得我发现了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地址。(原文)

延伸 · 阅读

精彩推荐
  • ZBLOGz-blog插件的制作过程步骤分享

    z-blog插件的制作过程步骤分享

    有关z-blog插件的制作过程步骤,在搜索引擎里至今没有发现一篇详细的教程,官方也没有给出一个详细的实例,所以不少跃跃欲试的朋友,却找不到方向,...

    zblog教程网6522019-10-10
  • ZBLOG安装zblog程序时数据库连接失败

    安装zblog程序时数据库连接失败

    问:如图所示,之前安装过程序,现在安装程序就成这样了,安装程序时数据库连接失败 答:您好,站点 根目录下的 zb_users/ c_option.php 中的数据库配置文件...

    未知822023-05-07
  • ZBLOGZ-blog错误原因:未知错误ID:-2147467259

    Z-blog错误原因:未知错误ID:-2147467259

    最近很多人都碰到一个问题:在索引重建的时候出现了操作必须使用一个可更新的查询 错误原因:未知错误ID:-2147467259。 摘要: 操作必须使用一个可更新的查...

    Zblog教程网6502019-10-07
  • ZBLOG刚上传了个ZBLOG的打开怎么显示这样子

    刚上传了个ZBLOG的打开怎么显示这样子

    问:FTP(上传)用户名: 刚上传了个ZBLOG的打开怎么显示这样子 500InternalPrivoxyError Privoxyencounteredanerrorwhileprocessingyourrequest: Couldnotloadtemplatefileno-server-datao...

    未知842023-05-07
  • ZBLOGZ-Blog博客设置技巧:设置Gravatar头像无法显示的方法

    Z-Blog博客设置技巧:设置Gravatar头像无法显示的方法

    Gravatar是“全球通用头像”,在任何支持Gravatar的网站和博客中,填写填写申请注册Gravatar头像用的这个Email地址,你的头像就会出现在留言和评论系统中。...

    zblog教程网5342020-08-21
  • ZBLOGzblog伪静态设置教程

    zblog伪静态设置教程

    zblog默认是动态页面链接,从seo角度考虑,做成静态链接会更好一些,zblog的伪静态设置还是挺方便的,下面来看一下如何设置 ...

    万书涛8012021-07-12
  • ZBLOGz-blog如何刷新和显示浏览计数

    z-blog如何刷新和显示浏览计数

    1.更新浏览计数 在打开单页日志后产生,每刷新一次,计数加1。 注意:只有在b_article-single.html有以下及第3步中介绍的代码,浏览计数才有效。 在b_articl...

    zblog教程网4022019-10-06
  • ZBLOGzblog提示授权文件非法的解决办法

    zblog提示授权文件非法的解决办法

    本文为大家介绍zblog提示授权文件非法的解决办法,有需要的朋友可以参考下...

    zblog教程网13702021-07-12