提搞網(wǎng)站訪問速度可做哪些優(yōu)化小結(jié)介紹
一、 服務(wù)器優(yōu)化
Windows系列:
64位Win2008r2 + Hpyer-V + 負(fù)載均衡 + IIS7.5
64位Win2003 + 虛擬機(jī) + 負(fù)載均衡 + IIS6
禁止服務(wù)器訪問外網(wǎng)。關(guān)掉不必要的端口。
去掉每個(gè)磁盤的所有權(quán)限,只保留administrators組和system完全控制權(quán)限。
IIS7.5標(biāo)識(shí)使用ApplicationPoolIdentity,給目錄權(quán)限用戶是:IIS AppPool站點(diǎn)名
IIS6需要為每個(gè)站點(diǎn)建獨(dú)立的用戶,為IIS用戶單獨(dú)設(shè)置權(quán)限。
IIS禁止日志記錄。
二、 數(shù)據(jù)庫優(yōu)化
l 64位MSSQL2008:
少用觸發(fā)器/游標(biāo)/外鍵。多用存貯過程和視圖。適量使用索引查詢速度會(huì)提高很多,每個(gè)表的索引盡量不要超過3個(gè)。
定時(shí)查看死鎖的進(jìn)程和等待進(jìn)程,并清除,還要及時(shí)修正死鎖的來源。
復(fù)雜的`統(tǒng)計(jì)報(bào)表需要用計(jì)劃去跑。
查詢記錄數(shù)要使用count(0) 不要使用count(*)。
select的時(shí)候表字段不要使用*。*查詢所有字段是很慢的。
如果字段是索引列可使用UNION ALL 替代 OR,走索引線路查詢。
大記錄集要使用分頁查詢。
盡量不要使用TEXT/NTEXT類型,要使用VARCHAR(MAX)/NVARCHAR(MAX)。
盡量不要使用臨時(shí)表,要使用Table表類型或內(nèi)嵌視圖。
三、 后端優(yōu)化
l 多使用DbDataReader,盡量不要使用DataTable/DataSet讀取數(shù)據(jù)。
l for (int i = 0; i < dt.Rows.Count; i++) 應(yīng)該這么寫:
for (int i = 0, len = dt.Rows.Count; i < len; i++)或
foreach (DataRow info in dt.Rows)推薦這種寫法
l 少用try catch,用到try catch時(shí)要和 finally一起使用。
l 多使用using如:
using (DbDataReader dr = Data.GetDbDataReader(strSql)) { while (dr.Read()) { }; }
l 大字符串操作請(qǐng)使用StringBuilder 少使用string,字符串比較用Compare,字符串相加用Concat,大字符串相加用StringBuilder Append。
l 變量要在先定義在使用,不要在循環(huán)內(nèi)定義變量。如:
錯(cuò)誤的寫法是:for (int i = 1; i < 10; i++) { string s = i.ToString(); }
正確寫法:string s = string.Empty; for (int i = 1; i < 10; i++) { s = i.ToString(); }
這里還有一個(gè)地方要注意的:在字符串相加的時(shí)候,如果有int類型的要先轉(zhuǎn)成string類型在相加,減少不必要的裝箱拆箱操作。
l 如果你使用的是HTML控件,需要禁用<%@ Page EnableViewState="false" AutoEventWireup="false" EnableSessionState="false",web.config
l 使用foreach替代for
l 操作數(shù)據(jù)庫要使用存貯過程/視圖。
l 多使用CACHE對(duì)數(shù)據(jù)緩存。這才是最關(guān)鍵的。NET提供:HttpContext.Current.Cache/HttpRuntime.Cache,共享緩存有velocity/ memcached
l 可使用<%@ OutputCache Duration="60" 緩存頁面,可使用Response.BufferOutput = true;/ <%@ Page Buffer="true" 輸出緩沖。
l 可將站點(diǎn)生成靜態(tài)面頁,好處多多。
l 可使用URL重寫成偽靜態(tài),提供rss/baidu-sitemap/google-sitemap服務(wù),有利于搜索引擎收錄。
l Ajax調(diào)用頁面要使用.ashx一般處理程序,速度要比.aspx文件要快。Ajax請(qǐng)求要使用POST不要使用GET。
l 發(fā)布站點(diǎn)時(shí)DLL要Release版本,不要用Debug版本。
l IIS需要使用集成模式,不要使用經(jīng)典模式。
l Web.config 加關(guān)閉錯(cuò)誤提示。
l Web.config 加關(guān)閉調(diào)試模式。
l 使用Server.Transfer替換Response.Redirect
l 多使用泛型集合操作,少用ArrayList。
四、 前端優(yōu)化
l 最好不使用NET控件,用HTML控件,頁面使用CSS+DIV布局。
l 使用JSON + AJAX進(jìn)行數(shù)據(jù)交互。
l 要學(xué)會(huì)使用jQuery提高開發(fā)速度。
l 盡量少用<img標(biāo)記,改用background樣式控制背景圖片。這樣做的好處是方便擴(kuò)展多皮膚。
l 將CSS background背景圖片多張合并成一張圖片,保證合并后的圖片大小不要超過50K。可將JS文件合并在一個(gè)JS文件中,然后使用closure_packer_yui_compiler進(jìn)行壓縮,這樣做的好處是可減少客戶端連接數(shù)。
l JS代碼段不要放在HTML頁面,應(yīng)該放在獨(dú)立的JS文件里面,好處是JS文件可以CDN/緩存。
l 可將CSS文件放到之間,JS文件或代碼放到之前,讓頁面先顯示在執(zhí)行JS。
l 可將網(wǎng)站的圖片/CSS/JS/資料/資源放到獨(dú)立的站點(diǎn),做下CDN加速,二級(jí)域名會(huì)有COOKIES,最好使用一級(jí)域名。
l A標(biāo)記和IMG標(biāo)記需要加上title/alt,標(biāo)簽內(nèi)需要加title/keywords/description/rss/sitemap優(yōu)化,有利于搜索引擎收錄。
l 頁面可啟用gzip壓縮。
l 安裝FF的插件“YSlow/Page Speed”。
五、 其它優(yōu)化
【提搞網(wǎng)站訪問速度可做哪些優(yōu)化小結(jié)介紹】相關(guān)文章:
網(wǎng)站打開速度慢的原因有哪些08-05
手機(jī)網(wǎng)站優(yōu)化技巧有哪些03-17
ADSL訪問速度慢解決方法08-15