前些天的一些突發(fā)事件,使得我發(fā)現(xiàn)了Z-Blog存在的一個很嚴(yán)重的性能問題,就是當(dāng)單篇文章日訪問量數(shù)萬的時候,會有大量并發(fā)用戶同時寫Access數(shù)據(jù)庫,會導(dǎo)致數(shù)據(jù)庫死鎖,之后的外在表現(xiàn)就是CPU占用猛增。
經(jīng)過對Z-Blog的代碼進行分析,我發(fā)現(xiàn)其原因是大并發(fā)用戶同時寫數(shù)據(jù)庫產(chǎn)生的原因。
我這里想到了一個針對這個問題的解決方案,就是時間緩存,定時寫數(shù)據(jù)庫,在一定時間內(nèi),數(shù)據(jù)只寫入內(nèi)存,不寫入數(shù)據(jù)庫,當(dāng)緩存時間到了以后,再把內(nèi)存的數(shù)據(jù)寫入數(shù)據(jù)庫。這樣,即使再大的并發(fā)量,也不會再發(fā)生數(shù)據(jù)庫死鎖的問題了。
經(jīng)過初步的代碼修改和測試,發(fā)現(xiàn)修改完了以后就沒有這個問題了。
修改方法是,打開FUNCTION目錄下的c_html_js.asp文件,修改UpdateCountInfo函數(shù)為以下代碼即可。
Function UpdateCountInfo(id) Dim strLastUpdate Application.Lock If IsEmpty(strLastUpdate) Or Not IsDate(strLastUpdate) Then If DateDiff("s",strLastUpdate,Now()) > 30 Then Set objRS=objConn.Execute("SELECT [log_ID],[log_ViewNums] FROM [blog_Article] WHERE [log_ID] =" & id) If aryArticleCount(id) > intArticleCount Then Call CloseConnect() End Function |
另外,默認(rèn)的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" 修改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#>標(biāo)簽。 |
之后,文章評論就會出現(xiàn)評論者的IP地址欄,不過有個問題是,當(dāng)評論有人回復(fù)的是時候,只能留下最后一個回復(fù)者的IP地址。(原文)
江西省上饒市廣信區(qū)三清山中大道588號7棟5號
電話:0793-8313026 7094119
傳真:0793-8313026
手機:18079306668 13576325382 曾
郵箱:174216168@qq.com
QQ:174216168
Copyright © 2008-2019 (srlrcm.cn) 獵人傳媒. All Rights Reserved.
贛ICP備08101270號-1 百度統(tǒng)計