從cdn說起

来源:http://www.cnblogs.com/liuyongjia/archive/2017/11/22/7881400.html
-Advertisement-
Play Games

為什麼要使用cdn 雅虎軍規有一條規則建議我們是用cdn。隨便在網上搜索,可以找到使用的cdn的好處。 再次強調第一條黃金定律,減少網頁內容的下載時間。提高下載速度還可以通過CDN(內容分髮網絡)來提升。CDN通過部署在不同地區的伺服器來提高客戶的下載速度。如果你的網站上有大量的靜態內容,世界各地的 ...


為什麼要使用cdn

雅虎軍規有一條規則建議我們是用cdn。隨便在網上搜索,可以找到使用的cdn的好處。

再次強調第一條黃金定律,減少網頁內容的下載時間。提高下載速度還可以通過CDN(內容分髮網絡)來提升。CDN通過部署在不同地區的伺服器來提高客戶的下載速度。如果你的網站上有大量的靜態內容,世界各地的用戶都在訪問,我說的是youtube麽?那CDN是必不可少的。事實上大多數互聯網中的巨頭們都有自己的CDN。我們自己的網站可以先通過免費的CDN供應商來分髮網頁資源。

cdn不只是可以讓用戶去請求到離自己最近的伺服器,提高速度,他還有以下幾個好處。

1. 防止本功能變數名稱下的cookie在發送請求時被帶過去。

如果在network下看過頁面的請求,可以發現,即使是請求一張jpg的圖片,也會發送同域下的cookie過去。即便是不到幾k的大小,用戶量大了,也是一個巨大的消耗。不論是出於載入速度還是寬頻的考慮,都應該避免這種情況。這也是靜態cdn的功能變數名稱不與主功能變數名稱一致的原因之一。

2. 防止過多請求被瀏覽器限制。

瀏覽器同功能變數名稱的請求是有最大併發限制的,一般是6個。具體可以參考這篇博客。這是cdn的功能變數名稱不與主功能變數名稱一致的原因之二。

3. 方便緩存復用。

如果是同一個靜態文件,在多個頁面被載入,如果在cdn上,被客戶端緩存下來,那麼再打開另一個頁面,也不需要再去請求,可以直接使用緩存。

說點別的

說到了cdn,就想到了一些平時開發時約定俗成的習慣。

dns預解析

估計大部分同學都會有一個文件存滿了諸如以下的內容:

<meta http-equiv="x-dns-prefetch-control" content="on" />
<link rel="dns-prefetch" href="http://img.jd.com" />
<link rel="dns-prefetch" href="http://static.jd.com" />

公司常常會有很多個靜態資源的功能變數名稱,有的時候,頁面下的靜態資源很可能是從許多個不同的功能變數名稱下載入的。而功能變數名稱解析為主機也需要時間,這時,如果我們使用dns預解析,可以加快資源的請求速度。
這需要瀏覽器的支持,目前主流瀏覽器全部支持。

合理利用緩存

雅虎軍規第一條————減少http請求。
實際開發中,雪碧圖、壓縮捆綁css、js是我們常用的方式。但是在客戶端能力越來越強的如今,其實不一定非要這麼做。
舉個例子,如今客戶端會緩存大部分靜態資源在本地,加上併發請求的原因,多個文件反而能更好的利用客戶端的能力。
我認為,在項目上線時,儘可能找到復用較多的資源,單獨拿出來,項目專享的js和css打包成一個文件,不失為一個更好的選擇。

常用的cdn網站

bootCdn這個網站可以用來檢索常用的前端項目。
七牛也有這種服務。

以上是我個人的一些理解,如有不對,敬請指教。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 上篇(Angular2快速入門-2.創建一個新聞列表)已經完成新聞列表的展示,並且點擊新聞列表的時候,下麵可以展示出新聞的詳細信息,這節我們把新聞詳細和新聞列表頁面分離出來 新聞詳細單獨一個component 第一、創建news-detail.component 1)創建news-detail.co ...
  • 前段時間,終於仔仔細細的把pt、px、em、rem瞭解了一遍,簡單整理了一下做個記錄。 pt、px、em、rem都是什麼 pt單位名稱為點(Point),絕對長度單位。現在網頁中出現得很少甚至不出現,常用於印刷行業。 單位換算:1in = 2.54cm = 25.4 mm = 101.6q = 72 ...
  • 一、介紹 本篇繼上一篇 "深入理解js執行 單線程的JS" ,這次我們來深入瞭解js執行過程中的執行上下文。 本篇涉及到的名詞:預執行,執行上下文,變數對象,活動對象,作用域鏈,this等 二、預執行 在上一篇說到,在js代碼被執行,執行上下文會被壓進執行棧中,但是在此之前還有一步工作要做,就是創建 ...
  • js:在頁面中用戶操作頁面時發生的效果都是Js功勞。操作有點擊,移入,和移出等。。。 例1:通過display隱藏盒子 當通過變數名var可以 繼續實現: 也可以通過透明的opacity,和高度來控制隱藏和顯示。 製作百度登錄效果,點擊登錄,彈出登錄視窗,及退出 (即使簡單也不可餓大意,以上便是di ...
  • 1.安裝node-inspector npm install -g node-inspector 2.安裝完成之後啟動 inspector 服務: node-inspector & 3.在chrome瀏覽器中打開:http://127.0.0.1:8080/?port=5858 4.打開想要debu ...
  • 一、項目編譯打包後生成的dist文件夾後;項目提交到github上dist文件提交不上去。 在.gitignore文件,刪除一行 二、更改github的語言屬性 .gitattributes文件:若項目是Vue屬性 ...
  • 作用:處理時間和日期 一、創建方式 1.var mydate = new Date() —— 當前電腦時間 2.var mydate = new Date("2015-1-1") —— 創建時間 二、Date內置方法 var myDate = new Date(); console.log(myD ...
  • 查看原文 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...