我在BAT學(xué)到的技術(shù)工具-使用nodejs搭建支持高并發(fā)的http服務(wù)

1. 面對(duì)的需求

  • 圖片標(biāo)簽商品服務(wù)申尤,類似產(chǎn)品:nice,商品濾鏡:
    ![單圖片維度](http://7u2g5z.com1.z0.glb.clouddn.com/屏幕快照 2015-01-08 下午5.38.36.png)

![tag標(biāo)簽維度](http://7u2g5z.com1.z0.glb.clouddn.com/屏幕快照 2015-01-08 下午5.43.22.png)

  • 接口說(shuō)明
    1. 獲取指定圖片中的tag內(nèi)容
      輸入:objurl蛾坯,userid
      輸出:tag list

    2. 獲取指定話題(如:"G-SHOCK")下面所有的圖片
      輸入:tagname
      輸出:objurl list,tag desc 等信息

    3. 為某個(gè)圖片添加標(biāo)簽tag
      輸入:objurl, userid悼枢, tagname(這個(gè)為了歸一化,前端會(huì)有選擇引導(dǎo))
      輸出:是否成功

2. 可選的技術(shù)方案

2種技術(shù)方案A/B
2種技術(shù)方案A/B
  • php 使用lighty 配置fastcgi模式
  • nodejs使用lighty配置redirect模式
  • 由于搜索核心的流量經(jīng)過(guò)php集群脾拆,所以馒索,本次從開(kāi)發(fā)效率,并發(fā)請(qǐng)求支持效率(單機(jī)qps)上考慮使用nodejs搭建后端服務(wù)

3. 基于nodejs的技術(shù)方案

  • nodejs完成連接接入绰上,結(jié)果處理拼裝的工作,其中使用到了幾個(gè)很好用的插件渠驼。
    pm2: 類似服務(wù)端的supervise蜈块,當(dāng)進(jìn)程意外崩潰后自動(dòng)重啟動(dòng);
    ![示例](http://7u2g5z.com1.z0.glb.clouddn.com/屏幕快照 2015-01-08 下午6.31.43.png)
    由于nodejs是單進(jìn)程模型迷扇,pm2支持自動(dòng)部署為多進(jìn)程運(yùn)行百揭,可以更好的利用服務(wù)器cpu;

    redis:支持的nodejs的redis proxy

  • redis
    使用了set作為value類型谋梭,犧牲部分性能達(dá)到去除重復(fù)標(biāo)簽的功能信峻。

  • 管理redis的web 工具
    redis-commander
    ![示例](http://7u2g5z.com1.z0.glb.clouddn.com/屏幕快照 2015-01-08 下午6.20.30.png)

4. 效果總結(jié)

  • 實(shí)際壓力測(cè)試,讀寫混合的pv單機(jī)可以在1W qps左右瓮床。
  • 總結(jié)nodejs適合應(yīng)用場(chǎng)景:高并發(fā)流量盹舞,不是很重的處理邏輯,http服務(wù)層隘庄。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末踢步,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子丑掺,更是在濱河造成了極大的恐慌获印,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件街州,死亡現(xiàn)場(chǎng)離奇詭異兼丰,居然都是意外死亡玻孟,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門鳍征,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)黍翎,“玉大人,你說(shuō)我怎么就攤上這事艳丛∠坏В” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵氮双,是天一觀的道長(zhǎng)碰酝。 經(jīng)常有香客問(wèn)我,道長(zhǎng)戴差,這世上最難降的妖魔是什么送爸? 我笑而不...
    開(kāi)封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮暖释,結(jié)果婚禮上碱璃,老公的妹妹穿的比我還像新娘。我一直安慰自己饭入,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布肛真。 她就那樣靜靜地躺著谐丢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蚓让。 梳的紋絲不亂的頭發(fā)上乾忱,一...
    開(kāi)封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音历极,去河邊找鬼窄瘟。 笑死,一個(gè)胖子當(dāng)著我的面吹牛趟卸,可吹牛的內(nèi)容都是我干的蹄葱。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼锄列,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼图云!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起邻邮,我...
    開(kāi)封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤竣况,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后筒严,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體丹泉,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡情萤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了摹恨。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片筋岛。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖睬塌,靈堂內(nèi)的尸體忽然破棺而出泉蝌,到底是詐尸還是另有隱情,我是刑警寧澤揩晴,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布勋陪,位于F島的核電站,受9級(jí)特大地震影響硫兰,放射性物質(zhì)發(fā)生泄漏诅愚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一劫映、第九天 我趴在偏房一處隱蔽的房頂上張望违孝。 院中可真熱鬧,春花似錦泳赋、人聲如沸雌桑。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)校坑。三九已至,卻和暖如春千诬,著一層夾襖步出監(jiān)牢的瞬間耍目,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工徐绑, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留邪驮,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓傲茄,卻偏偏與公主長(zhǎng)得像毅访,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子盘榨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容