
ãããã®è³æã¯ãã¬ãŒã ã¯ãŒã¯ãéžæããããã®ã¬ã€ãã§ã¯ãªããè°è«ã®äœå°ããããããããªããšããäºå®ã«æ³šæãåèµ·ããããšæããŸãã ç§ã¯ãã®ç 究ã®çµæãå ¬è¡šããã€ããã¯ãŸã£ãããããŸããã§ãããã圌ããç§ã®ç®ã«çãŸã£ããšããç§ã¯ããã誰ãã«åœ¹ç«ã€ãããããªããšèããŸããã ä»ãç§ã¯ã°ã©ãã§ã·ã£ã¯ãŒã济ã³å§ããŸãã
1.ããã¹ã/ Httperf / VPS 1 CPUã512Mb RAM
æãå®äŸ¡ãªVPS DigitalOceanïŒ1ã³ã¢ã512Mb RAMã20Gb SSDïŒã§è¡ã£ãæåã®ãã¹ãã ããã©ãŒãã³ã¹ãã¹ãã«ã¯ã httperfãŠãŒãã£ãªãã£ã䜿çšãããŸãã ã å¿ èŠãªè² è·ãçæããããã«ãåãæ§æã®VPSã5åå«ãŸããŠããŸããã ãã¹ãŠã®ã¯ã©ã€ã¢ã³ãã§åæã«ãã¹ããå®è¡ããããã«ã èªåãã³ããŠãŒãã£ãªãã£ã次ã®ãã©ã¡ãŒã¿ãŒãšãšãã«äœ¿çšããŸãã ã
autobench_admin --single_host --host1 example.com --port1 8080 --uri1 / --low_rate 50 --high_rate 600 --rate_step 10 --num_call 10 --num_conn 6000 --timeout 5 --clients XX.XX.XX.XX:4600,XX.XX.XX.XX:4600,XX.XX.XX.XX:4600,XX.XX.XX.XX:4600,XX.XX.XX.XX:4600 --file bench.tsv
ãã®ãã¹ãã¯ã1ç§ããã50æ¥ç¶ïŒ1æ¥ç¶ã§10ãªã¯ãšã¹ãïŒããå§ãŸãã1ç§ããã10æ¥ç¶ã§600æ¥ç¶ã«éããŸããåãã¹ãã¯åèš6000æ¥ç¶ã確ç«ãã5ç§ä»¥å ã«åŠçãããªãã£ããã¹ãŠã®ãªã¯ãšã¹ãã¯ãšã©ãŒãšèŠãªãããŸãã
ãã¹ãŠã®HTTPãµãŒããŒã¯åãããšãè¡ããŸããã€ãŸãããªã¯ãšã¹ãããšã«æååãI am aæããªHTTPãµãŒããŒã§ãïŒããè¿ããŸãã çµæã¯æ¬¡ã®ãšããã§ããïŒ X軞ã«æ²¿ã£ãŠ-1ç§ãããã®ãªã¯ãšã¹ãæ° ïŒïŒ
CPUè² è·

RAMæ¶è²»ïŒ512Mbã®ïŒ ïŒ

è¿ä¿¡æ°

å¿çæéïŒããªç§ïŒ

ãšã©ãŒæ°

CPU䜿çšçã100ïŒ ã«éãããšãRAMã®æ¶è²»éãå¢å ãå§ããå¿çæ°ãæžå°ããåèŠæ±ã®å¿çæéãé·ããªãããšã©ãŒã衚瀺ããå§ããŸãã äžèšã§æžããããã«ã5ç§ä»¥å ã«å¿çãåä¿¡ããªãã£ãåèŠæ±ã¯ãšã©ãŒãšèŠãªãããŸããããã¯ãŸãã«ããã§èµ·ããããšã§ããããã¯ãå¿çæéãã°ã©ãã§è¿œè·¡ã§ããŸãã
çµæ ïŒæ¬åŒ§å ã¯ãšã©ãŒãªãã§åŠçããããªã¯ãšã¹ãã®æ°ïŒïŒ
- ã²ãã³ãïŒ 4700 ïŒ
- Express.jsïŒ 3600 ïŒ
- ã€ãã³ãã¬ããïŒ 3200 ïŒ
- ç«å·»ïŒ 2200 ïŒ
ç§ã¯èªåã®ä»äºã«å®å šã«æºè¶³ããŠããããã§ã¯ãªãã®ã§ãæ°æéåŸãVPSã§ã®ããã©ãŒãã³ã¹ã®ãã¹ãã¯æè¯ã®éžæã§ã¯ãªããšå€æããŸããã ãã¬ãŒã ã¯ãŒã¯éã§ã¯ãããã©ãŒãã³ã¹ã®éãã¯ç解å¯èœã§ãããããã€ãã®çµè«ãåŒãåºãããšãã§ããŸãããå®éã®ããã»ããµã®åãã³ã¢ã§ãµãŒãã¹ã§ããã¯ã©ã€ã¢ã³ãã®æ°ã¯ããããŸããã æªç¥ã®ãªãœãŒã¹ã誰ããšå ±æããããšãšããã¹ãŠã®ãªãœãŒã¹ãæ¢ç¥ã§èªç±ã«äœ¿ããå Žåã¯ãŸã£ããå¥ã®ããšã§ãã
2.Text / Httperf / Intel Core i7-4770 Quad-Core Haswellã32 GB DDR3 RAM
次ã®ãã¹ãã§ã¯ãIntel Core i7-4770ã¯ã¢ããã³ã¢Haswellããã»ããµãŒãš32 GB DDR3 RAMãåããHetznerïŒEX40ïŒããå°çšãµãŒããŒãã¬ã³ã¿ã«ããŸããã
ä»åã¯ãå¿ èŠãªè² è·ãäœæãã10 VPSãäœæãã次ã®ãã©ã¡ãŒã¿ãŒã䜿çšããŠãªãŒããã³ããèµ·åããŸããã
autobench_admin --single_host --host1 example.com --port1 8080 --uri1 / --low_rate 50 --high_rate 1500 --rate_step 50 --num_call 10 --num_conn 15000 --timeout 5 --clients XX.XX.XX.XX:4600,XX.XX.XX.XX:4600,XX.XX.XX.XX:4600,XX.XX.XX.XX:4600,XX.XX.XX.XX:4600 ... --file bench.tsv
ãã®ãã¹ãã¯ã1ç§ããã50æ¥ç¶ïŒ1æ¥ç¶ã§10ãªã¯ãšã¹ãïŒã§å®è¡ãéå§ãã1ç§ããã50æ¥ç¶ã®ã¹ãããã§1500ã«éããŸããåãã¹ãã¯åèš15,000æ¥ç¶ã確ç«ãã5ç§ä»¥å ã«åŠçãããªãã£ããã¹ãŠã®ãªã¯ãšã¹ãã¯ãšã©ãŒãšèŠãªãããŸãã
ãµãŒããŒã®ãœãŒã¹ã³ãŒãã¯ãæåã®ãã¹ããšåãã§ãã 1ã€ã®ã³ã¢ã®ã¿ã䜿çšãããµãŒããŒã®ã³ããŒã1ã€èµ·åãããŸããã ãã®ãã¹ãã§ã¯ã Twisted 13.2ããã³Eventmachine 1.0.3ãã¬ãŒã ã¯ãŒã¯ãè¿œå ããŸããã ãã¹ãçµæããã¡ã¢ãªæ¶è²»éãåé€ããŸãããããã¯ãææ°ã®åºæºã§ã¯ãã®å·®ãç¡èŠã§ããã»ã©å°ããããã§ãã ç§ã¯ç«ãå°Ÿã§åŒã£åŒµããŸãããçµæã¯ããã«ãããŸãïŒ
CPUè² è·

è¿ä¿¡æ°

å¿çæéïŒããªç§ïŒ

ãšã©ãŒæ°

ããã§ã以åã®ããã«ã圌ãã¯CPUã«ã¶ã€ãããŸããã ããã§ã®çç£æ§ã¯ãå¹³åããŠVPS DigitalOceanïŒ1ã³ã¢ã512MbïŒã®3åã§ãããå²ãåœãŠããããªãœãŒã¹ã®éã«ã€ããŠé©åãªçµè«ãå°ãåºãããšãã§ããŸãã
çµæ ïŒæ¬åŒ§å ã¯ãšã©ãŒãªãã§åŠçããããªã¯ãšã¹ãã®æ°ïŒïŒ
- EventmachineïŒ ä»¥äžã®è©³çŽ° ïŒ
- ã²ãã³ãïŒ 12500 ïŒ
- Express.jsïŒ 11500 ïŒ
- ã€ãã³ãã¬ããïŒ 9000 ïŒ
- ãã€ã¹ãïŒ 7000 ïŒ
- ç«å·»ïŒ 6500 ïŒ
ã€ãã³ããã·ã³
Eventmachineã¯ãã®ããã©ãŒãã³ã¹ã«é©ãã競åä»ç€Ÿãšã¯ããé¢ããŠããŸããããã®ãããç¹ã«åœŒã®ããã«è² è·ã1ç§ããã25,000ãªã¯ãšã¹ãã«å¢ããå¿ èŠããããŸããã ã°ã©ãã®çµæïŒ
CPUè² è·

è¿ä¿¡æ°

å¿çæéïŒããªç§ïŒ

ãšã©ãŒæ°

圌ã¯30,000件ã®ãªã¯ãšã¹ããåŠçã§ããã®ã§ã¯ãªãããšçã£ãŠããŸãããå ã«é²ãå¿ èŠããã£ããããããã確èªã§ããŸããã§ããã äžè¬ã«ããã®æç¹ã§ããããžã§ã¯ãã«Pythonã䜿çšããããšã¯æ¢ã«ããã£ãŠãããããæ¯èŒã®ããã«ä»ã®èšèªã®ãã¬ãŒã ã¯ãŒã¯ãå¿ èŠã§ããã
3.ãã¡ã€ã«/ Siege / Intel Core i7-4770ã¯ã¢ããã³ã¢Haswellã32 GB DDR3 RAM
äžã«æžããããã«ãç§ã¯èªåã®ä»äºã«å®å šã«æºè¶³ããŠããããã§ã¯ãªãã®ã§ãéææãæã£ãŠå°±å¯ããããã£ãšãã¹ããå¿ èŠã ïŒããšããèãã§ç®ãèŠããŸããã åãªã¯ãšã¹ãã«1è¡ã®ããã¹ããäžããããšã¯ç¢ºãã«è¯ãããšã§ããããããWebãµãŒããŒã®å¯äžã®æ©èœã§ã¯ãªãããããã¡ã€ã«ãé åžããŸãã
ãã®ãã¹ãã§ã¯ã10 VPSã䜿çšããŠå¿ èŠãªè² è·ãäœæããŸããã å®éšçã«ã1 VPS DigitalOceanã§ã¯ãå¹³åã§100 Mbpsã®ãã£ãã«ãå²ãåœãŠãããŠããããšãããããŸããã 1Gbpsãã£ãã«ã®ãµãŒããŒããããå®å šã«ããŒãããå¿ èŠããããŸããã é åžçšã®ãã¡ã€ã«ã¯ããµã€ãºãç°ãªã10,000åã®ãªã³ã©ã€ã³ã¹ãã¢ããã®ç»åã§ããã è² è·ãäœæããããã«ãç§ã¯æ¬¡ã®ãã©ã¡ãŒã¿ãŒã§siegeãŠãŒãã£ãªãã£ã䜿çšããŸããã
siege -i -f fileslist.txt -c 55 -b -t1M
ãã¡ã€ã«ã®ãªã¹ãã¯filelist.txtã«ä¿åããã55ã®æ¥ç¶ã確ç«ãããããããä»ããŠ1å以å ã«ãªã¯ãšã¹ãããµãŒããŒã«éãå§ããŸãã ãã¡ã€ã«ã¯ãfileslist.txtãªã¹ãããã©ã³ãã ã«éžæãããŸãã ãã®ãã¹ãã¯åæã«10å°ã®ãã·ã³ã§å®è¡ãããããšãèæ ®ãã䟡å€ããããŸããã€ãŸãã 550ã§ã¯ãªã550ã®åææ¥ç¶ãã€ã³ã¹ããŒã«ãããšããããšã§ãã ããã«ããã®ãªãã·ã§ã³ã5ãã55ã«5åäœã§çµ¶ããå€æŽããŠããµãŒããŒã®è² è·ãå¢ããã50ãã550ã®åææ¥ç¶ã確ç«ããŸããã
ããã«åŸããããã®ããããŸãïŒ X軞ã«æ²¿ã£ãŠ-åææ¥ç¶ã®æ° ïŒïŒ
å®äºãããªã¯ãšã¹ãã®æ°

1ç§ãããã®åŠçæžã¿ãªã¯ãšã¹ãã®æ°

CPUè² è·ïŒïŒ ïŒ

RAMæ¶è²»ïŒ32Gbã®ïŒ ïŒ

éä¿¡ãã£ãã«ã®è² è·ïŒã¡ã¬ãã€ã/ç§ïŒ

å¹³åèŠæ±å¿çæéïŒç§åäœïŒ

ãã®ãã¹ãã§ã¯ãæ¯èŒã®ããã«nginx WebãµãŒããŒãšåæ§ã«RAMæ¶è²»éãè¿œå ããŸããã ããã§ããã«ããã¯ã¯éä¿¡ãã£ãã«ã§ããã1ã³ã¢ã§ãã®ãã£ãã«å šäœã1 Gbpsã§ããŒãããã«ã¯ååã§ãã
çµæ ïŒæ¬åŒ§å ã¯ãšã©ãŒãªãã§åŠçããããªã¯ãšã¹ãã®æ°ïŒïŒ
- ãã°ã³ïŒ 100175 ïŒ
- ã€ãã³ãã¬ããïŒ 97925 ïŒ
- ã²ãã³ãïŒ 96918 ïŒ
- Express.jsïŒ 96162 ïŒ
- ãã€ã¹ãïŒ 85733 ïŒ
- ç«å·»ïŒ 83241 ïŒ
4. GridFS / Siege / Intel Core i7-4770ã¯ã¢ããã³ã¢Haswellã32 GB DDR3 RAM
ããã§èšäºã®çµãããããããŸãããããããžã§ã¯ãã§MongoDB GridFSã䜿çšãããã£ãã®ã§ããã®äœ¿çšã«ãã£ãŠããã©ãŒãã³ã¹ãã©ã®ããã«å€åãããã確èªããããšã«ããŸããã ãã®ãã¹ãã¯3çªç®ã®ãã¹ãã«äŒŒãŠããŸããã10,000åã®ãã¹ãŠã®ç»åãMongoDBã«ã¢ããããŒãããããŒã¿ããŒã¹ãããã¡ã€ã«ãé åžããããã«WebãµãŒããŒãæžãæããŸããã ããã§äœãåŸãããŸããïŒ
å®äºãããªã¯ãšã¹ãã®æ°

1ç§ãããã®åŠçæžã¿ãªã¯ãšã¹ãã®æ°

CPUè² è·ïŒïŒ ïŒ

RAMæ¶è²»ïŒ32Gbã®ïŒ ïŒ

éä¿¡ãã£ãã«ã®è² è·ïŒã¡ã¬ãã€ã/ç§ïŒ

å¹³åèŠæ±å¿çæéïŒç§åäœïŒ

ãšã©ãŒæ°

ãã¹ãäžãGeventã«ã¯ãšã©ãŒã®ããåçããã£ããããããšã©ãŒã®æ°ããšããã°ã©ããè¿œå ããŸããã äžè¬ã«ãGridFSã䜿çšã§ããŸãããããŒã¿ããŒã¹èªäœãCPUã«ããªãã®è² è·ããããããšãèæ ®ãã䟡å€ããããŸãããŸãããã¡ã€ã«ã·ã¹ãã ã®ãã¹ãŠãéåžžã«åçŽãªå Žåã7ã€ã®ç©ºãã³ã¢ãèªç±ã«äœ¿çšã§ããŸããã
çµæ ïŒæ¬åŒ§å ã¯ãšã©ãŒãªãã§åŠçããããªã¯ãšã¹ãã®æ°ïŒïŒ
- Express.jsïŒ 88714 ïŒ
- ã²ãã³ãïŒ 86182 ïŒ
çµè«
- MacBook Pro Retinaã¯ã1åã®å é»ã§9æéåäœããŸãã
- Node.jsã¯ããããã¯ãŒã¯ã¢ããªã±ãŒã·ã§ã³ãéçºããããã®å¯äžã®ããŒã«ã§ã¯ãããŸããã
- Geventã®ããã©ãŒãã³ã¹ã¯éåžžã«åªããŠããŸãã
- èšäºã®äœæã«ã¯ãæžããããæéãããããŸãã
- ããã©ãŒãã³ã¹ãã¹ãã¯ãæéããããè€éãªããã»ã¹ã§ãã
çå£ã«ãããã¯ãã¹ãŠããªãã®ãããžã§ã¯ããåäœããæ¡ä»¶ã«äŸåããŸãã èšå€§ãªæ°ã®ãã¹ããå®è¡ã§ããŸããããµãŒãã¹ãäœæããããšããã¹ãŠãå®å šã«ç°ãªãå¯èœæ§ãé«ããªããŸãã ããšãã°ãåçã®æ°ã10,000ãã1,000,000ã«å¢ãããšãéä¿¡ãã£ãã«ã§ã¯ãªãããŒããã©ã€ãã®ããã©ãŒãã³ã¹ãæ¢ã«ããã«ããã¯ã«ãªããŸãã
çŽ æ
ç¬èªã®ãã¹ããå®æœããããããã«è©³ãã調æ»ãããããå Žåã¯ããã®ãªã¹ãã圹ç«ã¡ãŸãã
å ±åæž
åã ã®ãã£ãŒããšæ°åãå«ãå®å šãªã¬ããŒãã¯ã次ã®ãªã³ã¯ããããŠã³ããŒãã§ããŸãã
- ããã¹ã/ Httperf / VPS 1 CPUã512Mb RAM
- ããã¹ã/ Httperf / Intel Core i7-4770ã¯ã¢ããã³ã¢Haswellã32 GB DDR3 RAM
- ãã¡ã€ã«/ Siege / Intel Core i7-4770 Quad-Core Haswellã32 GB DDR3 RAM
- GridFS / Siege / Intel Core i7-4770ã¯ã¢ããã³ã¢Haswellã32 GB DDR3 RAM
éå ·
ç§ã®ãã¹ãã§ã¯ã以äžã䜿çšããŸããã
ãã¬ãŒã ã¯ãŒã¯
é¢é£ãããã¹ãïŒ
- Gevent ïŒ ããã¹ã ã ãã¡ã€ã« ã GridFSãµãŒããŒã³ãŒã ïŒ
- Express.js ïŒ ããã¹ã ã ãã¡ã€ã« ã GridFSãµãŒããŒã³ãŒã ïŒ
- Eventlet ïŒ ããã¹ã ã ãã¡ã€ã«ãµãŒããŒã³ãŒãïŒ
- ç«å·» ïŒ ããã¹ã ã ãã¡ã€ã«ãµãŒããŒã³ãŒãïŒ
- Eventmachine ïŒ ããã¹ããµãŒããŒã³ãŒãïŒ
- ãã€ã¹ã ïŒ ããã¹ã ã ãã¡ã€ã«ãµãŒããŒã³ãŒãïŒ
ãæž èŽããããšãããããŸããã
Twitterã§ç§ããã©ããŒããŠãã ãããç§ã¯ã¹ã¿ãŒãã¢ããã§ã®ä»äºãç§ã®ééããšæ£ãã決æãPythonããããŠWebéçºã«é¢é£ãããã¹ãŠã«ã€ããŠè©±ããŠããŸãã
PS äŒç€Ÿã§éçºè ãæ¢ããŠããŸã ã詳现ã¯ç§ã®ãããã£ãŒã«ã«ãããŸã ã