白話文解說 CDN(Content Delivery Network)
大家都知道一旦網站上線之後,流量就可能來自世界各地(賺刀了啦~💵
不過有一個很現實的問題是「世界各地的網路速度是存在差異的」,使用者越覺得網站響應速度慢,越可能影響網站的使用意願,也就是說網站載入速度越慢,使用者關掉走人的機率越高。
那麼,要怎麼盡量讓世界各地的使用者都能快速地存取到我們的網站?
最最最極端的方法是到全世界各地都架網站,每個使用者都直接連到離他最近的網站就好。
不過這個方法成本很高,因為至少要在歐洲、美洲、亞洲都各架一個站,成本可能需要 3 倍⋯⋯。
CDN 技術的出現就是解決這樣的問題。
讓我們可以只需要架一個站,而且使用者都會連到離自己最近的伺服器下載網站資源。
它的運作原理是你會有一個 CDN 專用的域名(domain)指向你的網站,例如 CDN 網域 example.com
指向你的網站 real.example.com
,當使用者對 example.com
發出要求時, CDN 就會開始運作,先檢查離使用者最近的伺服器是否有 cache 可以先給使用者,如果沒有才向 real.example.com
發出請求,再將回應 cache 在離使用者最近的伺服器內,待下次使用。
p.s. 所以 CDN 服務都會要求你要做一些 DNS 設定
可能有人會想問「 但 API 通常是根據使用者不同而回應不同內容,這樣使用 CDN 不會有問題嗎?」
沒錯,所以 CDN 不適合應用在 API 的回應上,通常都是一些靜態檔案(static files),例如圖檔、CSS, JavaScript, HTML 檔案等等,所以一些部落格、 Profilo 就很適合編譯成靜態檔案,然後透過 CDN 加速回應速度。
p.s. 有些大型電商甚至把商品頁都編譯成靜態網頁以加速回應
用了 CDN 之後,還有一個衍伸問題,那就是我們更新網站之後,使用者看到的還是 cache 的內容耶,那怎麼辦?
很簡單, CDN 的 cache key 其實是認網址,如果相同的網址都對應到同一份 cache, 所以很多有用 CDN 服務的網站都會在靜態檔案的網址裡面加上版本號,因為新的版本號在 CDN 找不到 cache, 所以就自然而然會載入最新的內容。
p.s. 網址只要有任何一個字元不一樣,就是另一份 cache 喔!
但如果你連網頁所有內容都在 CDN cache 起來,那麼使用者自然無法載入最新內容,這時有 2 種方式可以讓使用者載入最新內容:
- 等快取時間自然結束,也就是 TTL(Time To Live) 時間到期, CDN 將刪除快取,使用者就可以取得最新內容
- 使用 API purge cache 。 CDN 服務通常都會提供 API 讓我們可以選擇要清除哪些 cache, 但由於 CDN 分佈全球,清除所有 cache 通常需要一點時間,不過相較於等快取時間自然結束來說,還是快很多
最後,由於 CDN 可以加速網頁回應速度,所以對於 SEO 也是有加分效果!所以在挑網頁空間時,可以看看有沒有支援 CDN ,這會是一個加分項目!