AWS中怎么實(shí)現(xiàn)動態(tài)CDN

AWS 中怎么實(shí)現(xiàn)動態(tài)cdn,相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

成都創(chuàng)新互聯(lián)從2013年成立,先為鳳泉等服務(wù)建站,鳳泉等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為鳳泉企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

CDN 不是一個新名詞,這個把緩存分布到世界各地的技術(shù)起碼出現(xiàn)了 10 年。最近又火起來,原因是用戶對網(wǎng)絡(luò)響應(yīng)時間的要求深化。國內(nèi)就有阿里云的 CDN, ChinaCache, Baidu+Cloudfare, UCloud, 7牛 還有很多。。。因?yàn)榫W(wǎng)絡(luò)問題,很多大公司都會采用國外服務(wù)器,然后把內(nèi)容通過CDN 推到國內(nèi)。

技術(shù)上,我認(rèn)為這么多公司一起做CDN,其中一個原因就是這東西不復(fù)雜,當(dāng)然國內(nèi)國外的支持還會加上一些其他問題。主流技術(shù)就是 Nginx / Varnish 作為 File Cache, 然后部署 GSLB(全局負(fù)載均衡)。 以技術(shù)角度來看,我是不會自己架一個CDN網(wǎng)絡(luò)的,得上百節(jié)點(diǎn)的才算得上CDN,個人架設(shè)成本有點(diǎn)高。認(rèn)為選擇 CDN 時會考慮以下的因素

  1. 支持 Cache invalidation 

  2. Invalidation 所需要的時間與價格

  3. 流量費(fèi)不要超過 USD 0.14/GB

  4. 支持動態(tài) CDN

  5. 支持子域名 (CloudFlare / 安全寶 都需要域名切換,防DDOS)

  6. 支持 Cache Behaviour (不同的路徑有不同的 cache 特性)

  7. 可以 pass through header / cookie

  8. Respect Cache-control header

  9. 最好可以直接有操作介面更改 header

  10. 支持 edge side include

相信能做到以上的,就不純粹是個簡單的CDN,是個真正的CDN。今天主要分享的是第 4)點(diǎn) 動態(tài) CDN

AWS 在 2013 年開始在 Cloudfront 支持動態(tài)CDN,意思就是可以把 html 也存到 CDN 上,用戶拿到 HTML 和 靜態(tài)文件都在 CDN 上,不需要向服務(wù)器 (origin) 請求。原理上,這就支持無限的訪問。read 請求日千萬不是問題,問題去了信用卡能刷多少錢而已。

AWS 中怎么實(shí)現(xiàn)動態(tài)CDN

這個 Dynamic CDN 的原理是這樣的 比如,以 abc.com為例子作一下說明。

  1. abc.com CNAME 去 Cloudfront 的域名 (xxxxxxxx.aws.cloudfront.com)

  2. 在 xxxxxxxx.aws.cloudfront.com 以下的 Cloudfront ID (cloudfrontID.default.cloudfront.com) 接受 abc.com 的請求

  3. xxxxxxxx.aws.cloudfront.com 指向  origin.abc.com 拿數(shù)據(jù) (就是本服務(wù)器)

  4. 要是請求沒有 cloudfront 本地 cache, 就繼續(xù),否則反回 cache

  5. 要是請求不是特定的 path ( cache behaviour),則反回

  6. cloudfrontID.default.cloudfront.com 向 web 服務(wù)器 (Origin) 請求 object (html / css / .jpg / …)

  7. 把 header (cache-header / CORs) 也記到 cache 中

  8. 把 xxx.default.cloudfront.com 的 cache 反回到 abc.com 的客戶端

  9. 跟據(jù)在第 7) 點(diǎn) 定義的 header按時間清理緩存

  10. 跟據(jù)請求的來源IP,在世界各地每一個edge 上操作 1-9

這有點(diǎn)像反向代理,比如 Varnish 就在做差不多的事。只是CDN 在用 edge cache. Varnish 一般的使用情況是把文件緩存最長時間,然后根據(jù) Origin 給的指令來更新緩存。這是客戶最想要的,這樣就不會有 “第一位用戶變慢” 這樣的問題。但要是用過好幾個 CDN 的人就會發(fā)現(xiàn),市面上沒有CDN 支持永久緩存這回事。原因在哪?這沒有官方回應(yīng),我感覺是 edge cache 是很多很多的服務(wù)器,在 AWS 上跑一次 cache invalidation 去清理所有 edge 上的 cache 要花上 20-30 分鐘,要是每一次的 object 更新也得像 Varnish 去 “push” 更新,就會花上很大的成本。倒不如自動 Expire, 然后在下一位用戶有需要時,才把最近那地理位置的 edge cache 上加一個 object cache. 這樣就省去一筆很大的成本。

好的 CDN 得支持 Behaviour, 就是路徑不同的特性,在不同的應(yīng)用上,特別是已登錄的用戶,使用太多的 cache 會令系統(tǒng)出問題。得跟據(jù)路徑來刪除/加速 刷新。

AWS 中怎么實(shí)現(xiàn)動態(tài)CDN

要是支持登錄用戶的話, Cookie 要用客戶端直接傳送到 Origin, 所以得支持 (forward cookie)

AWS 中怎么實(shí)現(xiàn)動態(tài)CDN

每個 CDN 會有一個 Default behaviour, 就是不指定情況下,都跟據(jù)這個 behaviour 作出回應(yīng)。比如我們要支持用戶登錄,得把 session 通過 Dynamic CDN 回傳到 origin 

AWS 中怎么實(shí)現(xiàn)動態(tài)CDN

看完上述內(nèi)容,你們掌握AWS 中怎么實(shí)現(xiàn)動態(tài)CDN的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

當(dāng)前文章:AWS中怎么實(shí)現(xiàn)動態(tài)CDN
新聞來源:http://bm7419.com/article8/jdsdop.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè)App開發(fā)、網(wǎng)站制作自適應(yīng)網(wǎng)站、網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站