- å€å žçãªã¢ã«ãŽãªãºã ã¯ãããŸããã
- åé¡ã¯ãŸã çºçããŠãããïŒäžæïŒãã©ãã«ããããæšæž¬ããããšããã§ããŸããã
- ã·ã¹ãã å ã®æœåšçãªåŒ±ç¹ãèŠã€ããå¿ èŠããããŸãã
- ãããã®å Žæã§ã¯ãšãªã®ããã©ãŒãã³ã¹ãæé©åããŠãã ããã
ããã¢ã¯ãã£ããªæé©åã®äž»ãªç®æš
ããã¢ã¯ãã£ããªæé©åã®äž»ãªã¿ã¹ã¯ã¯ããªã¢ã¯ãã£ããªæé©åã®ã¿ã¹ã¯ãšã¯ç°ãªãã次ã®ãšããã§ãã
- ããŒã¿ããŒã¹ã®ããã«ããã¯ãåãé€ãã
- ããŒã¿ããŒã¹ã®ãªãœãŒã¹æ¶è²»ã®æžå°ã
æåŸã®ç¬éãæãåºæ¬çã§ãã ãªã¢ã¯ãã£ãæé©åã®å ŽåããªãœãŒã¹æ¶è²»å šäœãåæžããã¿ã¹ã¯ã¯ãããŸããããæ©èœã®å¿çæéã蚱容ç¯å²å ã«ããã¿ã¹ã¯ã®ã¿ããããŸãã

ããã«ãµãŒããŒã䜿çšããŠããå Žåãããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã®æå³ãç解ã§ããŸãã ãã¹ãŠãçµäºããåé¡ãè¿ éã«è§£æ±ºããå¿ èŠããããŸãã RNKO Payment Center LLCã¯å€ãã®ãšãŒãžã§ã³ããšé£æºããŠãããã§ããã ãå°ãªãåé¡ãæ±ããããšãéåžžã«éèŠã§ãã HighLoad ++ Siberiaã®Alexander Makarovã¯ãããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã®æ°ãå€§å¹ ã«æžããããã«äœãè¡ãããããèªããŸããã ããã¢ã¯ãã£ããªæé©åãå©ãã«ãªããŸããã ãããŠãæŠéãµãŒããŒã§äœæãããçç±ãšæ¹æ³ã«ã€ããŠã¯ã以äžããèªã¿ãã ããã

è¬æŒè ã«ã€ããŠïŒã¢ã¬ã¯ãµã³ããŒãã«ããïŒ AL_IG_Makarov ïŒãOracleããŒã¿ããŒã¹ã®äž»ä»»ç®¡çè ãRNCO Payment Center LLCã äœçœ®ã«ããããããããã®ãããªç®¡çã¯ã»ãšãã©ãããŸãããäž»ãªã¿ã¹ã¯ã¯ãç¹ã«ããã©ãŒãã³ã¹ã®åé¡ã解決ããããã«ãè€åäœã®ã¡ã³ããã³ã¹ãšãã®éçºã«é¢é£ããŠããŸãã
æŠéããŒã¿ããŒã¹ã®æé©åã¯ããã¢ã¯ãã£ãã§ããïŒ
ãŸãããã®ã¬ããŒãã§ãããã¢ã¯ãã£ããªããã©ãŒãã³ã¹ã®æé©åããšåŒã°ããçšèªãæ±ããŸãã ããã¢ã¯ãã£ããªæé©åãšã¯ãã¢ããªã±ãŒã·ã§ã³ãèµ·åããåã§ãã£ãŠãåé¡é åã®åæãå®è¡ããããšã§ãããšãã芳ç¹ãæºãããå ŽåããããŸãã ããšãã°ãååãªã€ã³ããã¯ã¹ããªãããã¯ãšãªãéå¹ççãªã¢ã«ãŽãªãºã ã䜿çšããŠããããã®äœæ¥ã¯ãã¹ããµãŒããŒã§å®è¡ããããããäžéšã®ã¯ãšãªã¯æé©ã«æ©èœããªãããšãããããŸãã
ããã«ãããããããRNCOã®ç§ãã¡ã¯æŠéãµãŒããŒã§ãã®ãããžã§ã¯ããè¡ããŸããã ç§ã¯äœåºŠãèããïŒãã©ãããŠïŒ æŠéãµãŒããŒã§ãããè¡ããŸããã€ãŸããããã¢ã¯ãã£ããªããã©ãŒãã³ã¹ã®æé©åã§ã¯ãããŸããïŒãããã§ã¯ãITILã§å¹ãããã¢ãããŒããæãåºãå¿ èŠããããŸãã ITILã®èŠ³ç¹ããã次ã®ãã®ããããŸãã
- ããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã¯æ¢ã«çºçããŠãããã®ã§ãã
- ããã©ãŒãã³ã¹ã€ã³ã·ãã³ããçºçããªãããã«ããããã®å¯Ÿçã
ãã®æå³ã§ãç§ãã¡ã®è¡åã¯ç©æ¥µçã§ãã ããã«ãµãŒããŒã§åé¡ã解決ããŠãããšããäºå®ã«ãããããããåé¡èªäœã¯ãŸã çºçããŠããŸãããã€ã³ã·ãã³ãã¯çºçãããå®è¡ãããçæéã§ãã®åé¡ã解決ããããšããŸããã§ããã
ãããã£ãŠããã®ã¬ããŒãã§ã¯ãããã¢ã¯ãã£ãã¯ITILã®æå³ã§ã®ããã¢ã¯ãã£ããšç解ãããŠãã ãããã©ãŒãã³ã¹ã€ã³ã·ãã³ããçºçããåã«åé¡ã解決ããŸãã
åºæºç¹
RNKOãPayment Centerãã¯ã2ã€ã®å€§èŠæš¡ã·ã¹ãã ã«å¯Ÿå¿ããŠããŸãã
- RBS-Retail Bank;
- CFTéè¡ã
ãããã®ã·ã¹ãã ã®è² è·ã®æ§è³ªã¯æ··åšããŠããŸãïŒDSS + OLTPïŒïŒéåžžã«è¿ éã«æ©èœãããã®ããããã¬ããŒãããããäžçšåºŠã®è² è·ããããŸãã
ããŸãé »ç¹ã§ã¯ãªããäžå®ã®é »åºŠã§ããã©ãŒãã³ã¹ã®åé¡ãçºçãããšããäºå®ã«çŽé¢ããŸããã ããã«ãµãŒããŒã§äœæ¥ãã人ã¯ããããäœã§ããããæ³åããŸãã ããã¯ããã®æç¹ã§ã¯ã©ã€ã¢ã³ãããµãŒãã¹ãåä¿¡ã§ããªãããäœãããŸã£ããæ©èœããªãããåäœãéåžžã«é ãããããã¹ãŠãçµäºããŠåé¡ãè¿ éã«è§£æ±ºããå¿ èŠãããããšãæå³ããŸãã
éåžžã«å€ãã®ãšãŒãžã§ã³ããšã¯ã©ã€ã¢ã³ããçµç¹ã«çµã³ã€ããŠãããããããã¯ç§ãã¡ã«ãšã£ãŠéåžžã«éèŠã§ãã ããã©ãŒãã³ã¹ã®åé¡ãè¿ éã«è§£æ±ºã§ããªãå Žåãã客æ§ã¯äœããã®åœ¢ã§èŠããããšã«ãªããŸãã ããšãã°ãã«ãŒããè£å ããããééãããããããšã¯ã§ããŸããã ãããã£ãŠããããã®ãŸããªããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã§ããåãé€ãããã«äœãã§ããã®ãçåã«æããŸããã ãã¹ãŠãããããããŠåé¡ã解決ããå¿ èŠããããšãã«ã¢ãŒãã§äœæ¥ãã-ããã¯å®å šã«æ£ããããã§ã¯ãããŸããã ã¹ããªã³ãã䜿çšããŠãã¹ããªã³ãäœæ¥èšç»ãäœæããŸãã ããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã®ååšã¯ãäœæ¥èšç»ããã®éžè±ã§ããããŸãã
ããªãã¯ããã«ã€ããŠäœããããªããã°ãªããŸããïŒ
æé©åã¢ãããŒã
ããã¢ã¯ãã£ããªæé©åã®ãã¯ãããžãŒãèããç解ããããã«ãªããŸããã ãã ããããã¢ã¯ãã£ããªæé©åã«ã€ããŠèª¬æããåã«ãå€å žçãªãªã¢ã¯ãã£ããªæé©åã«ã€ããŠããã€ã説æããå¿ èŠããããŸãã
ãªã¢ã¯ãã£ãæé©å
ã·ããªãªã¯åçŽã§ããäœããèµ·ãã£ãããã«ãµãŒããŒããããŸãã圌ãã¯ã¬ããŒããç«ã¡äžããã¯ã©ã€ã¢ã³ãã¯ã¹ããŒãã¡ã³ããåãåãããã®æç¹ã§ããŒã¿ããŒã¹äžã§é²è¡äžã®ã¢ã¯ãã£ããã£ããããçªç¶èª°ããäœããã®çš®é¡ã®ãã£ã¬ã¯ããªãæŽæ°ããããšã決ããŸããã ã·ã¹ãã ã®é床ãäœäžãå§ããŸãã ãã®æç¹ã§ãã¯ã©ã€ã¢ã³ããæ¥ãŠããç§ã¯ãããŸãã¯ãããããããšãã§ããŸããããšèšããŸã-ç§ãã¡ã¯åœŒããããã§ããªãçç±ãèŠã€ããå¿ èŠããããŸãã
åŸæ¥ã®ã¢ã¯ã·ã§ã³ã¢ã«ãŽãªãºã ïŒ
- åé¡ãåçŸããŸãã
- åé¡ç®æãèŠã€ããŸãã
- åé¡ç®æãæé©åããŸãã
ãªã¢ã¯ãã£ãã¢ãããŒãã®ãã¬ãŒã ã¯ãŒã¯å ã§ã®äž»ãªã¿ã¹ã¯ã¯ãæ ¹æ¬åå èªäœãèŠã€ããŠãããæé€ããããšã§ã¯ãªããã·ã¹ãã ãæ£åžžã«æ©èœãããæ¹æ³ã§ãã æ ¹æ¬åå ã®é€å»ã¯åŸã§å¯ŸåŠã§ããŸãã äž»ãªããšã¯ãã¯ã©ã€ã¢ã³ãããµãŒãã¹ãåä¿¡ã§ããããã«ããµãŒããŒããã°ãã埩å ããããšã§ãã
ãªã¢ã¯ãã£ãæé©åã®äž»ãªç®æš
ãªã¢ã¯ãã£ãæé©åã§ã¯ã2ã€ã®äž»èŠãªç®æšãåºå¥ã§ããŸãã
1. å¿çæéãççž®ããŸãã
ã¬ããŒããã¹ããŒãã¡ã³ãããã©ã³ã¶ã¯ã·ã§ã³ã®åä¿¡ãªã©ã®ã¢ã¯ã·ã§ã³ã¯ãã¹ã±ãžã¥ãŒã«ãããæéã«å®è¡ããå¿ èŠããããŸãã ãµãŒãã¹ã®åä¿¡æéãã¯ã©ã€ã¢ã³ãã«åãå ¥ããããå¢çã«æ»ãããšã確èªããå¿ èŠããããŸãã ãµãŒãã¹ã¯éåžžããå°ãé ããªããããããŸããããã¯ã©ã€ã¢ã³ãã«ãšã£ãŠã¯ããã¯èš±å®¹ç¯å²ã§ãã ãã®åŸãããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã¯è§£æ¶ããããšèããæ ¹æ¬åå ã®èª¿æ»ãéå§ããŸãã
2. ãããåŠçäžã®åäœæéãããã®åŠçæžã¿ãªããžã§ã¯ãã®æ°ã®å¢å ã
ãã©ã³ã¶ã¯ã·ã§ã³ã®ãããåŠçãé²è¡äžã®å Žåãããã±ãŒãžã®1ã€ã®ãªããžã§ã¯ãã®åŠçæéãççž®ããå¿ èŠããããŸãã
ãªã¢ã¯ãã£ãã¢ãããŒãã®é·æïŒ
â ããŸããŸãªããŒã«ãšãã¯ããã¯ãããªã¢ã¯ãã£ãã¢ãããŒãã®äž»ãªå©ç¹ã§ãã
ç£èŠããŒã«ã䜿çšããŠãåé¡ãäœã§ããããçŽæ¥ç解ã§ããŸããCPUãã¹ã¬ãããã¡ã¢ãªãäžè¶³ããŠãããããã£ã¹ã¯ã·ã¹ãã ãã¹ãªããããŠãããããã°ã®åŠçãé ãã§ãã OracleããŒã¿ããŒã¹ã®çŸåšã®ããã©ãŒãã³ã¹ã®åé¡ã調æ»ããããã®å€ãã®ããŒã«ãšãã¯ããã¯ããããŸãã
â æãŸããå¿çæéã¯ãã1ã€ã®ãã©ã¹ã§ãã
ãã®ãããªäœæ¥ã®éçšã§ãç¶æ³ã蚱容å¯èœãªå¿çæéã«ããŸããã€ãŸããç¶æ³ãæå°å€ã«ãŸã§äœäžãããããšããŸããããç¹å®ã®å€ã«å°éãããã®ã¢ã¯ã·ã§ã³ã®åŸã蚱容é床ã«å°éãããšèãããããããçµäºããŸãã
ãªã¢ã¯ãã£ãã¢ãããŒãã®çæïŒ
- ããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã¯æ®ããŸããããã¯ãæ ¹æ¬çãªåå ã«åžžã«å°éã§ãããšã¯éããªããããäºåŸå¯Ÿå¿åã¢ãããŒãã®æ倧ã®ãã€ãã¹ã§ãã ç§ãã¡ã蚱容ã§ããããã©ãŒãã³ã¹ã«å°éãããšããäºå®ã«ããããããã圌女ã¯ã©ããé¢ãããšããã«ãšã©ãŸããã©ããã«æ·±ã暪ããã£ãŠãããããããŸããã
ããã©ãŒãã³ã¹ã€ã³ã·ãã³ãããŸã çºçããŠããªãå Žåã®å¯ŸåŠæ¹æ³ã¯ïŒ ãã®ãããªç¶æ³ãé²ãããã«ãã©ã®ããã«ããã¢ã¯ãã£ããªæé©åãå®è¡ã§ããããå®åŒåããŠã¿ãŸãããã
ããã¢ã¯ãã£ããªæé©å
æåã«ééããããšã¯ãäœãæé©åããå¿ èŠãããããããããªããšããããšã§ãã ããããããŠãã ãããç§ã¯äœãç¥ããŸãããã
- å€å žçãªã¢ã«ãŽãªãºã ã¯ãããŸããã
- åé¡ã¯ãŸã çºçããŠãããïŒäžæïŒãã©ãã«ããããæšæž¬ããããšããã§ããŸããã
- ã·ã¹ãã å ã®æœåšçãªåŒ±ç¹ãèŠã€ããå¿ èŠããããŸãã
- ãããã®å Žæã§ã¯ãšãªã®ããã©ãŒãã³ã¹ãæé©åããŠãã ããã
ããã¢ã¯ãã£ããªæé©åã®äž»ãªç®æš
ããã¢ã¯ãã£ããªæé©åã®äž»ãªã¿ã¹ã¯ã¯ããªã¢ã¯ãã£ããªæé©åã®ã¿ã¹ã¯ãšã¯ç°ãªãã次ã®ãšããã§ãã
- ããŒã¿ããŒã¹ã®ããã«ããã¯ãåãé€ãã
- ããŒã¿ããŒã¹ã®ãªãœãŒã¹æ¶è²»ã®æžå°ã
æåŸã®ç¬éãæãåºæ¬çã§ãã ãªã¢ã¯ãã£ãæé©åã®å ŽåããªãœãŒã¹æ¶è²»å šäœãåæžããã¿ã¹ã¯ã¯ãããŸããããæ©èœã®å¿çæéã蚱容ç¯å²å ã«ããã¿ã¹ã¯ã®ã¿ããããŸãã
ããŒã¿ããŒã¹ã§ããã«ããã¯ãèŠã€ããæ¹æ³
ãã®åé¡ã«ã€ããŠèãå§ãããšãããã«å€ãã®ãµãã¿ã¹ã¯ãçºçããŸãã 以äžãå®è¡ããå¿ èŠããããŸãã
- CPUãã¹ã
- èªã¿åã/ã¬ã³ãŒãã®è² è·ãã¹ãã
- ã¢ã¯ãã£ããªã»ãã·ã§ã³ã®æ°ã«ããã¹ãã¬ã¹ãã¹ãã
- è² è·ãã¹ã...ãªã©
ãã¹ãè€åäœã§ãããã®åé¡ãã·ãã¥ã¬ãŒãããããšãããšããã¹ããµãŒããŒã§çºçããåé¡ã¯æŠéã®ãã®ãšã¯é¢ä¿ããªããšããäºå®ã«ééããå¯èœæ§ããããŸãã ããã«ã¯å€ãã®çç±ããããŸãããã¹ããµãŒããŒã¯é垞匱ããšããäºå®ããå§ãŸããŸãã ãã¹ããµãŒããŒãæŠéãµãŒããŒã®æ£ç¢ºãªã³ããŒã«ããããšãã§ããã°è¯ãã®ã§ããããŠãŒã¶ãŒã¢ã¯ãã£ããã£ãæçµçãªè² è·ã«åœ±é¿ããããŸããŸãªèŠçŽ ãæ£ç¢ºã«åçŸããå¿ èŠããããããè² è·ãåãæ¹æ³ã§åçŸãããããšã¯ä¿èšŒãããŸããã ãã®ç¶æ³ãã·ãã¥ã¬ãŒãããããšãããšãæŠããŠãããã«ãµãŒããŒã§ãŸã£ããåãããšãèµ·ããããšã誰ãä¿èšŒããŸããã
ããã±ãŒã¹ã§æ°ããã¬ãžã¹ããªãå°çããããã«åé¡ãçºçããå Žåãå¥ã®ã±ãŒã¹ã§ã¯ããŠãŒã¶ãŒã倧èŠæš¡ãªãœãŒããè¡ã巚倧ãªã¬ããŒããèµ·åããããã«çºçããå¯èœæ§ããããŸãããã®çµæãã·ã¹ãã ã®é床ãäœäžãå§ããŸããã ã€ãŸããçç±ã¯ç°ãªãå¯èœæ§ããããåžžã«äºæž¬ã§ãããšã¯éããŸããã ãããã£ãŠãã»ãšãã©æåãããã¹ããµãŒããŒã§ããã«ããã¯ãæ€çŽ¢ããè©Šã¿ãæŸæ£ããŸãã ã ç§ãã¡ã¯æŠéãµãŒããŒãšããã«äœãèµ·ãã£ãŠãããã«äŸåããŠããŸããã
ãã®å Žåã®å¯ŸåŠæ¹æ³ ããããäžè¶³ããŠããå¯èœæ§ãæãé«ããªãœãŒã¹ãç解ããŠã¿ãŸãããã
ããŒã¿ããŒã¹ã®ãªãœãŒã¹æ¶è²»ã®åæž
ç§ãã¡ãèªç±ã«äœ¿ããå·¥æ¥å£å°ã«åºã¥ããŠã ãªãœãŒã¹ã®æãé »ç¹ãªäžè¶³ã¯ãã£ã¹ã¯èªã¿åããšCPUã§èŠ³å¯ãããŸã ã ãããã£ãŠããããããããã®é åã®åŒ±ç¹ãæ£ç¢ºã«æ¢ããŸãã
2çªç®ã®éèŠãªè³ªåïŒäœããæ¢ãæ¹æ³ã¯ïŒ
質åã¯éåžžã«éèŠã§ãã Oracle Enterprise Editionã§ã¯Diagnostic Packãªãã·ã§ã³ã䜿çšããŸããã AWRã¬ããŒã ïŒOracleã®ä»ã®ãšãã£ã·ã§ã³ã§ã¯STATSPACKã¬ããŒãã䜿çšã§ããŸã ïŒãšããããŒã«ãèŠã€ãããŸããã PostgreSQLã«ã¯ã¢ããã°ããããŸã-pgstatspackã Andrey Zubkovã®pg_profileã§ã ã ç§ãç解ããŠããããã«ãæåŸã®è£œåãç»å Žããæšå¹Žã ãéçºãéå§ããŸããã MySQLã®å Žåãåæ§ã®ããŒã«ã¯èŠã€ãããŸããã§ããããMySQLã®å°é家ã§ã¯ãããŸããã
ã¢ãããŒãèªäœã¯ãç¹å®ã®çš®é¡ã®ããŒã¿ããŒã¹ã«é¢é£ä»ããããŠããŸããã ã¬ããŒãããã·ã¹ãã è² è·ã«é¢ããæ å ±ãååŸã§ããå Žåã¯ããããã説æããææ³ã䜿çšããŠã ä»»æã®ããŒã¹ã§ããã¢ã¯ãã£ããªæé©åã®äœæ¥ãå®è¡ã§ããŸã ã
äžäœ5ã€ã®æäœã®æé©å
ãã€ã¡ã³ãã»ã³ã¿ãŒRSCOã§éçºããã³äœ¿çšããŠããããã¢ã¯ãã£ããªæé©åãã¯ãããžãŒã¯ã4ã€ã®æ®µéã§æ§æãããŠããŸãã
ã¹ããŒãž1ãAWRã¬ããŒããå¯èœãªéãæ倧æéåãåããŸãã
é±ã®ããŸããŸãªææ¥ã®è² è·ãå¹³ååããã«ã¯ãå¯èœãªéãæ倧ã®æéãå¿ èŠã§ãã ããšãã°ãå é±ã®ã¬ãžã¹ããªã¯ç«ææ¥ã«RBS-Retail Bankã«å°çããåŠçãéå§ãããçµæ¥å¹³åçŽ2ã3åã®è² è·ãããããŸãã ä»ã®æ¥ã«ã¯ãè² è·ã¯ããå°ãªããªããŸãã
ã·ã¹ãã ã«ããã€ãã®ä»æ§ãããããšãããã£ãŠããå Žå-ããæ¥ã«ã¯è² è·ã倧ãããããæ¥ã«ã¯-å°ãªãå Žåããããã®æéã®ã¬ããŒããåå¥ã«åä¿¡ããç¹å®ã®æéééãæé©åããå Žåã¯åå¥ã«äœæ¥ããå¿ èŠããããŸãã ãµãŒããŒã®å šäœçãªç¶æ³ãæé©åããå¿ èŠãããå Žåã¯ããã®æã®å€§ããªã¬ããŒããååŸããŠããµãŒããŒã®ãªãœãŒã¹ãå®éã«æ¶è²»ããŠãããã®ã確èªã§ããŸãã
æã«ã¯éåžžã«äºæããªãç¶æ³ãçºçããŸãã ããšãã°ãCFT Bankã®å Žåãã¬ããŒããµãŒããŒãã¥ãŒããã§ãã¯ããèŠæ±ã¯äžäœ10ã«ããå¯èœæ§ããããŸãã ããã«ããã®ãªã¯ãšã¹ãã¯å ¬åŒã§ãããããžãã¹ããžãã¯ãå®è¡ããŸããããå®è¡ã«é¢ããã¬ããŒãããããã©ããã®ã¿ããã§ãã¯ããŸãã
ã¹ããŒãž2.ã»ã¯ã·ã§ã³ãèŠãŸãïŒ
- çµéæéã§äžŠã¹æ¿ããããSQL-å®è¡æéã§äžŠã¹æ¿ããããSQLã¯ãšãªã
- CPUæéé ã«äžŠã¹ãããSQL-CPU䜿çšçã
- Getsã§é åºä»ããããSQL-è«çèªã¿åãå€ã
- èªã¿åãé ã«äžŠã¹ãããSQL-ç©ççãªèªã¿åãçšã
SQLã®æ®ãã®ã»ã¯ã·ã§ã³ã¯ãå¿ èŠã«å¿ããŠèª¿æ»ãããŸãã
ã¹ããŒãž3.芪æäœãšããã«äŸåããèŠæ±ã決å®ããŸãã
AWRã¬ããŒãã«ã¯åå¥ã®ã»ã¯ã·ã§ã³ããããOracleã®ããŒãžã§ã³ã«å¿ããŠããããã®åã»ã¯ã·ã§ã³ã«15以äžã®äžäœã¯ãšãªã衚瀺ãããŸãã ããããAWRã¬ããŒãã®ãããã®ã¯ãšãªOracleã¯æ··ä¹±ã瀺ããŠããŸãã
ããšãã°ã芪æäœãããããã®äžã«3ã€ã®äžäœã¯ãšãªãããå ŽåããããŸãã AWRã¬ããŒãã®Oracleã¯ã芪æäœãšããã3ã€ã®ã¯ãšãªã®äž¡æ¹ã衚瀺ããŸãã ãããã£ãŠããã®ãªã¹ããåæããç¹å®ã®èŠæ±ãåç §ããæäœã確èªããŠãã°ã«ãŒãåããå¿ èŠããããŸãã
ã¹ããŒãž4ãäžäœ5ã€ã®ãªãã¬ãŒã·ã§ã³ãæé©åããŸãã
ãã®ãããªã°ã«ãŒãåã®åŸãåºåã¯æãé£ããæäœãéžæã§ããæäœã®ãªã¹ãã«ãªããŸãã 5ã€ã®æäœã«å¶éãããŠããŸãïŒèŠæ±ãã€ãŸãæäœã§ã¯ãããŸããïŒã ã·ã¹ãã ãããè€éãªå Žåã¯ãããã«å€ããåãããšãã§ããŸãã
äžè¬çãªã¯ãšãªèšèšãšã©ãŒ
ãã®ææ³ã®é©çšäžã«ãå žåçãªèšèšãšã©ãŒã®å°ããªãªã¹ãããŸãšããŸããã ããã€ãã®ãšã©ãŒã¯éåžžã«åçŽã§ãããããããã§ã¯ãªãããã§ãã
â ã€ã³ããã¯ã¹ã®æ¬ åŠâãã«ã¹ãã£ã³
ããšãã°ãæŠéã¹ããŒã ã«é¢ããã€ã³ããã¯ã¹ããªããªã©ãéåžžã«å¶çºçãªã±ãŒã¹ããããŸãã ã€ã³ããã¯ã¹ãªãã§é·æéã®ã¯ãšãªãè¿ éã«æ©èœããç¹å®ã®äŸããããŸããã ãããããã«ã¹ãã£ã³ãè¡ãããããŒãã«ãµã€ãºãåŸã ã«å€§ãããªãã«ã€ããŠãã¯ãšãªã®åäœãé ããªããååæããšã«å°ãæéãããããŸããã çµå±ãç§ãã¡ã¯åœŒã«æ³šæãæããŸããããã€ã³ããã¯ã¹ãããã«ãªãããšãããããŸããã
â 倧èŠæš¡ãªéžæâãã«ã¹ãã£ã³
2çªç®ã®ããããééãã¯ã倧éã®ããŒã¿ãµã³ãã«-ãã«ã¹ãã£ã³ã®å žåçãªã±ãŒã¹ã§ãã ãã«ã¹ãã£ã³ã¯ãæ£åœãªçç±ãããå Žåã«ã®ã¿äœ¿çšããå¿ èŠãããããšã誰ããç¥ã£ãŠããŸãã ããšãã°ããã£ã«ã¿ãªã³ã°æ¡ä»¶ãpl / sqlã³ãŒãããã¯ãšãªã«è»¢éããå Žåãªã©ããã«ã¹ãã£ã³ãå®è¡ã§ããªãå ŽåããããŸãã
â ç¡å¹ãªã€ã³ããã¯ã¹âãã³ã°ã€ã³ããã¯ã¹ã¬ã³ãžã¹ãã£ã³
ãã¶ãããã¯æãäžè¬çãªééãã§ããäœããã®çç±ã§ã圌ãã¯éåžžã«å°ãªããšèšã£ãŠããŸã-ããããéå¹ççãªã€ã³ããã¯ã¹ïŒé·ãã€ã³ããã¯ã¹ã¹ãã£ã³ãé·ãã€ã³ããã¯ã¹ç¯å²ã¹ãã£ã³ïŒã ããšãã°ãã¬ãžââã¹ããªçšã®ããŒãã«ããããŸãã èŠæ±ã§ã¯ããã®ãšãŒãžã§ã³ãã®ãã¹ãŠã®ã¬ãžã¹ããªãæ€çŽ¢ããæçµçã«ãããšãã°ç¹å®ã®æéãç¹å®ã®çªå·ãç¹å®ã®ã¯ã©ã€ã¢ã³ããªã©ã®ãã£ã«ã¿ãŒæ¡ä»¶ãè¿œå ããããšããŸãã ãã®ãããªç¶æ³ã§ã¯ãã€ã³ããã¯ã¹ã¯éåžžã䜿çšã®æ®éæ§ã®çç±ããããšãŒãžã§ã³ãããã£ãŒã«ãã«ã®ã¿æ§ç¯ãããŸãã çµæã¯æ¬¡ã®å³ã«ãªããŸããããšãã°ãäœæ¥ã®æåã®å¹Žã«ã¯ããšãŒãžã§ã³ãã¯ãã®ããŒãã«ã«100åã®ãšã³ããªãæã¡ãæ¥å¹Žã¯ãã§ã«1,000åãå¥ã®å¹Žã«ã¯10,000åã®ãšã³ããªããããŸãã æéãçµã€ãšããããã®ã¬ã³ãŒãã¯100,000ã«ãªããŸãããªã¯ãšã¹ãã§ã¯ããšãŒãžã§ã³ãèå¥åã ãã§ãªãããã®å Žåã¯æ¥ä»ã«ããè¿œå ã®ãã£ã«ã¿ãŒãè¿œå ããå¿ èŠãããããããªã¯ãšã¹ãã®åäœãé ããªãããšã¯æããã§ãã ããããªããšããã®ãšãŒãžã§ã³ãã®ã¬ãžã¹ããªã®æ°ãå¢ããŠããããããµã³ãã«ãµã€ãºã幎ã å¢å ããããšãããããŸãã ãã®åé¡ã¯ã€ã³ããã¯ã¹ã¬ãã«ã§å¯ŸåŠããå¿ èŠããããŸãã ããŒã¿ãå€ãããå Žåã¯ãããŒãã£ã·ã§ã³åå²ã®æ¹åããã§ã«èããŠããå¿ èŠããããŸãã
â äžèŠãªé åžã³ãŒããã©ã³ã
ããã奜å¥å¿isçãªã±ãŒã¹ã§ãããããã«ãããããããèµ·ãããŸãã äžäœã®ã¯ãšãªãèŠããšãå¥åŠãªã¯ãšãªãããã€ããããŸãã ç§ãã¡ã¯éçºè ã®ãšããã«æ¥ãŠããç§ãã¡ã¯ããã€ãã®ãªã¯ãšã¹ããèŠã€ããŸããããããç解ããããã«ã€ããŠäœãã§ãããèŠãŠã¿ãŸããããã éçºè ã¯èãããã°ããããŠãã次ã®ããã«èšããŸããããã®ã³ãŒãã®ãã©ã³ãã¯ã·ã¹ãã äžã«ããã¹ãã§ã¯ãããŸããã ãã®æ©èœã¯äœ¿çšããŸãããã 次ã«ãéçºè ã¯ãã³ãŒãã®ãã®ã»ã¯ã·ã§ã³ãåé¿ããããã«ãç¹å¥ãªèšå®ããªã³ã«ããããšããå§ãããŸãã
ã±ãŒã¹ã¹ã¿ãã£
ããã§ãå®éã®å®è·µãã2ã€ã®äŸãæ€èšããŸãã äžäœã®ã¯ãšãªãåŠçããå Žåããã¡ããããŸãæåã«ãè€éã§æäœãéåžžã«å€§ãããèªæã§ã¯ãªãäœããããã¯ãã§ãããšããäºå®ã«ã€ããŠèããŸãã å®éãããã¯åžžã«ããã§ã¯ãããŸããã éåžžã«åçŽãªã¯ãšãªãäžäœã®æäœã«è©²åœããå ŽåããããŸãã
äŸ1
select * from (select o.* from rnko_dep_reestr_in_oper o where o.type_oper = 'proc' and o.ean_rnko in (select l.ean_rnko from rnko_dep_link l where l.s_rnko = :1) order by o.date_oper_bnk desc, o.date_reg desc) where ROWNUM = 1
ãã®äŸã§ã¯ãã¯ãšãªã¯2ã€ã®ããŒãã«ã®ã¿ã§æ§æãããŠããããããã¯éãããŒãã«ã§ã¯ãªãããããæ°çŸäžã®ã¬ã³ãŒãã§ãã ããã¯ç°¡åã«æããŸããïŒ ãã ãããªã¯ãšã¹ãã¯ãããã«ãããããŸãã
圌ã®äœãæªãã®ããèããŠã¿ãŸãããã
以äžã¯ãEnterprise Manager Cloud Controlã®åçã§ãããã®ãªã¯ãšã¹ãã®çµ±èšã«é¢ããããŒã¿ã§ãïŒOracleã«ã¯ãã®ãããªããŒã«ããããŸãïŒã ãã®ãªã¯ãšã¹ãã«ã¯éåžžã®è² è·ãããããšãããããŸãïŒäžã®ã°ã©ãïŒã 暪ã®æ°å1ã¯ãå¹³åããŠ1ã€ã®ã»ãã·ã§ã³ã®ã¿ãå®è¡ãããŠããããšã瀺ããŸãã ç·ã®å³ã¯ã ãªã¯ãšã¹ããCPUã®ã¿ã䜿çšããŠããããšã瀺ããŠããŸãã

ããã§äœãèµ·ãã£ãŠããã®ããç解ããŠã¿ãŸããããïŒ

äžã®è¡šã¯ããªã¯ãšã¹ãã«é¢ããçµ±èšãå«ãè¡šã§ãã ã»ãŒ70äžåã®æã¡äžã-ããã¯èª°ãé©ããªãã§ãããã ãã ãã12æ15æ¥ã®æåã®èªã¿èŸŒã¿æéãã12æ22æ¥ã®æåŸã®èªã¿èŸŒã¿æéãŸã§ã®æéééïŒåã®å³ãåç §ïŒã¯1é±éã§ãã 1ç§ãããã®éå§åæ°ãæ°ãããšã ã¯ãšãªã¯1ç§ããšã«å¹³åããŠå®è¡ãããããšãããããŸã ã
ããã«èª¿ã¹ãŸãã ã¯ãšãªã®å®è¡æéã¯0.93ç§ã§ãã 1ç§æªæºãããã¯çŽ æŽãããããšã§ãã ç§ãã¡ã¯åã¶ããšãã§ããŸã-èŠæ±ã¯éããã®ã§ã¯ãããŸããã ããã«ããããããã圌ã¯ããããå©ããŸãããã€ãŸãã圌ã¯å€ãã®ãªãœãŒã¹ãæ¶è²»ããŸãã ã©ãã§å€ãã®ãªãœãŒã¹ãæ¶è²»ããŸããïŒ
ããŒãã«ã«ã¯ãè«çèªã¿åãçšã®è¡ããããŸãã 1åã®èµ·åã«ã¯çŽ8,000ãããã¯ãå¿ èŠã§ããããšãããããŸãïŒéåžžã1ãããã¯ã¯8 KBã§ãïŒã 1ç§ã«1ååäœãããªã¯ãšã¹ãã¯ãã¡ã¢ãªããçŽ64 MBã®ããŒã¿ãããŒãããããšãããããŸããã ããã§äœããééã£ãŠããŸããç解ããå¿ èŠããããŸãã
èšç»ãèŠãŠã¿ãŸãããïŒãã«ã¹ãã£ã³ããããŸãã ããã§ã¯å ã«é²ã¿ãŸãããã
Plan hash value: 634977963 ------------------------------------------------------------------- | Id | Operation | Name | ------------------------------------------------------------------- | 0 | SELECT STATEMENT | | |* 1 | COUNT STOPKEY | | | 2 | VIEW | | |* 3 | SORT ORDER BY STOPKEY | | | 4 | NESTED LOOPS | | | 5 | TABLE ACCESS BY INDEX ROWID| RNKO_DEP_LINK | |* 6 | INDEX UNIQUE SCAN | UK_RNKODEPLINK$S_RNKO | |* 7 | TABLE ACCESS FULL | RNKO_DEP_REESTR_IN_OPER | ------------------------------------------------------------------- Predicate Information (identified by operation id): 1 - filter(ROWNUM=1) 3 - filter(ROWNUM=1) 6 - access("L"."S_RNKO"=:1) 7 - filter(("O"."TYPE_OPER"='proc' AND "O"."EAN_RNKO"="L"."EAN_RNKO"))
rnko_dep_reestr_in_operããŒãã«ã«ã¯500äžè¡ãããªããè¡ã®å¹³åã®é·ãã¯150ãã€ãã§ãã ããããæ¥ç¶ããŠãããã£ãŒã«ãã«ååãªã€ã³ããã¯ã¹ããªãããšãå€æããŸããããµãã¯ãšãªã¯ãean_rnkoãã£ãŒã«ããä»ããŠãªã¯ãšã¹ãã«æ¥ç¶ãããŠããŸãã
ããã«ãããšã圌ãçŸããŠããå®éã«ã¯ç¶æ³ã¯ããŸãè¯ããããŸããã ãã®é·ãã€ã³ããã¯ã¹ã¹ãã£ã³ïŒé·ãINDEX RANGE SCANïŒãçºçããŸãã ean_rnkoã¯ããšãŒãžã§ã³ãã®å éšèå¥åã§ãã ãšãŒãžã§ã³ãã®ã¬ãžã¹ããªã¯èç©ããããã®ãªã¯ãšã¹ããéžæããããŒã¿ã®éã¯æ¯å¹Žå¢å ãããªã¯ãšã¹ãã¯é ããªããŸãã
解決çïŒ ean_rnkoããã³date_regãã£ãŒã«ãã®ã€ã³ããã¯ã¹ãäœæãããã®ãªã¯ãšã¹ãã§æ¥ä»ããšã«ã¹ãã£ã³ã®æ·±ããå¶éããããã«éçºè ã«äŸé ŒããŸãã ãã®åŸãå°ãªããšãããçšåºŠãã¯ãšãªã®ããã©ãŒãã³ã¹ãã»ãŒåãå¢çã«ãšã©ãŸãããšãä¿èšŒã§ããŸããããã¯ããµã³ãã«ãµã€ãºãäžå®ã®æéééã«å¶éãããããŒãã«å šäœãèªã¿åãå¿ èŠããªãããã§ãã ããã¯éåžžã«éèŠãªãã€ã³ãã§ããäœãèµ·ãã£ãã®ãèŠãŠãã ããã

æé©ååŸãåäœæéã¯100åã®1ç§æªæºïŒ0.93ã§ããïŒã«ãªãããããã¯æ°ã¯å¹³åã§8.5ã«ãªããŸãã-ããã¯ä»¥åã®1000åã®1ã«ãªããŸããã
äŸ2
select count(1) from loy$barcodes t where t.id_processing = :b1 and t.id_rec_out is null and not t.barcode is null and t.status = 'u' and not t.id_card is null
éåžžãã¯ãšãªãããã«ã¯è€éãªãã®ãäºæ³ããããšãã話ãã話ãå§ããŸããã äžèšã¯ã1ã€ã®ããŒãã«ã«ç§»åãããè€éãªãã¯ãšãªã®äŸã§ãïŒïŒïŒããŸããäžäœã®ã¯ãšãªã«ãå ¥ããŸãã:) ID_PROCESSINGãã£ãŒã«ãã«ã€ã³ããã¯ã¹ããããŸãã
ãã®ã¯ãšãªã«ã¯IS NULLæ¡ä»¶ã3ã€ããããåãã®ãšããããã®ãããªæ¡ä»¶ã«ã¯ã€ã³ããã¯ã¹ãä»ããããŠããŸããïŒãã®å Žåã¯ã€ã³ããã¯ã¹ã䜿çšã§ããŸããïŒã ããã«ãïŒID_PROCESSINGããã³STATUSã«ããïŒç䟡ã¿ã€ãã®æ¡ä»¶ã¯2ã€ãããããŸããã
ããããããã®ã¯ãšãªãèŠãéçºè ã¯ããŸãID_PROCESSINGãšSTATUSã«ã€ã³ããã¯ã¹ãäœæããããšããå§ãããŸãã ããããéžæãããããŒã¿ã®éïŒå€ãã®ããŒã¿ãããïŒãèãããšããã®ãœãªã¥ãŒã·ã§ã³ã¯æ©èœããŸããã
ãã ãããªã¯ãšã¹ãã¯å€ãã®ãªãœãŒã¹ãæ¶è²»ããŸããã€ãŸããåäœãéãããã«ã¯äœããããå¿ èŠããããŸãã çç±ãç解ããŠã¿ãŸãããã

äžèšã®çµ±èšã¯1æ¥éã®ãã®ã§ããã5åããšã«ãªã¯ãšã¹ããéå§ãããããšãããããŸãã äž»ãªãªãœãŒã¹æ¶è²»ã¯ãCPUãšãã£ã¹ã¯ã®èªã¿åãã§ãã ã¯ãšãªã®éå§æ°ã®çµ±èšã瀺ãã°ã©ãã®äžã§ã¯ããã¹ãŠãé 調ã§ããããšãããããŸã-éå§æ°ã¯æéãšãšãã«ã»ãšãã©å€åããŸãã-ããªãå®å®ããç¶æ³ã§ãã

ããã«è©³ããèŠããšãã¯ãšãªã®å®è¡æéãéåžžã«å€§ããå€åããããšããããŸã-æ°åãããã¯ãã§ã«éèŠã§ãã

次ã«èããŠã¿ãŸãããã
Oracle Enterprise Managerã«ã¯SQLç£èŠãŠãŒãã£ãªãã£ããããŸãã ãã®ãŠãŒãã£ãªãã£ã䜿çšãããšããªã¯ãšã¹ãã«ãããªãœãŒã¹ã®æ¶è²»ããªã¢ã«ã¿ã€ã ã§ç¢ºèªã§ããŸãã

äžèšã¯åé¡ã®ãããªã¯ãšã¹ãã®ã¬ããŒãã§ãã ãŸãã[å®éã®è¡]åã®INDEX RANGE SCANïŒäžã®è¡ïŒã1700äžè¡ã瀺ããŠããããšã«æ³šç®ããŠãã ããã ããããæ€èšãã䟡å€ããããŸãã
å®è£ èšç»ãããã«èŠããšãèšç»ã®æ¬¡ã®é ç®ã®åŸããããã®1700äžè¡ã®ãã¡ã1705ã ããæ®ã£ãŠããããšãããããŸãã æçµãµã³ãã«ã§ã¯ãââçŽ0.01ïŒ ãæ®ã£ãŠããŸããã€ãŸããæããã«éå¹ççã§ãäžèŠãªäœæ¥ãè¡ãããŸãã ã ããã«ããã®äœæ¥ã¯5åããšã«è¡ãããŸãã ããã«åé¡ããããŸãïŒ ãããã£ãŠããã®ãªã¯ãšã¹ãã¯äžäœã¯ãšãªã«ãããããŸãã
ãã®éèŠãªåé¡ã解決ããŠã¿ãŸãããã ããããããèªäœãè«ãã€ã³ããã¯ã¹ã¯éå¹ççã§ãããããããªãããŒãªäœããèãåºããIS NULLã®æ¡ä»¶ãç Žãå¿ èŠããããŸãã
æ°ããã€ã³ããã¯ã¹
éçºè ãšçžè«ããèããŠããã®æ±ºå®ã«è³ããŸãããID_PROCESSINGåãå«ãŸããæ©èœã€ã³ããã¯ã¹ãäœæããŸãããããã¯ããªã¯ãšã¹ãã«åçã®æ¡ä»¶ããããä»ã®ãã¹ãŠã®ãã£ãŒã«ãããã®é¢æ°ã®åŒæ°ãšããŠå«ããŸããã
create index gc.loy$barcod_unload_i on gc.loy$barcodes (gc.loy_barcodes_ic_unload(id_rec_out, barcode, id_card, status), id_processing); function loy_barcodes_ic_unload( pIdRecOut in loy$barcodes.id_rec_out%type, pBarcode in loy$barcodes.barcode%type, pIdCard in loy$barcodes.id_card%type, pStatus in loy$barcodes.status%type) return varchar2 deterministic is vRes varchar2(1) := ''; begin if pIdRecOut is null and pBarcode is not null and pIdCard is not null and pStatus = 'U' then vRes := pStatus; end if; return vRes; end loy_barcodes_ic_unload;
ãã®é¢æ°ã®ã¿ã€ãã¯æ±ºå®è«çã§ããã€ãŸããåããã©ã¡ãŒã¿ãŒã»ããã«å¯ŸããŠåžžã«åãçããè¿ããŸãã ãã®é¢æ°ã¯åžžã«1ã€ã®å€ããã®å Žåã¯ãUããåžžã«è¿ãããã«ããŸããã ãããã®ãã¹ãŠã®æ¡ä»¶ãæºãããããšãæºããããªãå Žåã¯ãUããçºè¡ãããŸã-NULLã ãã®ãããªæ©èœã€ã³ããã¯ã¹ã«ãããããŒã¿ãå¹æçã«ãã£ã«ã¿ãªã³ã°ã§ããŸãã
ãã®ã€ã³ããã¯ã¹ãé©çšãããšã次ã®çµæãåŸãããŸããã

ããã§ã¯ã1ã€ã®åã1ã€ã®ã¹ãããã·ã§ããã§ãããããŒã¿ããŒã¹ã®30åããšã«è¡ãããŸãã ç§ãã¡ã¯ç®æšãéæãããã®ææšã¯æ¬åœã«å¹æçã§ãã å®éçãªç¹æ§ãèŠãŠã¿ãŸãããã
å¹³åãªã¯ãšã¹ãçµ±èš
| ||
åã«
| åŸ
| |
çµéæéãç§
| 143.21
| 60.7
|
CPUæéãç§
| 33.23
| 45.38
|
ãããã¡ååŸãããã¯
| 6`288`237.67
| 1`589`836
|
ãã£ã¹ã¯èªã¿åããããã¯
| 266`600.33
| 2`680
|
åäœæéã¯2.5åæžå°ãããªãœãŒã¹ã®æ¶è²»ïŒãããã¡ååŸïŒ-çŽ4æžå°ããŸããããã£ã¹ã¯ããèªã¿åãããããŒã¿ãããã¯ã®æ°ã¯éåžžã«å€§å¹ ã«æžå°ããŸããã
ç©æ¥µçãªæé©åã®çµæ
ç§éã¯åãåã£ãïŒ
- ããŒã¿ããŒã¹ã®è² è·ã軜æžããŸãã
- ããŒã¿ããŒã¹ã®å®å®æ§ãåäžãããŸãã
- ãœãããŠã§ã¢ããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã®æ°ã®å€§å¹ ãªåæžã
ããã©ãŒãã³ã¹ã€ã³ã·ãã³ãã¯10åæžå°ããŸãã ã ããã¯äž»èŠ³çãªéã§ããã以åã¯ãRBS-Retail Bankã®è€åæœèšã§æã«1ã2åçºçããŠããŸããããä»ã§ã¯äºå®äžå¿ããŠããŸããã
ããã«ããåé¡ãçºçããŸãããœãããŠã§ã¢ããã©ãŒãã³ã¹ã®åé¡ã¯ã©ãã§ããããã ç§ãã¡ã¯ãããã«çŽæ¥å¯ŸåŠããŸããã§ãããïŒ
æåŸã®ã¹ã±ãžã¥ãŒã«ã«æ»ããŸãã èŠããŠããã°ããã«ã¹ãã£ã³ãè¡ãããã¡ã¢ãªã«å€æ°ã®ãããã¯ãä¿åããå¿ èŠããããŸããã èŠæ±ã¯å®æçã«å®è¡ãããããããããã®ãããã¯ã¯ãã¹ãŠOracleãã£ãã·ã¥ã«æ ŒçŽãããŠããŸããã çŸæç¹ã§ããŒã¿ããŒã¹ã§é«è² è·ãçºçããå Žåãããšãã°èª°ããç©æ¥µçã«ã¡ã¢ãªã䜿çšãå§ããå ŽåãããŒã¿ãããã¯ãä¿åããããã«ãã£ãã·ã¥ãå¿ èŠã«ãªãããšãããããŸãã ãããã£ãŠããªã¯ãšã¹ãã®ããŒã¿ã®äžéšã¯æ··ã¿åã£ãŠããŸããŸããã€ãŸããç©ççãªèªã¿åããè¡ãå¿ èŠããããŸãã ç©ççãªèªã¿åããè¡ããšãã¯ãšãªã®å®è¡æéã¯ããã«å€§å¹ ã«å¢å ããŸãã
è«çèªã¿åãã¯ã¡ã¢ãªã䜿çšããŠåäœããŠãããããé«éã§çºçãããã£ã¹ã¯ãžã®ã¢ã¯ã»ã¹ã¯é ããªããŸãïŒæéãããªç§ãèŠããšïŒã éãããããªãã¬ãŒãã£ã³ã°ã·ã¹ãã ã®ãã£ãã·ã¥ãŸãã¯ã¢ã¬ã€ãã£ãã·ã¥ã«ãã®ããŒã¿ãããå Žåãããã¯ãŸã æ°åãã€ã¯ãç§ã«ãªããŸãã Oracleã®ãã£ãã·ã¥ããã®èªã¿åãã¯ã¯ããã«é«éã§ãã
ãã«ã¹ãã£ã³ãåé€ãããšããã®ãããªå€æ°ã®ãããã¯ããã£ãã·ã¥ïŒãããã¡ãŒãã£ãã·ã¥ïŒã«ä¿åããå¿ èŠããªããªããŸããã ãããã®ãªãœãŒã¹ãäžè¶³ããŠããå Žåããªã¯ãšã¹ãã¯å€å°å®å®ããŠããŸãã å€ãã€ã³ããã¯ã¹ã®ãããªå€§ããªãµãŒãžã¯ãããããŸããã
ããã¢ã¯ãã£ããªæé©åã®æŠèŠïŒ
- ã¯ãšãªãšãã®ããžãã¹ããžãã¯ãã©ã®ããã«æ©èœãããã確èªããããã«ããã¹ããµãŒããŒã§æåã®ã¯ãšãªæé©åãå®è¡ããäœåãªæäœãè¡ããªãããã«ããŸãã ãããã®äœåã¯æ®ã£ãŠããŸãã
- ãã ããå®æçã«ãæ°ãæã«1åããµãŒããŒããå šè² è·ã«é¢ããã¬ããŒããåé€ããããŒã¿ããŒã¹å ã®äžäœã®ã¯ãšãªãšæäœãæ€çŽ¢ããŠæé©åããããšã¯çã«ããªã£ãŠããŸãã
OracleããŒã¿ããŒã¹ã§çµ±èšãååŸããããã®å€ãã®ããŒã«ããããŸãã
- AWRã¬ããŒãïŒDBMS_WORKLOAD_REPOSITORY.awr_report_htmlïŒ;
- Enterprise Manager Cloud Control 12cïŒSQLã®è©³çŽ°ïŒ;
- SQL詳现ã¢ã¯ãã£ãã¬ããŒãïŒDBMS_PERF.report_sqlïŒ;
- SQLç£èŠïŒEMCCã®ã¿ãïŒ;
- SQLç£èŠã¬ããŒãïŒDBMS_SQLTUNE.report_sql_monitor *ïŒã
ãããã®ããŒã«ã®äžéšã¯ã³ã³ãœãŒã«ã§æ©èœããŸããã€ãŸããEnterprise Managerã«é¢é£ä»ããããŠããŸããã
çµ±èšãåéããããã®OracleããŒã«ã®äŸ
SQL-Monitoringã¯ããã¹ãŠããªã¢ã«ã¿ã€ã ã§ã©ã®ããã«èŠãããã瀺ããŸãïŒç·è²ã®æ¯è»ãå転ããŠããå Žåãã¯ãšãªã¯çŸåšåäœããŠããŸãïŒã
äžèšã¯ãSQLç£èŠã¬ããŒãã®å éšã³ã³ãã³ãã§ãã ãªã¢ã«ã¿ã€ã ã§ãå®è¡ããã¯ãšãªè¡ãšèªã¿åãè¡æ°ã衚瀺ãããŸãïŒ[å®éã®è¡]åïŒã ãã®å ŽåãINDEX RANGE SCANã¯ãã§ã«500äžãã«ãŠã³ãããŠããŸãã
ããã¹ãç£èŠããŒã«SQLç£èŠã¬ããŒããäžéšã®æ å ±ïŒãã¹ãŠã§ã¯ãªãïŒããããŸãã

- äžã®ã°ã©ãã¯ããã®ãªã¯ãšã¹ãã§åäœããã»ãã·ã§ã³ã®æ°ã瀺ããŠããŸãã
- å·Šã®ãããã¯ã¯ããã®ãªã¯ãšã¹ããã©ãããèµ·åãããã©ã®ã¢ãžã¥ãŒã«ã«ãããã瀺ããŠããŸãã
- å·Šäž-å ±æããŒã«ã®äœ¿çšã«é¢ããæ å ±ã
- å³åŽã®å³ã¯ãã·ã¹ãã å ã®åŸ æ©ã€ãã³ãã瀺ããŠããŸãã ãã®å ŽåãCPUã®ã¿ã§ãã
- å³äž-æãèå³æ·±ã-ããã©ãŒãã³ã¹ã®åé¡ãåæãããšãã«æãéèŠãªå質ç¹æ§ãåãããã¬ãŒãã

SQL-Monitoringã¯ããã¹ãŠããªã¢ã«ã¿ã€ã ã§ã©ã®ããã«èŠãããã瀺ããŸãïŒç·è²ã®æ¯è»ãå転ããŠããå Žåãã¯ãšãªã¯çŸåšåäœããŠããŸãïŒã

äžèšã¯ãSQLç£èŠã¬ããŒãã®å éšã³ã³ãã³ãã§ãã ãªã¢ã«ã¿ã€ã ã§ãå®è¡ããã¯ãšãªè¡ãšèªã¿åãè¡æ°ã衚瀺ãããŸãïŒ[å®éã®è¡]åïŒã ãã®å ŽåãINDEX RANGE SCANã¯ãã§ã«500äžãã«ãŠã³ãããŠããŸãã

ããã¹ãç£èŠããŒã«SQLç£èŠã¬ããŒããäžéšã®æ å ±ïŒãã¹ãŠã§ã¯ãªãïŒããããŸãã

ããŒãã¹ïŒ RNCOããã€ã¡ã³ãã»ã³ã¿ãŒãããã³CFT ã®å°é家ã¯ãããã·ãã«ã¹ã¯ã§ã®äŒè°ã®æºåãæŽã£ãŠãããããã€ãã®æçšãªã¬ããŒããäœæããå®éã®åºå£ã©ãžãªãç·šæããŸããã 2æ¥éãå°é家ãè¬æŒè ãäž»å¬è ãCFTã©ãžãªã蚪ããŸããã ãšã³ããªãå«ããããšã§ãã·ããªã¢ã®å€ã«æ»ãããšãã§ããŸãããããã¯ãžã®ãªã³ã¯ã¯æ¬¡ã®ãšããã§ããKubernetesïŒé·æãšçæ ã ããŒã¿ãµã€ãšã³ã¹ãšæ©æ¢°åŠç¿ DevOps
æ¢ã«11æ8æ¥ãš9æ¥ã§ããã¢ã¹ã¯ã¯ã®HighLoad ++ã§ã¯ãããã«èå³æ·±ãããšããããŸãã ãã®ããã°ã©ã ã«ã¯ãå°é家ã®ã¢ããã€ã¹ãå ±æããé©ãã®äœããèŠã€ããããŒãããŒããã®ãè² è·ã®é«ããããžã§ã¯ãããã¹ã¿ãŒã¯ã©ã¹ãäŒè°ãã€ãã³ãã«é¢ããäœæ¥ã®ããããåŽé¢ã«é¢ããã¬ããŒããå«ãŸããŠããŸãã æãèå³æ·±ããã®ã«ã€ããŠæžãã ãã¥ãŒã¹ã¬ã¿ãŒã§ããªãã«éç¥ããŸããæ¥ç¶ããŠãã ããïŒ