![](https://habrastorage.org/getpro/habr/post_images/04c/5f2/c9e/04c5f2c9ef65c2ddd51244d80f5e2edb.jpg)
ãã®èšäºã§ã¯ããããžã§ã¯ãAnswersã«é¢é£ããã¿ã¹ã¯ã®å®è£ ã§ééãããã¹ãŠã®å°é£ãšèœãšãç©ŽãæãåºããŠèª¬æãããããžã§ã¯ãã®ã¢ãŒããã¯ãã£ã«ã€ããŠã説æããŸãã
ããã¯ãã¹ãŠãç§ã®å¥çŽãçµäºãããšããäºå®ããå§ãŸããŸããïŒMail.ruã¡ãŒã«ã®äœæ¥ã«åå ãã幎ã®éã«ïŒã ãåéºã¯åã³ç§ãåŸ ã£ãŠããŸããããæ°ããåœãæ°ããä»äºããšç§ã®èãããã©ãã·ã¥ããŸããã ç§ã¯äžåžã®ããšã«è¡ããŸããããããã§ãè°è«ã®éçšã§ãé¢çœããããžã§ã¯ãã®åœ¢ã§åéºã®äžéšãåãåããŸãã-å¿çãããžã§ã¯ããåãäžããŸãã
2012幎10æ15æ¥ã®æç¹ã§ããããžã§ã¯ãã«ã¯1æ¥ãããå¹³å350äžäººã®ãŠããŒã¯ããžã¿ãŒã蚪ããŸããã
ã«ãŠã³ãã¯ãå蚪åè ã«çºè¡ãããäžæã®ãCookieãïŒCookieïŒã«ãã£ãŠå®è¡ãããŸããã 蚪åè ã®ãã©ãŠã¶ã§Cookieã®åä¿¡ãç¡å¹ã«ãªã£ãŠããå Žåã蚪åè ã¯ã«ãŠã³ããããŸããããããžã§ã¯ãã®ååºã¯ã¹ã¯ãªãŒã³ãšåŒã°ããããšããããŸããã¹ã¯ãªãŒã³ã¯èª°ããç¥ã£ãŠãããšæããŸãã
![](https://habrastorage.org/getpro/habr/post_images/08b/304/42b/08b30442b231e016fc05ec9cfe29ae06.jpg)
䜿çšããããã¯ãããžãŒã®ã»ããã¯æ¬¡ã®ãšããã§ãã
- CentOS 5 i386
- Apacheã§ã®mod_perl
- Nginx
- SQLããŒã¿ããŒã¹
- rsyncã䜿çšããæŠéäžã®ã³ãŒãã®ã¬ã€ã¢ãŠã
ã¢ãŒããã¯ãã£ïŒ
![](https://habrastorage.org/getpro/habr/post_images/b85/913/02b/b8591302b7aa78e2f851220eb60cffa6.png)
å | è¡ãå | CPU | ã©ã ãGB | hdd | ã¡ã¢ |
ããªã ã¹ | æ£é¢ | 2xE5504 | 8 | 2 x sata | ãšã³ããªãŒãã€ã³ãããã©ã³ãµãŒ |
ã¢ã«ãã¡ | ãã㯠| 2xXeonå€ã | 2 | 2 x scsi | ãã®äžã§ããã¹ãŠã®ã¯ã©ãŠã³ã¹ã¯ãªãããèµ·åããŸã |
ã¢ã«ãŽã³ | ãã㯠| 2xE5504 | 8 | 2 x sata | |
ãã¿ã³ | ãã㯠| 2x E5506 | 4 | 2 x sata | |
ã«ã | ãã㯠| 2xE5405 | 8 | 2 x sata | ããã§wapãšmããŒãžã§ã³ |
ãªã¯ã¿ã³ | ãã㯠| 2xE5405 | 8 | 2 x sata | |
ã¡ã¿ã³ | ãã㯠| 2xE5506 | 4 | 2 x sata | |
ãããã³ | ãã㯠| 2xE5405 | 4 | 2 x sata | |
ã©ãã³ | ãã㯠| 2xE5504 | 8 | 2 x sata | |
ããªã³ | ãã㯠| 2xE5-2620 | 16 | 2 x sata | æ°ãã |
çªçŽ | ãã㯠| 2xE5-2620 | 16 | 2 x sata | æ°ãã |
ãã©ãºã | ãã㯠| 2xE5-2620 | 16 | 2 x sata | æ°ãã |
ã¿ã€ã¿ã³ | æ ç¹ | 2 x E5620 | 96 | 4sata + 20sas | ãã¹ã¿ãŒ |
ãã©ã³ | æ ç¹ | 2 x E5620 | 64 | 2 sata + 4 ssd | äžæ¬¡ã¬ããªã« |
極倧 | æ ç¹ | 2 x 5110 | 32 | 2 sata + 4 scsi | 管çããã«ã®ã¬ããªã« |
ãããã¹ | æ ç¹ | 2 x 5110 | 16 | 2 sata + 4 scsi | 管çããã«ã®ã¬ããªã« |
巚人 | æ ç¹ | 2 x 5130 | 8 | 6 scsi | ã³ã¡ã³ãããŒã¹ |
- ãããžã§ã¯ãã®äžå®å®æ§
- ãã®SQLããŒã¿ããŒã¹ã®éçšéšéã«ã¯ã¹ãã·ã£ãªã¹ããã»ãšãã©ããŸãããããŒã¿ããŒã¹ãèœã¡ããšãã«ãäœãäœã§ãªãç解ã§ããªãå¯äžã®ã¹ãã·ã£ãªã¹ããåžžã«å©çšã§ããããã§ã¯ãããŸããã
- ã¬ããªã«ã®é ãã®æ°žé ã®åé¡ãããã解決ãã人ã¯ããªã
- ããŒã¿ããŒã¹å ã®ããžãã¯ã®90ïŒ ãæ°ããæ©èœã®éçºãé£ãã
ãªãŒããŒã·ããããã®ææŠ
ãµãŒãã¹ã®å®å®ããéçšãšãã®ãããªãéçºã®å¯èœæ§ãç¹ã«ã¢ãã€ã«çã®èµ·åã確èªããŠãã ãããMysqlã«ç§»è¡ããŠããã»ã¹ããžãã¯ãã°ããŒãã«å ¥ãããšãã»ãšãã©ã®åé¡ã解決ããŸãã
æåã®ã¹ãããã¯ç£èŠã§ããã ç§ã¯åœŒã«ã€ããŠèšäºã«æžããŸããïŒãšããã§ã
AnyEventã§æžãçŽãããšãããçç£æ§ã¯æ¯ç§50ãã24äžè¡ã«å¢å ããŸããïŒã
圌ã¯æ¬¡ã®ããšã«ç®ãéããŸããã
- ç§ãã¡ã¯æ¯æ¥èœã¡ãŸãïŒ
- ãšã©ãŒ504ã®èšå€§ãªèæ¯ã1æ¥çŽ5äžã
504ã®çç±ã¯äœã§ããïŒ
- é ãHTMLããŒãµãŒã§ã質åããŒãžã衚瀺ãããšããã€ãŸããªã³ã¶ãã©ã€ã§ãã®ä»äºãããŸãã
- ã³ã³ãã³ããããŠã³ããŒããããããã
- YandexãšGoogleã®ã€ã³ããã¯ã¹ã
Yandexããã®æçŽïŒ
otvet.mail.ruã«ã€ããŠã¯ãè² è·ãå¢ããå§ããŸãããã1åããã200ãè¶ ãããªã¯ãšã¹ããè¡ãããšã¯ããŸããã§ããå¥ã®åé¡ãè¡šé¢åããŸããããã©ã³ãµãŒã§ã¯ã1ã€ã®IPãã1ç§ããã1ã€ã®ãªã¯ãšã¹ãã®å¶éãããããããå¢ãããšè² è·ã«å¯ŸåŠã§ããªããªããŸãã
æå»ã«é¢ä¿ãªãHTTP 503ãåä¿¡ãå§ãããšå€æããŸãã å¯èœã§ãã
ããªãã®åŽã§ãããæé€ããŸããïŒ
æ€çŽ¢ãã©ãã£ãã¯ã¯Responsesãããžã§ã¯ãã«ãšã£ãŠæãéèŠãªããšãªã®ã§ãè¿ éã«è¡åããå¿ èŠããããŸãã 誰ããç·åŒµããŠããŠãç¶æ³ã¯éç±ããŠããŸã=ïŒã
æãåçŽã§ãæãç°¡åã§ãå®äŸ¡ãªãã®ãããããªã³ããã©ãºããçªçŽ ã®3ã€ã®ããã¯ãšã³ããè³Œå ¥ããŸããã ããªã ã¹ãã©ã³ãµãŒã«RAMãè¿œå ããŸããïŒãèš±å¯ãããŠããªããã¹ãŠã®ãŠãŒã¶ãŒåãã«nginxã«çŽ40ïŒ ã®htmlãã£ãã·ã¥ãè¿œå ããŸããã ãã©ã³ãµãŒã®å¶éã¯ã1ç§ããã15ãªã¯ãšã¹ãã«å¢å ããŸããã
圌ãã¯æ¯æ¥èœäžãæ¢ããYandexã¯ãã¯ãç§ãã¡ã«ã€ããŠäžå¹³ãèšããŸããã§ããã é倧ãªåé¡ã解決ãããã®ã§ãã¿ã¹ã¯ã«ã€ããŠèããããšãã§ããŸãã
ä»åŸã¯ãæ°ããAPIã§ãé ãHTMLã®åé¡ã解決ããããšèšããŸãã ç¬èªã®è§£ææžã¿ïŒPerl XSïŒããŒãµãŒãé©çšããããŒã¿ããŒã¹ã«ä¿åãããšãã«ã®ã¿è§£æããŸããã 誰ããXSSãèŠã€ãããšããã¹ãŠã®æåã解æããã®ã«å€ãã®æéïŒ5ãã¿ãã€ãã®ããŒã¿ïŒããããããããã®ãããªãœãªã¥ãŒã·ã§ã³ã¯ã¡ãŒã«ã«ã¯é©ããŠããŸããããã®ãããä¿è·ãè¿œå ãããã®å Žã§è§£æããã®ãããç°¡åã§è¿ éã§ãã
移è¡ãšã¢ãã€ã«ç
移è¡ã¯ãããŒã¿ã®æŽåæ§ã®ç¶æãšãããžã§ã¯ãã®24æé365æ¥ã®ããã©ãŒãã³ã¹ãšãã2ã€ã®æ¡ä»¶ãæºããå¿ èŠããããŸãã ãããã£ãŠããããžã§ã¯ãããªãã«ããŠããŒã¿ã転éãããšå€±æããŸãã
APIãäœæããŸããããã«åºã¥ããŠãã¢ãã€ã«ããŒãžã§ã³ãšå°æ¥ã®ãããã°ãããŒãžã§ã³ã®äž¡æ¹ã§ããã¹ãŠãæ©èœããŸãã APIã¯ããã¹ã«ããã®ã¿èªã¿åããå€ãããŒã¿ããŒã¹ãšæ°ããããŒã¿ããŒã¹ã®äž¡æ¹ã«æžã蟌ã¿ãŸãã
![](https://habrastorage.org/getpro/habr/post_images/edc/a6a/382/edca6a3824c3e61599a5ec2418873809.png)
MySQLãå€ãããŒã¿ããŒã¹ããå€æŽãååŸããããã«ãåæããå¿ èŠããããšã³ãã£ãã£ãæžã蟌ããã¥ãŒãéå§ããŸãããïŒå€ããšã³ãã£ãã£ããååŸããŠãæ°ãããšã³ãã£ãã£ã§è¿œå ãŸãã¯çœ®æããŸãïŒã
![](https://habrastorage.org/getpro/habr/post_images/6d2/4cd/1d9/6d24cd1d90ac1f20a633698023e4ad11.png)
ãããè¡ãã«ã¯ãããŒã¹å šäœããšã³ãã£ãã£ã«åå²ããå¿ èŠããããŸãã ããšãã°ãåçã質åããŠãŒã¶ãŒããã¹ãŠã®ãŠãŒã¶ãŒã®åçãªã©ãååæããã¿ã¹ã¯ã
ãŸããåæã®ããã®ã¿ã¹ã¯ã®ã¹ããªãŒã ãèšå€§ã§ããããããã®ãã¥ãŒã®ãã³ãã©ãŒã䞊è¡ããŠåäœããããšãèæ ®ããå¿ èŠããããŸãã æçµçã«12åã®ãã©ãŒã¯ãåŠçã§ããŸããã
ããã¯ãã¹ãŠå¿ èŠãªããããã€ã§ããã¥ãŒã«ã¿ã¹ã¯ãè¿œå ããŠãå¿ èŠãªãšã³ãã£ãã£ãå®å šã«ååæã§ããŸãã
ããã§ãããã¯å§ãŸããŸããã 1æ10æ¥ã ã¢ã¬ãã¯ã¹Q倧麊ããªãªãŒã¹ãããŸããã ã©ã€ã³ã¯çèã«å®è£ ãããŸããã ããã¹ã«çšã«2ã€ã®ãµãŒããŒïŒãããŒãããšããã€ã³ããšåŒã°ããïŒãš2ã€ã®ããã³ãïŒãããã³ããšãããŒãã³ãïŒãè³Œå ¥ããŸããã ããã¹ã«ãã¹ã¿ãŒãšã¬ããªã«ã 圌ãã¯å€ãããŒãžã§ã³ã«ãååæã®ããã«ãã¥ãŒã«ã¿ã¹ã¯ãæžãããšãæããŸããã ããã¯éåžžã«æ¥åžžçã§ãçã¿ã䌎ãé·ãããã»ã¹ã§ããã å€ãã°ããŒãã«æžã蟌ãå°ããªã°ããŒãã®ãã¹ãŠã®å ŽæãèŠã€ããŠã察å¿ããååæã¿ã¹ã¯ã§ããã¯ã¢ããããå¿ èŠããããŸããã
çŸæç¹ã§ã¯ãäž»ãªããšã¯æ¬¡ã®ããšãå¿ããªãããšã§ãã
- ããŒã¿ããŒã¹å ã®cronãžã§ãã ãã®åŸãããŒã¿ããŒã¹å ã®ããã±ãŒãžã³ãŒãã«å¹²æžããããªããããæ°ããããŒãžã§ã³ã«ã¢ããã°ãå®è£ ããå¿ èŠããããŸããã
- éåžžã®çå ã¹ã¯ãªããã 圌ãã®ããã«ãæã ã¯æ°ããããŒãžã§ã³ã§åæ§ã®ãã®ãæžããŸããã
- ãŸããæãé°æ¹¿ãªããããã¯ããªã¬ãŒã§ãã ç§ãã¡ã®å ŽåãããŒã¹ã®æŠéããŒãžã§ã³ã¯éçºããŒãžã§ã³ãšã¯ç°ãªãããšãå€æããŸããã ãããã£ãŠãããã泚ææ·±ã培åºçã«ç¢ºèªããŠãã ããã
äžèšã®ãšã©ãŒã¯ãããã14æ¥éããããŸãã ãªããããªã«å€ãã®ã§ããïŒ ããã«ã€ããŠã¯åŸã§è©³ãã説æããŸãã
ãã®ãããå€ãããŒãžã§ã³ã¯ãã¥ãŒã«æžã蟌ã¿ãè² è·ã確èªã§ããŸãã å€ãããŒãžã§ã³ãæåã«2ã€ã®ããã¯ã§å±éãã次ã«4ã€ã®ããã¯ã§å±éããçèã確èªããŸãããã¹ãŠåé¡ãããŸããããã¹ãŠã®åå²ã§å±éããè² è·ãç¶æããŸãã 次ã®ã¹ãããã«é²ã¿ãŸãã
圌ãã¯ãåãåå²ããŠè¿œè·¡ããæ¹æ³ãç¥ã£ãŠãããã¥ãŒãã³ãã©ãäœæããŸãããåãèœã¡ãããæ°ããåãçæããŸãã 圌ã¯ã¿ã¹ã¯ã®äžéšãåããããããååæããããããå¿ èŠãªæ§é ã«å€ããŸãã å°æ¥çã«ã¯ã2ã€ã®æŠç¥ã®ãã¡ããããããããããçš®é¡ã®ã¿ã¹ã¯ãã¬ã€ã¯ãã12ã®ãã©ãŒã¯ã®èµ·åããã¿ã¹ã¯Aãå®è¡ãã4ã€ã®ãã©ãŒã¯ãã¿ã¹ã¯Bãå®äºãã4ã€ã®ãã©ãŒã¯ã®èµ·åãããé ãããšã«æ°ä»ããŸããã
ããã¯ããã¥ãŒããã»ããµãçŸåšã®ãã¹ã§ååæãããšã³ãã£ãã£ãèšæ¶ããå床äžèŽããå Žåã¯ããããã¹ããããããšããäºå®ã«ãã£ãŠèª¬æãããŸãããŸãããšã³ãã£ãã£ã®çš®é¡ãå¶éãããšãæ¢ã«åŠçãããã¿ã¹ã¯ã«å ¥ã確çãã¯ããã«é«ããªããŸãã
ãã®çµæããã¥ãŒã«æžã蟌ãããã«å€ãããŒãžã§ã³ãæããŸããããã¥ãŒããã»ããµã¯æºåãã§ããŠããŸãã å€ãããŒãžã§ã³ãæŠéã«æå ¥ãããŸãã ãã¥ãŒã¯å±±ç©ã¿ã«ãªã£ãŠããŸããããããŸã§ã®ãšããã¯ã¬ã€ã¯ãããŠããŸããã
次ã«ããã§ã«èç©ãããããŒã¿ãããããŒã¿ããŒã¹ããå¥ã®ããŒã¿ããŒã¹ã«è»¢éããå¿ èŠããããŸãã çŽ500ã®ã¬ãã€ãã§ãã ã©ããã£ãŠããã®ïŒ ããããšãã¢ã¬ãã¯ã¹Q =ïŒ
ãã£ã¬ã³ãžïŒ
å€ãSQLããŒã¿ããŒã¹ããMySQLãžã®å€§ããªããŒãã«ïŒæ倧1å5åäžã¬ã³ãŒãïŒã®ç§»è¡ã åæã«ãæ§é ã¯ïŒãããã«ïŒå€æŽã§ããŸããããšãã°ãå€ãSQLããŒã¿ããŒã¹ã§ã¯ãããŒã«åãã£ãŒã«ãã¯CHARïŒ1ïŒã§ããïŒé衚瀺ã«ã¯å€ ''ãŸã㯠'H'ã䜿çšã§ããŸãïŒãMySQLã§ã¯TINYINTã«ãªããŸãïŒé衚瀺ã¯0ãŸãã¯1ã«ãªããŸãïŒãããŒã¿è»¢éã«å ããŠãå€ãããŒã¿ããŒã¹ã§ããŒã¿ãè¿œå ããã³å€æŽã§ããŸãã ãã®åé¡ã¯ãå€ãããŒã¿ããŒã¹ã®ã©ã®ããŒã¿ãå€æŽãŸãã¯è¿œå ããããã«ã€ããŠã®æ å ±ãæžã蟌ãŸãããã¥ãŒãäœæããããšã§è§£æ±ºãããŸãã ããŒãã«ã®ç§»è¡äžããäºååæãã®ãžã§ãã¯ãã¥ãŒã«èç©ãããŸãã ãã®åŸããã¥ãŒã¯å¥ã®ã¹ã¯ãªããã§è§£æãããŸãã
移è¡ïŒ
- INSERTã䜿çšãããããã¯ããã«é«éã§ãããããæååã®1000ïŒããã©ã«ãã§ã¯ãã¹ã¿ãŒãã¢ããããŒã«ãã£ãŠãªãŒããŒã©ã€ããããïŒã®ããã¯ã§LOAD DATA INFILEãä»ããŠMySQLã«ã€ã³ããŒãããŸãã
- FIFOãã€ããããŒã¿è»¢éãã¡ã€ã«ãšããŠäœ¿çšããŸããããã¯ããã¹ãŠã®ããŒã¿ããã£ã¹ã¯ã«æžã蟌ãŸãã«ã¡ã¢ãªãééããããã§ãã ãã¡ã€ã«ã䜿çšãããããå€§å¹ ã«é«éã«ãªããŸãã
- ãã®ã¹ã¯ãªããã¯ãå€ãSQLããŒã¿ããŒã¹ïŒããšãã°ã10000ïŒããNè¡ãèªã¿åããŸãã
- ã¹ã¯ãªããã¯åããã»ã¹ã解æããŸãã ãã®ããã»ã¹ã§ã¯ãèªã¿åãçšã®FIFOãéãããããããMySQLã§LOAD DATA INFILEãå®è¡ãããŸãã
- 芪ã¯fifoã«Kè¡ïŒããšãã°1000ïŒãæžã蟌ã¿ãŸãã åããã¯ã®åŸããã€ãã®ãã¡ã€ã«ãã³ãã«ãéããåããã»ã¹ãçµäºãããŸã§åŸ æ©ããã¹ããã1ã§ååŸããããŒã¿ããªããªããŸã§ã¹ããã2ããç¹°ãè¿ããŸãã
2013幎2æ26æ¥-æåã®ã³ãããã 2013幎3æ6æ¥ãŸã§ã«ãäœæ¥ããŒãžã§ã³ãæºåã§ããŸãã çä¿¡ããŒãã«ïŒå€ãSQLããŒã¿ããŒã¹ïŒãšåºåããŒãã«ïŒMySQLïŒold_to_MySQLïŒïŒã®èª¬æãååŸããé¢æ°ãäœæãããã¹ãŠã®åŠçãå®è¡ããŸããã çªç¶ã®fakapäžã«ãŒãããéå§ããªãããã«ãold_migrate MySQLããŒãã«ã«åããŒãã«ã®æåŸã«ç§»è¡ãããè¡ã®IDãä¿åããŸãã
LOAD INFILE IGNOREã§ã¯ãªãLOAD INFILE REPLACEã䜿çšããŠãããããfakapããå埩ãããšãã«ãå€ãSQLããŒã¿ããŒã¹ã®ããŒã¿å€æŽã倱ãããããšã¯ãããŸããã
3æ15æ¥ãããã©ã«ãå€ã®åé¡ã¯äžæçã«è§£æ±ºãããŸãããå€ãSQLããŒã¿ããŒã¹ããNULLãçºçããMySQLã®NOT NULL DEFAULTåã0ã®å ŽåãNULLãæ¿å ¥ããããšãããšã¯ã©ãã·ã¥ããŸãã ã¹ããŒã ã®èª¬æã«ã¯ãå¿ èŠãªããŒåã®ã»ããããããŸããæ®ãã¯ãã¹ãŠãNULLãæ¥ãå Žåã«DEFAULTãæ¿å ¥ããŸãã
3æ20æ¥ãSIGPIPEãšã®æŠäºãå§ãŸããŸããã
æŠäºã®æ®µéïŒ
- $ SIG {PIPE}ãè¿œå ããŸãããããã¯ãä¿åãããäœçœ®ããã®å€ããã©ã¡ãŒã¿ãŒã䜿çšããŠold_to_MySQLïŒïŒã®åŒã³åºããç¹°ãè¿ããŸãã é·ãéããã¹ãŠãæ©èœããŠããŸããã
- 11æ13ã14æ¥ãSIGPIPEãåæã ãã€ããæäœããæé ãä¿®æ£ããŸããããŸããèªã¿åãçšã«fifoãéãã次ã«æžã蟌ã¿çšã«fifoãéããŸãã sigipeãšã®æŠãã®éã«ãdie / warnã®ä»£ããã«croak / carpãè¿œå ããCarpã®ãã°72467ïŒè§£æŸãããã¹ã«ã©ãŒãã³ããŒããããšããïŒã«ééãããã¹ãŠãå ã«æ»ããŸããã
- å©ãã«ã¯ãªããŸããã§ãã ç¡ç ã¯ãèªæžã®ããã«ãã€ããéããåŸããã«å©ãã«ã¯ãªããŸããã§ããã äžæãã¡ã€ã«ã«ç»ããŸããã ããã¯ãã¹ãŠã®ç¡ç ãç·©ããããšã«ããèããéããªããã·ã®ããšã®æŠãã§æŸèæãšããŠåœ¹ç«ã£ãã è¯ããªããŸããã
ã·ã°ã·ãæŠäºã¯ã11æ13æ¥ãš14æ¥ã«2æ¥éç¶ããŸããã ãšãŠãå¿ãã2æ¥éã§ããã
åèšã§ããããã®500ã®ã¬ãã€ãã転éããã®ã«14æ¥ããããŸããã
転éã®é²è¡äžãæ°ããAPIã®ã¢ã«ãã¡çïŒPerlãfast_cgiïŒã¯æ¢ã«æºåãããŠããŸããã
ããŒã¿ã転éããäŒæ¥ãŠãŒã¶ãŒåãã®ãã¹ãã¢ãã€ã«ããŒãžã§ã³ãéå§ããŸããã èŠãŠããã¹ãããŸãã å¶ç¶ãå€ãããŒãžã§ã³ã®ãã°ã§ãèäžã®1ã€ã§ãå°ããªperjochkaãDBDã¢ãžã¥ãŒã«ããªãããšãèªããšãããšã©ãŒã«æ°ä»ããŸããã ããã¯ãåããã®ãžã§ãããã¥ãŒãé¢ããŠããããããŒã¹ãäžè²«ããŠããªãããšãæå³ããŸãã ãããã¯ãœ ç§ã¯ãã¹ãŠãåã³è»¢éããªããã°ãªããŸããã§ããã 14æ¥ãçµéããŸãã=ïŒã
ããã§ãããŒã¿è»¢éåŸããã¥ãŒã®ã¬ã€ã¯ãéå§ã§ããçŽ3åã®å·šå€§ãªãžã§ããèç©ãããŸããã
ãã³ãã©ãŒã®éå§-é ãããã ç§ãã¡ã¯ãã¬ãŒãã®åå ãæ¢ããŠããŸããããã¿ãŒã³ãããã¬ãŒãã®ã€ã³ããã¯ã¹ãå¿ èŠã§ããããšãããããŸããã ç§ã¯æ¬åœã«14æ¥éåã³åŸ ã¡ãããããŸããã§ããã å¥ã®åããã¬ãŒããäœæããŸããããã€ã³ããã¯ã¹ããããŸãã 圌女ãã¡ã¯å€ãããŒãžã§ã³ãå ¬éãã圌女ã¯ã€ã³ããã¯ã¹ä»ãã®æ°ããçã«æžããã ããã¯InnoDBã§ããã ã€ã³ããã¯ã¹ãè¿œå ããŸããã 圌ãã¯ã¿ãã¬ãããããéããŠæ®ºããŸããã ãã¹ãŠã®ååãå ã«æ»ããŸããã
ããŸãããããã§ãã ã©ãã
æ°ããAPIã¯ãäž¡æ¹ã®ããŒã¿ããŒã¹ã«æžã蟌ãããšãã§ããå¿ èŠããããŸãã ããŸãã«ãå€ãã®æéãåŸ ããªãããã«éåæã«æžã蟌ã¿ãŸãã ãããè¡ãã«ã¯ãæ°ããããŒã¿ããŒã¹ã®ããŒãã«ã§ãèªåã€ã³ã¯ãªã¡ã³ãã®åæäœçœ®ã䜿çšããŠidã§äºçŽããŸãã ããšãã°ãå€ãããŒã¿ããŒã¹ã§ã¯è³ªåã®æ倧IDã¯1000ã§ãæ°ããããŒã¿ããŒã¹ã®åæ§ã®ããŒãã«ã§ã¯ãèªåã€ã³ã¯ãªã¡ã³ã2000ã®åæäœçœ®ãèšå®ããŸãã
æ°ããAPIã䜿çšããŠè³ªåãè¿œå ããèå¥å2001ãèŠã€ããå€ãããŒã¿ããŒã¹ã«è¿œå ããããã«èå¥å1001ãè¿œå ããèå¥å2001ã§ã¬ã³ãŒããæŽæ°ããèå¥å1001ã§ã¬ã³ãŒãã«å€æããŸãããããã£ãŠããšã³ãã£ãã£ã®èå¥åã¯ããŒã¿ããŒã¹ã§äžèŽããŸãã
ãã®åŸãããã¹ã«ãåèµ·åããããããŒãã«ãå€æŽããåŸãèªåã€ã³ã¯ãªã¡ã³ãããã©ã€ããªããŒã®æ倧å€ã«ãªã»ãããããããšãåŠã³ãŸããã ãããã£ãŠããããåé¿ããããã«ãèªåã€ã³ã¯ãªã¡ã³ãã®éå§çªå·ã«çãã倧ããªèå¥åãæã€ãšã³ãã£ãã£ããŒã¿ããŒã¹ãMySQLã«è¿œå ããŸãããå¿ èŠãªãšã³ãã£ãã£ãååæããããã®ã¿ã¹ã¯ããã¥ãŒã«è¿œå ããããšã«ãããããã«ãã¹ãŠã®phakapsã解決ãããŸããã
ç§ã¯ããå°ãæãåºããŸããïŒéçšéšéãããã©ãããããããããŒã¿ã»ã³ã¿ãŒã®1ã€ãå®æžããªããã°ãªããªããããããªããšãããã¥ãŒã¹ãèããŸãããã¢ãã€ã«ããŒãžã§ã³ã¯ãã§ã«æŠãäžã§ãããå€ãããŒã¿ããŒã¹ãæã€ãµãŒããŒããã®ããŒã¿ã»ã³ã¿ãŒã«ãããšããäºå®ãèãããšãå¥ã®æ°ããMySQLããŒã¿ããŒã¹-ããã¯å®å šã«æ²ãããªããŸããã ãããã幞ããªããšã«ãäºæž¬ã¯å®çŸããŸããã§ããã
äœãèµ·ãã£ãã®ãæ³åããŠã¿ãŠãã ããã
ããŒã¿ã»ã³ã¿ãŒã«å€ãããŒã¿ããŒã¹ãè¿æžããŸãã-ãã®åŸãããã«å¥ã®ããŒã¿ã»ã³ã¿ãŒã®åé¢ãäžžããïŒãã®ãã¥ãŒã¹ãç¥ã£ããšãããã«ãããè¡ããŸããïŒãã¢ãã€ã«ããŒãžã§ã³ãèªã¿åãå°çšã¢ãŒãã«åãæ¿ããå šå¡ãã¢ãã€ã«ããŒãžã§ã³ã«ãªãã€ã¬ã¯ãããŸãã
ããŒã¿ã»ã³ã¿ãŒã«æ°ããããŒã¿ããŒã¹ãè¿æžããŸãã-åæã®ããã«ãã¥ãŒã®èšé²ããªãã«ããŸãã ããŒã¿ã»ã³ã¿ãŒãæ©èœãå§ããåŸãåé¡ã®çºçåŸã«äœæããããã¹ãŠã®ãšã³ãã£ãã£ããã¥ãŒã«å ¥ããéãã«ååæããŸãã
3æãã¢ãã€ã«çãçºå£²ãããŸããã 1æ¥çŽ50äžäººã®ãŠããŒã¯ãªäººã ãããã«æ¥ãŸããã è² è·ãæãããã¹ãŠãã¹ããŒãã«æ©èœããŸãã
ãããžã§ã¯ãã®ã¢ãŒããã¯ãã£ã¯æ¬¡ã®åœ¢åŒãåããŸããã
![](https://habrastorage.org/getpro/habr/post_images/486/df1/e25/486df1e25ac2ab5607f71e1331955d6f.png)
å | è¡ãå | CPU | ã©ã ãGB | hdd | ã¡ã¢ |
ç·çµ | æ£é¢ | 2xE5-2620 | 32 | 2 x sata | httpd + mod_fcgidã倧ããªé»åããŒãžã³ |
ããŒãã³ | æ£é¢ | 2xE5-2620 | 32 | 2 x sata | httpd + mod_fcgidã倧ããªé»åããŒãžã³ |
ãã¬ã¶ | æ ç¹ | 2xE5-2609 | 96 | 2 x SATA + 10 x ssd | mysqlãã¹ã¿ãŒ |
ãœã¹ã | æ ç¹ | 2xE5-2609 | 96 | 2 x SATA + 10 x ssd | mysqlã¬ããªã« |
ããã¿ | æ ç¹ | 2xE5-2609 | 96 | 2 x SATA + 10 x ssd | mysqlã¬ããªã« |
è·éŠ¬è» | ã¡ã³ã±ã·ã¥ | 2xE5-2620 | 64 | 2 x sata | 2ã€ã®memcachedã€ã³ã¹ã¿ã³ã¹ |
圌ãã¯ãããããã¢ã¹ã¯ã¯å°æ¹ã«å·»ã蟌ãã ã 1ç§ããã800ãªã¯ãšã¹ãã®è² è·ã§ãApacheãçããŠããããšãããããŸããã æåã¯mod_fcgidã«ç念ããããŸããããç¯äººã¯mod_rpafã§ããããšãå€æããŸããã Monsã®ãããã§ã圌ã¯Apache Apacheã¯ã©ã¹ããå·§ã¿ã«ãã¬ã€ããŸããã
圌ãã¯mod_rpafãæŸæ£ããnginxã䜿çšããŠX-Real-IPããããŒããIPãæããŸããã
圌ãã¯ãã·ã¢äžã«ããã転ãããŸãããæã ã¯è² è·ãä¿ã¡ãŸãã 圌ãã¯æ°ãããããã°ãããŒãžã§ã³ãäœæããå šå¡ããªãã€ã¬ã¯ããå§ããŸããã 11æ19æ¥ãå€ãããŒãžã§ã³ã¯çµäºããŸããã
ããªã ã¹ãã©ã³ãµãŒã®å°çã®å¶éãåé€ããŸããïŒ1ã€ã®IPããæ¯ç§15ãªã¯ãšã¹ãïŒã è² è·ãéåžžã«ä¿ã¡ãŸãã APIããã®1ç§ãããçŽ950ãªã¯ãšã¹ãã
åºåžè ã¯1æ¥ãããå¹³å650äžäººã§ãã
ãã¹ãŠã®ãµãŒããŒã§CentOS 64ãããã䜿çšããRPMããã±ãŒãžãä»ããŠæŠéãžã®å±éãè¡ãããŸãã çŸæç¹ã§ã¯ãperlachkaã¯ãŸã Apache2ïŒmod_fcgidïŒã®äžã§å転ããŠããŸãã yumãããã°ãããŒã«ããã¯ããåŸãããã¯ãé çªã«åèµ·åããŸãã
åé¢ã§ã¯ã次ã®ãã®ã䜿çšããŸãã
proxy_next_upstream timeout error http_502 http_504;
ã€ãŸãããŠãŒã¶ãŒã502ãŸãã¯504ãåãåã£ãå ŽåããŠãŒã¶ãŒã¯å¥ã®ããã¯ãšã³ãã®äœ¿çšãèš±å¯ããããããApacheã®åèµ·åã«ããäžå¿«æãæå°éã«æããããŸãã
è² è·ãã£ãŒãã¯ãã¡ãã«ãããŸã ã
ãã®ã¡ã¢ããç§ãã¡ãæ©ããã¬ãŒããèžãŸãªãããã«ããã®ã«åœ¹ç«ã€ããšãé¡ã£ãŠããŸãïŒ èŠããŠãããŠãã ãããããªãèªèº«ãããããä»äººã®ééãããåŠã¶æ¹ãè¯ãã§ãïŒ :)