<s id="tzxwp"></s>
<address id="tzxwp"><var id="tzxwp"><ruby id="tzxwp"></ruby></var></address>

<dfn id="tzxwp"><cite id="tzxwp"><source id="tzxwp"></source></cite></dfn>
<label id="tzxwp"><tt id="tzxwp"></tt></label>

Z-Blog性能優(yōu)化和評論IP顯示

建站經驗 / 2010-01-22 10:24:00

前些天的一些突發(fā)事件,使得我發(fā)現(xiàn)了Z-Blog存在的一個很嚴重的性能問題,就是當單篇文章日訪問量數(shù)萬的時候,會有大量并發(fā)用戶同時寫Access數(shù)據庫,會導致數(shù)據庫死鎖,之后的外在表現(xiàn)就是CPU占用猛增。

經過對Z-Blog的代碼進行分析,我發(fā)現(xiàn)其原因是大并發(fā)用戶同時寫數(shù)據庫產生的原因。

我這里想到了一個針對這個問題的解決方案,就是時間緩存,定時寫數(shù)據庫,在一定時間內,數(shù)據只寫入內存,不寫入數(shù)據庫,當緩存時間到了以后,再把內存的數(shù)據寫入數(shù)據庫。這樣,即使再大的并發(fā)量,也不會再發(fā)生數(shù)據庫死鎖的問題了。

經過初步的代碼修改和測試,發(fā)現(xiàn)修改完了以后就沒有這個問題了。

修改方法是,打開FUNCTION目錄下的c_html_js.asp文件,修改UpdateCountInfo函數(shù)為以下代碼即可。

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
 ''如果當前時間與上次保存計數(shù)值的時間差大于設定的時間間隔,則把計數(shù)值重新寫入數(shù)據庫
  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地址前三位的顯示功能,具體實現(xiàn)方法如下。

修改c_system_lib.asp文件的Public Function MakeTemplate(strC)函數(shù),加入下面語句:

 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()函數(shù),將 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#>標簽。

之后,文章評論就會出現(xiàn)評論者的IP地址欄,不過有個問題是,當評論有人回復的是時候,只能留下最后一個回復者的IP地址。(原文

訂閱號

上饒幫

服務號

獵人傳媒

久久毛片无码av_久久无码视频黄色_99精品久久99久久久久_国产一级黄片免费观看视频 欧美高清久久久久久69 国产毛片天天看视频
<s id="tzxwp"></s>
<address id="tzxwp"><var id="tzxwp"><ruby id="tzxwp"></ruby></var></address>

<dfn id="tzxwp"><cite id="tzxwp"><source id="tzxwp"></source></cite></dfn>
<label id="tzxwp"><tt id="tzxwp"></tt></label>

av喷水高潮喷水在线观看| 成人www在线观看| 欧美日韩在线免费播放一二三区| 91日韩精品久久久精品无码| 国产精品亚洲专区在线观看| 精品国产91| 亚洲黄色无码免费网站| 国产亚洲综合91精品| 色婷婷5月综合久久| 亚洲中文久久精品无码91| av有码在线亚洲中文| 日韩AV无码综合网| 亚洲男女在线观看视频| 中文字幕精品aⅴ专区| 日韩精品亚洲人成在线观看| 婷婷丁香中文在线综合一区| 久热中文字幕在线精品观看| 毛片精品视频一区二区三区| 国产亚洲精品bt天堂精选| 五月婷婷无码在线|