伺服器訪問量超載如何升級
在ASP中優化資料庫處理
ASP是一個WEB伺服器端的開發環境,它提供了一種簡單易學的腳本(VBScript或Jscript),並帶有許多內置的對象,從而提供了一條簡捷的編程之路。更為重要的是,ASP中提供了ADO對象,讓程序員可以輕松操作各種資料庫,從而可以產生和運行動態的、交互的WEB服務應用程序。目前,國內很多電子商務站點都採用了ASP技術來與資料庫交互,為用戶提供各類服務。
由於電子商務站點的大部分信息都存放在資料庫中,要提高WEB的響應速度,建立高性能的電子商務站點,很大一部分取決於ASP與資料庫之間的處理性能。因此,在ASP編寫時,要注意資料庫處理方法。
1、 使用Connection pool機制
在資料庫處理中,資源花銷最大的是建立資料庫連接,而且用戶還會有一個較長的連接等待時間。若每一個用戶訪問時,都重新建立連接,不僅用戶要長時間等待,而且系統有可能會由於資源消耗過大而停止響應。如果能夠重用以前建立的資料庫連接,而不是每次訪問時都重新建立連接,則可以很好地解決這些問題,從而提高整個系統的性能。在IIS+ASP處理體系中,採用了Connection pool機制來保證這一點。
Connection pool的原理是,IIS+ASP體系中維持了一個連接緩沖池,建立好的資料庫連接在ASP程序中的斷開都是邏輯斷開,而實際的物理連接被存儲在池中並被維護。這樣,當下一個用戶訪問時,直接從連接緩沖池中取得一個資料庫連接,而不需重新連接資料庫,因此,可以大大地提高系統的響應速度。
為了正確使用Connection pool時,必須注意以下幾點:
a). 在MDAC2.0以前的版本中,必須經過資料庫驅動程序的配置才能使用Connection Pool;在以後的版本中(比如MDAC2.1),預設是使用Connection Pool機制。具體配置情況可以參見微軟公司的站點()。
順便提一句,在使用ORACLE資料庫時,最好使用微軟提供的驅動程序。
b). 每次資料庫連接串參數必須相同,否則會被認為是不同的連接而重新去連接資料庫,而不是使用緩沖池中的連接。最好的做法是將連接串存儲在Application變數中,所有的程序在建立連接時使用Application變數的值。
c). 為了更好地使用和維護連接緩沖池,建議在程序中使用以下的方法對資料庫連接進行操作,因為隱式使用資料庫連接時不能利用緩沖池的機制:
¨ 顯示地創建連接對象: Set conn=Server.CreateObject(「Adodb.connection」)
¨ 建立資料庫連接:conn.open Application(「connection_string」),…
¨ 進行資料庫操作:…
¨ 顯式地關閉連接對象:conn.close
2、 利用直接的Ole DB驅動程序
在Asp中,通過ADO可以使用兩種方式連接資料庫,一種是傳統的ODBC方式,一種是Ole DB方式。由於ADO是建立在Ole DB技術上的,為了支持ODBC,必須建立相應的Ole DB 到ODBC的調用轉換(如MS Oledb provider for ODBC)。而使用直接的Ole DB方式(如MS Oledb provider for sql, Oracle),則不需轉換,從而提高處理速度,同時,還能利用Ole DB的新特性。
3、 在內存中緩存ADO對象或其內容
通常,在ASP程序中,都會涉及到一些存儲在資料庫中的常用信息,如省份列表,商品分類等,這些信息對於每一個訪問用戶都是相同的。若每一個用戶訪問時,都要去資料庫里取出來,然後顯示給用戶,不僅會使資料庫伺服器負載加重,無法快速服務於更重要的事務處理,而且WEB伺服器也必須不停地創建ADO對象,消耗大量資源,導致了當用戶很多時幾乎失去響應。若能把一些常用信息事先存儲在內存中,當用戶訪問時,直接從內存中取出,顯示給用戶,則可以大大減小系統的壓力,提高響應速度。
比如,我們可以把已經取得了數據的RecordSet對象存儲在Application變數中,當用戶訪問時,從Application變數中取得RecordSet對象,而不需再次建立資料庫連接;也可以將RecordSet對象里的數據以其他方式存儲,比如存儲在數組中,然後再將數組存儲在Application變數中,使用時用數組的方式讀取。
需要注意的是,一個對象要存儲在Application變數中,線程模式必須是Both;對於不滿足該條件的對象,必須以其他方式,比如轉換成數組的方式存儲在Application變數中,這也是上面所說的將內容存儲在數組中的原因。
4、 使用數字序列
在Asp程序中,從諸如RecordSet中讀取數據時,為了方便,常使用資料庫列名的方式進行:
Response.write rs(「fieldnameN」)
而很少採用該資料庫列名所在的數字序列來讀取,即:
Response.write rs(N)
其實,為了從RecordSet得到列值,ADO必須將列名轉化為數字序列,因此,若直接使用數字序列,則可以提高讀取速度。若感覺使用數字序列,程序可讀性不直觀,可以採用建立常量的方法,定義:
const FIELDNAME1 1
5、 使用資料庫過程(procere)
在電子商務站點中,尤其是要進行交易的站點,為了完成交易,可能需要多次查詢大量的信息,用於判定是非,然後更新入庫。若在編寫Asp時,直接在一個程序中作多次資料庫操作,不僅IIS要創建很多ADO對象,消耗資源,而且加重了資料庫伺服器的負擔,增大了網路流量。若把多次資料庫操作流程定義為一個資料庫過程,用如下方式調用:
connection.execute 「」
則可以利用資料庫的強大性能,大大減輕Web系統的壓力,而且由於頁面內容與業務分開,管理維護也變得方便。
6、 使用優化過的sql語句
對於電子商務網站,最主要的就是要保證,不論訪問用戶的多少,系統都要有足夠快的響應速度。由於在Asp技術中,ADO對象消耗的資源是非常大的,若一個sql語句要執行很長的一段時間,對整個資源也將一直佔用,使系統沒有足夠的資源服務於其它用戶。因此,盡量使用優化過的sql語句,減少執行時間。比如,不使用在in語句中包含子查詢的語句,充分利用索引。
7、 利用資料庫的特性
ADO是一套通用的對象控制項,本身沒有利用資料庫的任何特性。但若在Asp程序編寫時,有意識地考慮結合資料庫的特性,往往可以有很好的效果。
比如,Oracle資料庫伺服器對於執行過的sql語句,通常都經過了分析優化,並存儲在一個sql內存緩沖區中,當下次同樣的sql語句請求時,直接從內存緩沖區取出執行,不再進行分析優化,從而可以大幅度提高性能。這就要求在Asp程序編寫時,盡量使用相同的Sql語句,或者參數化的Sql語句:
Set cmd=Server.createobject(「adodb.command」)
cmd.CommandText=」select * from proct where proctcode=?」
8、 用時創建,用完釋放
在前面也提到過,ADO對象是非常消耗資源的,因此一定要牢牢記住,只在用到ADO對象時才創建,用完後馬上釋放:
set rs=Server.createobject(「adodb.recordset」)
….
rs.close
set rs=nothing
願您愉快地編程,讓人們享受社會信息化所帶來的好處。
2. 伺服器帶寬跑滿了怎麼辦
造成伺服器帶寬跑滿的原因有很多,大致可以歸結為以下幾類:
病毒
Windows 系統伺服器中病毒或站點掛馬,導致伺服器內部有對外發包的文件。
建議在伺服器上安裝殺毒軟體,進行殺毒。可以通過任務管理器中查看是否異常進程。當前阿里雲暫時沒有提供殺毒軟體,您可以登陸伺服器根據自己的日常使用的殺毒軟體進行安裝即可。
網路攻擊
伺服器或站點遭受 DDOS 攻擊或 CC 攻擊等,短期內產生大量的訪問需求。
可以登陸阿里雲管理控制台,查看雲盾中的防護 DDOS 攻擊是否調整好閾值,並核實是否開啟CC防護。
目前CC防護有自己默認的閾值,由於安全問題此閾值暫時不對外公開。如果攻擊沒有觸發到閾值,雲盾沒有清洗,可以提交工單到售後請手工協助開起清洗,後期該調整閾值的功能會對外放。
存在耗資源進程
伺服器內部有耗資源進程。
Windows Server 2003 系統無法直接查看到,但可以藉助第三方軟體查看;
Windows Server 2008 系統可以啟動 任務管理器>性能>資源監控器>網路>查看 發送(位元組/秒) 佔用較多的進程。如果不是常用進程,說明可能是病毒或異常文件;如果是常用進程,說明該進程當前有異常,需要針對該進程對應的服務進行一下分析。
根據以往經驗,曾發現過因搜狗拼音的更新,以及疑似上傳本地詞庫導致的出網帶寬跑高。
爬蟲
正常網站所消耗的帶寬較多,此類情況建議通過訪問的日誌來分析,如果日誌中過多的 spider 或 googlebot 。說明網頁被爬蟲抓取,大量來自搜索引擎的鏈接也容易跑高帶寬,例如:
windows-cmd 下找到 iis的日誌,可以使用命令 type *.log | find 「 「 等。
Linux 的 Apache 和 nginx 可以檢查 cat access.log | grep 等。
同時檢查站點是否存有 MP3,flv,swf 等大文件被頻繁訪問下載,如果此類文件較多,建議減少這些文件,可搭配使用 OSS、CDN 服務。
網站規模大
網站規模較大(比如門戶網站、商城等),即網站本身訪問量需求大,查看網站的 Page View 值、Hits 值、日流量都很高,建議升級帶寬 。
造成流量大的原因主要有:
網站頁面設計不合理;
頁面中包含大圖片或音頻、視頻文件等文件,導致網站頁面太大;
網站提供.mp3,.rar,.zip.exe等文件的下載,或網站提供視頻、音頻文件的播放;
如果網站規模較大,網站的點擊率很高,建議減少音頻、視頻文件。如果還不能滿足要求,可以升級帶寬。
3. 怎樣提高伺服器的響應速度
一、伺服器周圍環境
伺服器通常放置於機房,所說的周圍環境也正是指機房。伺服器基本是一天24小時不間斷運行,所需要的電量如果沒有得到足夠保證,那麼宕機的可能性就會增加。
其次,一台不停運轉的機器,會產生大量的熱量,如果機房不能給予足夠的散熱與濕度保持,機器便會故障,對運行速度也會有很大影響。
最後,在伺服器配置相同的情況下,機房的帶寬越大,訪問速度相對越快。
二、本身配置
伺服器對非專業人員一直是難以理解的機器,但如果將其轉化為我們熟知的東西就很好理解了。我們可以將伺服器看做一台普通計算機,計算機中的處理器、內存和寬頻都直接影響了其運行速度。
因此,想要提升伺服器速度,可以對這些硬體進行升級,做好維護,如果速度下降,也可以從這些方面進行排查。
三、網站程序
程序代碼對速度影響也很大。代碼越精簡,所佔用空間便會越小,訪問速度便會越快。通常來說,編碼人員都會有一個書寫標准,但因為個人習慣問題而憑空多出許多冗餘代碼,導致速度被拖慢。壹基比觀觀