關於網站的最佳化

來源:互聯網
上載者:User

標籤:

網站最佳化:
是因為IIS的串連數的是有限的,所以
1、減少HTTP串連
1 盡量將同一個邏輯的css代碼放到一個css檔案中
2 盡量將同一個邏輯的js代碼放到一個js檔案中
3 盡量將小圖片合并成一個大圖,利用css中的backgroud-postinion : x,y去截取大圖上的具體的小圖 (最佳化以後效能是最好)
如何將小圖拼成大圖:
http://www.cnblogs.com/ivanyb/archive/2013/01/10/2854366.html 中有一個工具
只需要將小圖片打包成.zip 上傳到伺服器,自動的產生大圖,並且產生大圖中的每個小圖的css代碼

4 使用 CDN 加速將靜態資源全域緩衝到CDN服務商的伺服器上,將來瀏覽器請求一個靜態資源(圖片,.css,.js,.html,.htm),則直接去CDN的伺服器擷取而不去
web伺服器了
CDN的使用:
1、去CDN服務商購買服務
2、CDN就會將伺服器上的指定的靜態資源下載回去,同時設定緩衝時間
3、當緩衝失效以後,重新回源
4、也可以提供url進行手工刪除
5、CName:給某個網域名稱做一個別名
A記錄:將網域名稱www.xx.com綁定到外網ip上 212.198.9.2
cname:將當前網域名稱 s1.xx.cdndomain.com cname到www.xx.com

2、減少每次http請求響應回去的資料量大小
1、盡量壓縮js,css檔案的大小 ,所以一般使用的是 .min.js .min.css
可以使用
http://www.cnblogs.com/ivanyb/archive/2013/01/10/2854366.html中的說明一步步操作即可完成
2、開啟IIS中的壓縮功能,預設是zip壓縮,瀏覽器得到以後自動解壓縮

上面的2個最佳化過程不需要修改任何代碼。

3、頁面緩衝
在aspx頁面上 <@ outputcache %>

4、資料緩衝
將不常變化的資料緩衝到伺服器
失效策略:
1、相對到期時間
2、絕對到期時間
3、檔案依賴
4、資料庫依賴

asp.net中HttpRuntime.cache緩衝,此緩衝為當前網站的進程內部的

第三方緩衝軟體:memcached ,redis
本質上是利用key-value進行資料存放區的,可以使用當前伺服器上的所有記憶體
他們支援分布式緩衝

5、頁面真靜態化 .html 可以做CDN緩衝
要求:當前頁面的變化不大

6、開啟IIS的處理進程 web園
web園:一個網站的應用程式集區的背景工作處理序數>1
開啟web園引發的問題:
1、多個進程不能共用session對象
如何解決:
1、利用進程外,
1、狀態伺服器,本質上是是window服務,使用的記憶體更大,但是當超過了記憶體數的時候一樣的重啟,導致不穩定,讀寫速度很快
2、資料庫:本質上是將session資料存放區在硬碟上,讀寫速度慢,但是很穩定(一般使用此種訪問,因為系統的健壯性比效率更加重要)

2、利用cookie + redis(memcached)來類比session的功能

2、如果系統使用的是HttpRunTime.cache(進程內的緩衝) 會引發記憶體不夠用的問題,以及在多個進程中不能共用快取資料
如何解決:使用 redis(memcached) 在單獨的快取服務器上運行

7、增加web伺服器
必須使用LINUX+ NGINX 進行負載平衡
引發什麼問題?
1、多個進程不能共用session對象
2、如果系統使用的是HttpRunTime.cache(進程內的緩衝) 會引發記憶體不夠用的問題,以及在多個進程中不能共用快取資料
3、檔案上傳以後不能在各個伺服器上共用
解決方案:使用檔案伺服器來共用
如何從web伺服器將檔案儲存到檔案伺服器磁碟:
一般使用FTP ,可以滿足大檔案的穩定傳輸
也可以使用System.Net.WebClient中的Update() 有參數 (缺點不穩定,隨時都會斷開)
第一個:路徑 (可以是檔案伺服器的共用路徑 格式:\\檔案伺服器名稱\隱藏檔的檔案夾名稱)
第二個:儲存的資料
斷點續傳
1K ->Byte[]

斷點下載

8、最佳化資料庫
加索引
分表
分庫
讀寫分離
Nosql:Mongodb

關於網站的最佳化

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.