亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

用MongoDB 實現(xiàn)優(yōu)酷API 緩存

系統(tǒng) 3009 0

??????由于眾所周知的原因, 邪惡的企業(yè)優(yōu)酷于九月的某一天開始禁止第三方播放器加載視頻API, 我不得不設(shè)置一個反向代理來繞過Flash 的跨域限制. 自此服務(wù)器壓力激增, 導(dǎo)致用戶體驗大為劣化. 為了減少服務(wù)器壓力我費盡心思, 從原先的Apache2 + php 切換到nginx + php-fpm, 再到現(xiàn)在的nginx + nodejs, 充分利用了服務(wù)器有限的內(nèi)存空間, 使并發(fā)性能得以不斷優(yōu)化, 每次播放的請求時間由原來的10s 縮短到 1~4s.

但這也到頭了, 非緩存型反向代理受限于網(wǎng)絡(luò)連接速率, 如果反向代理服務(wù)器與優(yōu)酷服務(wù)器之間的傳輸速率不能有所突破, 很難把請求時間繼續(xù)縮短. 如果要追求更高的性能, 把請求時間縮短到1s 以內(nèi), 必須在反向代理服務(wù)器上部署緩存數(shù)據(jù)庫.

反向代理服務(wù)器的工作原理

反向代理服務(wù)器的工作原理

?

于是我開始尋找一個適合做緩存的數(shù)據(jù)庫, 根據(jù)服務(wù)器資源和應(yīng)用場景, 對緩存數(shù)據(jù)庫提出如下需求:

  1. NoSQL;
  2. 較高的讀寫速率;
  3. 過期機制;
  4. 能在512MB 內(nèi)存的VPS 上工作.

根據(jù)這些需求, 我最后選擇了MongoDB.

安裝好MongoDB 后, 建立一個存放緩存的collection, 大小為150MB, TTL 為1 小時:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
db.createCollection( 'youkuApiCache' ,{size:150*1024*1024})
//緩存大小150MB
db.youkuApiCache.ensureIndex({
???????? retrievedAt:1
???? }, {
???????? expireAfterSeconds: 60*60
???? })
//retrievedAt 字段存放更新時間, 每條記錄緩存1 小時
db.youkuApiCache.getIndexes() //看一下建好的索引
[
???????? {
???????????????? "v" : 1,
???????????????? "key" : {
???????????????????????? "_id" : 1
???????????????? },
???????????????? "ns" : "test.youkuApiCache" ,
???????????????? "name" : "_id_"
???????? },
???????? {
???????????????? "v" : 1,
???????????????? "key" : {
???????????????????????? "retrievedAt" : 1
???????????????? },
???????????????? "ns" : "test.youkuApiCache" ,
???????????????? "name" : "retrievedAt_1" ,
???????????????? "expireAfterSeconds" : 3600
???????? }
]
db.youkuApiCache.insert({
???????? _id: 'test' ,
???????? retrievedAt: new Date()
???? }) //插入一條記錄, 更新時間為當前時間
db.youkuApiCache.count() //現(xiàn)在youkuApiCache 中有1 條記錄
1
db.youkuApiCache.count() //一小時后youkuApiCache 中有0 條記錄
0

然后對反向代理的代碼稍作改動, 就完成了緩存部署.

到現(xiàn)在為止, youkuApiCache 緩存了15,000 多條記錄, 用掉100MB 空間, 性能得到了很大提高.

1
2
3
4
5
6
7
8
9
10
11
12
time wget "http: //v .opengg.me /player/getPlayList/VideoIDS/XMTIwNDk2MTA0
/timezone/ +08 /version/5/source/video &password=" -O /dev/null -q
// 第一次請求(Uncached request)
real??? 0m0.374s
user??? 0m0.000s
sys???? 0m0.004s
time wget "http: //v .opengg.me /player/getPlayList/VideoIDS/XMTIwNDk2MTA0
/timezone/ +08 /version/5/source/video &password=" -O /dev/null -q
// 第二次請求(Cached request)
real??? 0m0.007s
user??? 0m0.004s
sys???? 0m0.000s

用MongoDB 實現(xiàn)優(yōu)酷API 緩存


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!??!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 尹人香蕉网在线观看视频 | 亚洲欧美v视色一区二区 | 久久久久免费观看 | 久热国产精品视频 | avtt亚洲一区中文字幕 | 天天干天天舔 | 99热99色| 免费a视频在线观看 | 久久久久激情免费观看 | 日本一区二区三区中文字幕 | 99精品在线免费观看 | 视频在线亚洲 | 国产精品公开免费视频 | 久久成人国产 | 农村三级孕妇视频在线 | 精品无码久久久久久国产 | 久久精品国产在爱久久 | 一级特级女人18毛片免费视频 | 奇米影视久久777中文字幕 | 欧美日韩中文国产一区 | 欧美一级暴毛片 | 国产成人91精品 | 摸逼综合网 | 成人毛片免费观看视频在线 | 日日噜噜夜夜狠狠tv视频免费 | 亚洲一区有码 | 色婷婷久久综合中文久久一本` | 久久亚洲国产的中文 | 人人乳乳香蕉大免费 | 99精品国产兔费观看66 | 最近中文字幕免费版在线3 最近中文字幕无吗高清视频 | 久久久久免费精品国产小说 | 婷婷激情综合网 | 国内精品久久久久影院中国 | 国产一区二区三区免费在线观看 | 欧美一级精品 | 午夜在线一区 | 国产欧美另类性视频 | 久久99热成人精品国产 | a国产成人免费视频 | 日本免费一区二区久久人人澡 |