±à¼ÍƼö: |
±¾ÎÄÀ´×ÔÓÚcsdn£¬±¾ÎĽéÉÜÁ˽«linuxϵͳµÄ»úÆ÷×÷Ϊ·þÎñÆ÷£¬µ±ÔÚÉÏÃæ´î½¨·þÎñʱ£¬ÈçºÎ¶ÔһЩ³£ÓõÄÐÔÄÜÖ¸±ê½øÐÐ¼à¿Ø¡£ |
|
·þÎñÆ÷¼à¿Ø
Ôڴ·þÎñÆ÷ʱ£¬³ýÁ˲¿ÊðwebappÖ®Í⣬»¹ÐèÒª·þÎñµÄÒì³£ÐÅÏ¢Óë·þÎñÆ÷ÐÔÄÜÖ¸±ê½øÐÐ¼à¿Ø£¬Ò»µ©ÓÐÒì³£Ôò֪ͨ¹ÜÀíÔ±¡£
·þÎñÆ÷ʹÓÃLinux+Nginx-1.9.15+Tomcat7+Java´î½¨µÄ¡£
±àд½Å±¾¼ì²â´íÎóÈÕÖ¾ºÍ·þÎñÆ÷ÐÔÄÜÖ¸±ê£¬Ò»µ©ÐÂÉú´íÎóÈÕÖ¾»òÕßÐÔÄܽµµÍµ½É趨µÄãÐֵʱ£¬ÔòʹÓÃÔÆ¼à¿Ø½«±¨¾¯ÉÏ´«µ½ÔÆÕ˺š£
·þÎñÔËÐÐ¼à¿Ø
´íÎóÈÕÖ¾°üº¬ÒÔÏÂÈý¸ö·½Ã棺
nginx ´íÎóÐÅÏ¢¼à¿Ø(nginx.confÅäÖÃ)
${NGINX_HOME}/logs/error.log
tomcat ´íÎóÐÅÏ¢¼à¿Ø(server.xmlÅäÖÃ)
${TOMCAT_HOME}/logs/catalina.out
webapp´íÎóÐÅÏ¢¼à¿Ø(log4j)
${WEBAPP_HOME}/log/error
»úÆ÷ÐÔÄÜÖ¸±ê
Ò»°ã¶¼»áʹÓÃlinuxϵͳµÄ»úÆ÷×÷Ϊ·þÎñÆ÷£¬ÄÇôµ±ÔÚÉÏÃæ´î½¨·þÎñʱ£¬ÐèÒª¶ÔһЩ³£ÓõÄÐÔÄÜÖ¸±ê½øÐÐ¼à¿Ø£¬ÄÇôһ°ã°üº¬ÄÄЩָ±êÄØ£¿ÏÂÃæ¶ÔÆä½øÐÐһЩ×ܽᣬ»¶Ó²¹³ä¡
Ö¸±ê
1.CPU(Load) CPUʹÓÃÂÊ/¸ºÔØ
2.Memory ÄÚ´æ
3.Disk ´ÅÅ̿ռä
4.Disk I/O ´ÅÅÌI/O
5.Network I/O ÍøÂçI/O
6.Connect Num Á¬½ÓÊý
7.File Handle Num Îļþ¾ä±úÊý
¡
CPU
1.˵Ã÷
»úÆ÷µÄCPUÕ¼ÓÐÂÊÔ½¸ß£¬ËµÃ÷»úÆ÷´¦ÀíԽ棬ÔËËãÐÍÈÎÎñÔ½¶à¡£Ò»¸öÈÎÎñ¿ÉÄܲ»½ö»áÓÐÔËË㲿·Ö£¬»¹»áÓÐI/O(´ÅÅÌI/OÓëÍøÂçI/O)²¿·Ö£¬µ±ÔÚ´¦ÀíI/Oʱ£¬Ê±¼äƬδÍêÆäCPUÒ²»áÊÍ·Å£¬Òò´Ëij¸öʱ¼äµãµÄCPUÕ¼ÓÐÂÊûÓÐÌ«´óµÄÒâÒ壬Òò´ËÐèÒª¼ÆËãÒ»¶Îʱ¼äÄ򵀮½¾ùÖµ£¬ÄÇôƽ¾ù¸ºÔØ(Load
Average)Õâ¸öÖ¸±ê±ãÄÜºÜºÃµÃ¶ÔÆä½øÐбíÕ÷¡£Æ½¾ù¸ºÔØ£ºËüÊǸù¾ÝÒ»¶Îʱ¼äÄÚÕ¼ÓÐCPUµÄ½ø³ÌÊýÄ¿ºÍµÈ´ýCPUµÄ½ø³ÌÊýÄ¿¼ÆËã³öÀ´µÄ£¬ÆäÖеȴýCPUµÄ½ø³Ì²»°üÀ¨´¦ÓÚwait״̬µÄ½ø³Ì£¬±ÈÈçÔڵȴýI/OµÄ½ø³Ì£¬¼´Ö¸ÄÇЩ¾ÍÐ÷״̬µÄ½ø³Ì£¬ÔËÐÐֻȱCPUÕâ¸ö×ÊÔ´¡£¾ßÌåÈçºÎ¼ÆËã¿ÉÒԲμûLinuxÄں˴úÂ룬¼ÆËã³öÒ»¸öÊýÖ®ºó£¬È»ºó³ýÒÔCPUºËÊý£¬½á¹û£º
<=3 ÔòϵͳÐÔÄܽϺá£
<=4 ÔòϵͳÐÔÄÜ¿ÉÒÔ£¬¿ÉÒÔ½ÓÊÕ¡£
>5 ÔòϵͳÐÔÄܸºÔعýÖØ£¬¿ÉÄܻᷢÉúÑÏÖØµÄÎÊÌ⣬ÄÇô¾ÍÐèÒªÀ©ÈÝÁË£¬ÒªÃ´Ôö¼ÓºË£¬ÒªÃ´·Ö²¼Ê½¼¯Èº¡£
2.²é¿´ÃüÁî
vmstat
vmstat n m
n±íʾÿ¸ônÃë²É¼¯Ò»´Î£¬m±íʾһ¹²²É¼¯¶àÉٴΣ¬Èç¹ûmûÓУ¬ÄÇô»áÒ»Ö±²É¼¯ÏÂÈ¥. ÔÚÖն˼üÈë vmstat
5
½á¹û¸÷×ֶνâÊÍÈçÏÂ(ÕâÀïÖ»½âÊÍÓëCPUÏà¹ØµÄ)£º
r£º±íʾÔËÐжÓÁÐ(¾ÍÊÇ˵¶àÉÙ¸ö½ø³ÌÕæµÄ·ÖÅäµ½CPU)£¬µ±Õâ¸öÖµ³¬¹ýÁËCPUÊýÄ¿£¬¾Í»á³öÏÖCPUÆ¿¾±ÁË¡£Õâ¸öÒ²ºÍtopµÄ¸ºÔØÓйØÏµ£¬Ò»°ã¸ºÔس¬¹ýÁË3¾Í±È½Ï¸ß£¬³¬¹ýÁË5¾Í¸ß£¬³¬¹ýÁË10¾Í²»Õý³£ÁË£¬·þÎñÆ÷µÄ״̬ºÜΣÏÕ¡£topµÄ¸ºÔØÀàËÆÃ¿ÃëµÄÔËÐжÓÁС£Èç¹ûÔËÐжÓÁйý´ó£¬±íʾÄãµÄCPUºÜ·±Ã¦£¬Ò»°ã»áÔì³ÉCPUʹÓÃÂʺܸߡ£
b£º±íʾ×èÈûµÄ½ø³Ì£¬ÈçÔڵȴýI/OÇëÇó¡£
in£ºÃ¿ÃëCPUµÄÖжϴÎÊý£¬°üÀ¨Ê±¼äÖжϡ£
cs£ºÃ¿ÃëÉÏÏÂÎÄÇл»´ÎÊý£¬ÀýÈçÎÒÃǵ÷ÓÃϵͳº¯Êý£¬¾ÍÒª½øÐÐÉÏÏÂÎÄÇл»£¬Ï̵߳ÄÇл»£¬Ò²Òª½ø³ÌÉÏÏÂÎÄÇл»£¬Õâ¸öֵҪԽСԽºÃ£¬Ì«´óÁË£¬Òª¿¼Âǵ÷µÍÏ̻߳òÕß½ø³ÌµÄÊýÄ¿£¬ÀýÈçÔÚapacheºÍnginxÕâÖÖweb·þÎñÆ÷ÖУ¬ÎÒÃÇÒ»°ã×öÐÔÄܲâÊÔʱ»á½øÐм¸Ç§²¢·¢ÉõÖÁ¼¸Íò²¢·¢µÄ²âÊÔ£¬Ñ¡Ôñweb·þÎñÆ÷µÄ½ø³Ì¿ÉÒÔÓɽø³Ì»òÕßÏ̵߳ķåֵһֱϵ÷£¬Ñ¹²â£¬Ö±µ½csµ½Ò»¸ö±È½ÏСµÄÖµ£¬Õâ¸ö½ø³ÌºÍÏß³ÌÊý¾ÍÊDZȽϺÏÊʵÄÖµÁË¡£ÏµÍ³µ÷ÓÃÒ²ÊÇ£¬Ã¿´Îµ÷ÓÃϵͳº¯Êý£¬ÎÒÃǵĴúÂë¾Í»á½øÈëÄں˿ռ䣬µ¼ÖÂÉÏÏÂÎÄÇл»£¬Õâ¸öÊǺܺÄ×ÊÔ´£¬Ò²Òª¾¡Á¿±ÜÃâÆµ·±µ÷ÓÃϵͳº¯Êý¡£ÉÏÏÂÎÄÇл»´ÎÊý¹ý¶à±íʾÄãµÄCPU´ó²¿·ÖÀË·ÑÔÚÉÏÏÂÎÄÇл»£¬µ¼ÖÂCPU¸ÉÕý¾ÊµÄʱ¼äÉÙÁË£¬CPUûÓгä·ÖÀûÓã¬ÊDz»¿ÉÈ¡µÄ¡£
us£ºÓû§CPUʱ¼äÕ¼±È(%)£¬ÀýÈçÔÚ×ö¸ßÔËËãµÄÈÎÎñʱ£¬Èç¼ÓÃܽâÃÜ£¬ÄÇô»áµ¼ÖÂusºÜ´ó£¬ÕâÑù£¬rÒ²»á±ä´ó£¬Ôì³Éϵͳƿ¾±¡£
sy£ºÏµÍ³CPUʱ¼äÕ¼±È(%)£¬Èç¹ûÌ«¸ß£¬±íʾϵͳµ÷ÓÃʱ¼ä³¤£¬ÈçIOƵ·±²Ù×÷¡£
id £º¿ÕÏÐ CPUʱ¼äÕ¼±È(%)£¬Ò»°ãÀ´Ëµ£¬id + us + sy = 100,Ò»°ãÈÏΪidÊÇ¿ÕÏÐCPUʹÓÃÂÊ£¬usÊÇÓû§CPUʹÓÃÂÊ£¬syÊÇϵͳCPUʹÓÃÂÊ¡£
wt£ºµÈ´ýIOµÄCPUʱ¼ä¡£
uptime
17:53:46Ϊµ±Ç°Ê±¼ä
up 158 days, 6:23»úÆ÷ÔËÐÐʱ¼ä£¬Ê±¼äÔ½´ó˵Ã÷ÄãµÄ»úÆ÷Ô½Îȶ¨
2 usersÓû§Á¬½ÓÊý£¬¶ø²»ÊÇ×ÜÓû§Êý
oad average: 0.00, 0.00, 0.00 ×î½ü1·ÖÖÓ£¬5·ÖÖÓ£¬15·ÖÖÓµÄϵͳƽ¾ù¸ºÔØ¡£
½«Æ½¾ù¸ºÔØÖµ³ýÒÔºËÊý£¬Èç¹û½á¹û²»´óÓÚ3£¬ÄÇôϵͳÐÔÄܽϺã¬Èç¹û²»´óÓÚ4ÄÇôϵͳÐÔÄÜ¿ÉÒÔ½ÓÊÜ£¬Èç¹û´óÓÚ5£¬ÄÇôϵͳÐÔÄܽϲ
top
topÃüÁîÓÃÓÚÏÔʾ½ø³ÌÐÅÏ¢£¬topÏêϸ¼ûhttp://www.cnblogs.com/peida/archive/2012/12/24/2831353.html
ÕâÀïÖ÷Òª¹Ø×¢Cpu(s)ͳ¼ÆÄÇÒ»ÐÐ:
us£ºÓû§¿Õ¼äÕ¼ÓÃCPUµÄ°Ù·Ö±È
sy£ºÄں˿ռäÕ¼ÓÃCPUµÄ°Ù·Ö±È
ni£º¸Ä±ä¹ýÓÅÏȼ¶µÄ½ø³ÌÕ¼ÓÃCPUµÄ°Ù·Ö±È
id£º ¿ÕÏÐCPU°Ù·Ö±È
wa£º IOµÈ´ýÕ¼ÓÃCPUµÄ°Ù·Ö±È
hi£ºÓ²Öжϣ¨Hardware IRQ£©Õ¼ÓÃCPUµÄ°Ù·Ö±È
si£ºÈíÖжϣ¨Software Interrupts£©Õ¼ÓÃCPUµÄ°Ù·Ö±È
´ÓtopµÄ½á¹û¿´CPU¸ºÔØÇé¿ö£¬Ö÷Òª¿´usºÍsy£¬ÆäÖÐus<=70£¬sy<=35£¬us+sy<=70˵Ã÷״̬Á¼ºÃ£¬Í¬Ê±¿ÉÒÔ½áºÏidleÖµÀ´¿´£¬Èç¹ûid<=70
Ôò±íʾIOµÄѹÁ¦½Ï´ó¡£Ò²¿ÉÒÔºÍuptimeÒ»Ñù£¬¿´µÚÒ»ÐС£ÒýÓÃ[1]
3.·ÖÎö
±íʾϵͳCPUÕý³££¬Ö÷ÒªÓÐÒÔϹæÔò£º
CPUÀûÓÃÂÊ£ºus <= 70£¬sy <= 35£¬us + sy <= 70¡£ÒýÓÃ[1]
ÉÏÏÂÎÄÇл»£ºÓëCPUÀûÓÃÂÊÏà¹ØÁª£¬Èç¹ûCPUÀûÓÃÂÊ״̬Á¼ºÃ£¬´óÁ¿µÄÉÏÏÂÎÄÇл»Ò²ÊÇ¿ÉÒÔ½ÓÊܵġ£ÒýÓÃ[1]
¿ÉÔËÐжÓÁУºÃ¿¸ö´¦ÀíÆ÷µÄ¿ÉÔËÐжÓÁÐ<=3¸öÏ̡߳£
Memory
1.˵Ã÷
ÄÚ´æÒ²ÊÇϵͳÔËÐÐÐÔÄܵÄÒ»¸öºÜÖØÒªµÄÖ¸±ê£¬Èç¹ûÒ»¸ö»úÆ÷ÄÚ´æ²»×㣬ÄÇô½«»áµ¼Ö½ø³ÌÔËÐÐÒì³£¶øÍ˳ö¡£Èç¹û½ø³Ì·¢ÉúÄÚ´æÐ¹Â©£¬Ôò»áµ¼Ö´óÁ¿ÄÚ´æ±»À˷ѶøÎÞ×ã¹»¿ÉÓÃÄÚ´æ¡£ÄÚ´æ¼à¿ØÒ»°ã°üÀ¨total(»úÆ÷×ÜÄÚ´æ)¡¢free(»úÆ÷¿ÉÓÃÄÚ´æ)¡¢swap(½»»»Çø´óС)¡¢cache(»º´æ´óС)µÈ¡£
2.²é¿´ÃüÁî
vmstat
½á¹û¸÷×ֶνâÊÍÈçÏÂ(ÕâÀïÖ»½âÊÍÓëMemoryÏà¹ØµÄ)£º
swpd£ºÐéÄâÄÚ´æÒÑʹÓõĴóС£¬Èç¹û´óÓÚ0£¬±íʾÄãµÄ»úÆ÷ÎïÀíÄÚ´æ²»×ãÁË£¬Èç¹û²»ÊdzÌÐòÄÚ´æÐ¹Â¶µÄÔÒò£¬ÄÇôÄã¸ÃÉý¼¶ÄÚ´æÁË»òÕ߰ѺÄÄÚ´æµÄÈÎÎñÇ¨ÒÆµ½ÆäËû»úÆ÷£¬µ¥Î»ÎªKB¡£
free £º¿ÕÏеÄÎïÀíÄÚ´æµÄ´óС£¬ÎҵĻúÆ÷ÄÚ´æ×ܹ²8G£¬Ê£Óà4457612KB£¬µ¥Î»ÎªKB¡£
buff£ºLinux/UnixϵͳÀ´´æ´¢Ä¿Â¼ÀïÃæÓÐʲôÄÚÈÝ£¬È¨Ï޵ȵĻº´æ£¬ÕâÀï´ó¸ÅÕ¼ÓÃ280M£¬µ¥Î»ÎªKB¡£
cache£ºcacheÖ±½ÓÓÃÀ´¼ÇÒäÎÒÃÇ´ò¿ªµÄÎļþ£¬¸øÎļþ×ö»º³å£¬ÕâÀï´ó¸ÅÕ¼ÓÃ280M(ÕâÀïÊÇLinux/UnixµÄ´ÏÃ÷Ö®´¦£¬°Ñ¿ÕÏеÄÎïÀíÄÚ´æµÄÒ»²¿·ÖÄÃÀ´×öÎļþ¡¢Ä¿Â¼ºÍ½ø³ÌµØÖ·¿Õ¼äµÄ»º´æ£¬ÊÇΪÁËÌá¸ß³ÌÐòÖ´ÐеÄÐÔÄÜ£¬µ±³ÌÐòʹÓÃÄÚ´æÊ±£¬buffer/cached»áºÜ¿ìµØ±»Ê¹ÓÃ)£¬µ¥Î»ÎªKB¡£
si£º ÿÃë´Ó´ÅÅ̶ÁÈëÐéÄâÄÚ´æµÄ´óС£¬Èç¹ûÕâ¸öÖµ´óÓÚ0£¬±íʾÎïÀíÄÚ´æ²»¹»ÓûòÕßÄÚ´æÐ¹Â¶ÁË£¬Òª²éÕÒºÄÄÚ´æ½ø³Ì½â¾öµô¡£±¾»úÄÚ´æ³äÔ££¬Ò»ÇÐÕý³££¬µ¥Î»ÎªKB¡£
so£ºÃ¿ÃëÐéÄâÄÚ´æÐ´Èë´ÅÅ̵ĴóС£¬Èç¹ûÕâ¸öÖµ´óÓÚ0£¬Í¬ÉÏ£¬µ¥Î»ÎªKB¡£
free
µÚ¶þÐÐÊÇÄÚ´æÐÅÏ¢£¬totalΪ»úÆ÷×ÜÄڴ棬usedΪ¶àÉÙÒѾʹÓã¬freeΪ¶àÉÙ¿ÕÏУ¬sharedΪ¶à¸ö½ø³Ì¹²ÏíµÄÄÚ´æ×ܶbuffersÓëcache¶¼ÊÇ´ÅÅÌ»º´æµÄ´óС£¬·Ö±ðͬvmstatÀïÃæµÄbuffÓëcache.
µ¥Î»¶¼ÊÇM.
µÚÈýÐÐÊÇbuffersÓëcache×ܶîµÄusedÓëfree. µ¥Î»¶¼ÊÇM.
µÚËÄÐÐÊǽ»»»ÇøswapµÄ×ܶÒÑÓÃÓëfree. µ¥Î»¶¼ÊÇM.
Çø±ð£ºµÚ¶þÐÐ(mem)µÄused/freeÓëµÚÈýÐÐ(-/+ buffers/cache) used/freeµÄÇø±ð¡£
ÕâÁ½¸öµÄÇø±ðÔÚÓÚʹÓõĽǶÈÀ´¿´£¬µÚ¶þÐÐÊÇ´ÓOSµÄ½Ç¶ÈÀ´¿´£¬ÒòΪ¶ÔÓÚOS£¬buffers/cached
¶¼ÊÇÊôÓÚ±»Ê¹Óã¬ËùÒÔËûµÄ¿ÉÓÃÄÚ´æÊÇ4353M, ÒÑÓÃÄÚ´æÊÇ3519M, ÆäÖаüÀ¨£¬Äںˣ¨OS£©Ê¹ÓÃ+Application(X,
oracle,etc)ʹÓõÄ+buffers+cached.
µÚÈýÐÐËùÖ¸µÄÊÇ´ÓÓ¦ÓóÌÐò½Ç¶ÈÀ´¿´£¬¶ÔÓÚÓ¦ÓóÌÐòÀ´Ëµ£¬buffers/cached ÊǵÈÓÚ¿ÉÓõģ¬ÒòΪbuffer/cachedÊÇΪÁËÌá¸ßÎļþ¶ÁÈ¡µÄÐÔÄÜ£¬µ±Ó¦ÓóÌÐòÐèÔÚÓõ½ÄÚ´æµÄʱºò£¬buffer/cached»áºÜ¿ìµØ±»»ØÊÕ¡£
ËùÒÔ´ÓÓ¦ÓóÌÐòµÄ½Ç¶ÈÀ´Ëµ£¬¿ÉÓÃÄÚ´æ=ϵͳfree memory+buffers+cached¡£
top
Ö»¹Ø×¢ÓëÄÚ´æÏà¹ØµÄͳ¼ÆÐÅÏ¢£¬¼´MemÓëSwapÐС£·Ö±ðÊÇMemÓëSwapµÄ×ܶÒÑÓÃÁ¿¡¢¿ÕÏÐÁ¿¡¢buffersÓëcache.
ÕâÀï±ãÑéÖ¤ÁËbuffersÊÇ»º´æÄ¿Â¼ÀïÃæÓÐʲôÄÚÈÝ£¬È¨ÏÞµÈÐÅÏ¢µÄ£¬¶øcacheÊÇÓÃÀ´swapµÄ»º´æµÄ.
cat /proc/meminfo
Ö÷ÒªÕ⼸¸ö×ֶΣº
MemTotal£ºÄÚ´æ×ܶî
MemFree£ºÄÚ´æ¿ÕÏÐÁ¿
Buffers£ºÍ¬topÃüÁîµÄbuffers
Cached£ºÍ¬topÃüÁîµÄcache
SwapToatl£ºSwapÇø×Ü´óС
SwapFree£ºSwapÇø¿ÕÏдóС
3.·ÖÎö
±íʾϵͳMemÕý³££¬Ö÷ÒªÓÐÒÔϹæÔò£º
swap in (si) == 0£¬swap out (so) == 0
¿ÉÓÃÄÚ´æ/ÎïÀíÄÚ´æ >= 30%
´ÅÅÌ
˵Ã÷
»úÆ÷µÄ´ÅÅ̿ռäÒ²ÊÇÒ»¸öÖØÒªµÄÖ¸±ê£¬Ò»µ©Ê¹ÓÃÂʳ¬¹ýãÐÖµ¶øÊ¹µÃ¿ÉÓò»×㣬ÄÇô¾ÍÐèÒª½øÐÐÀ©ÈÝ»òÕßÇå³ýһЩÎÞÓõÄÎļþ¡£
²é¿´ÃüÁî
df
Filesystem£ºÎļþϵͳµÄÃû³Æ
1K-blocks£º1K¿éµÄÎļþϵͳ
Used£ºÒÑʹÓÃÁ¿£¬µ¥Î»ÎªKB
Available£º¿ÕÏÐÁ¿£¬µ¥Î»ÎªKB
Use%£ºÒÑʹÓÃÕ¼±È
Mounted on£º¹ÒÔØµÄĿ¼
·ÖÎö
±íʾϵͳ´ÅÅ̿ռäÕý³££¬Ö÷ÒªÓÐÒÔϹæÔò£º
Use% <= 90%
´ÅÅÌI/O
˵Ã÷
»úÆ÷µÄ´ÅÅ̿ռäÒ²ÊÇÒ»¸öÖØÒªµÄÖ¸±ê£¬Ò»µ©´ÅÅÌI/O¹ýÖØ£¬ÄÇô˵Ã÷ÔËÐеĽø³ÌÔÚ´óÁ¿µÄÎļþ¶Áд²¢ÇÒcacheÃüÖÐÂʵ͡£ÄÇôһ¸ö¼òµ¥µÄ·½·¨±ãÊÇÔö´óÎļþ»º´æ´óСÀ´Ìá¸ßÃüÖÐÂÊ´Ó¶ø½µµÍI/O¡£
ÔÚLinuxÖУ¬ÄÚºËÏ£ÍûÄܾ¡¿ÉÄܲúÉú´ÎȱҳÖжϣ¨´ÓÎļþ»º´æÇø¶Á£©£¬²¢ÇÒÄܾ¡¿ÉÄܱÜÃâÖ÷ȱҳÖжϣ¨´ÓÓ²Å̶Á£©£¬ÕâÑùËæ×ÅȱҳÖжϵÄÔö¶à£¬Îļþ»º´æÇøÒ²Öð²½Ôö´ó£¬Ö±µ½ÏµÍ³Ö»ÓÐÉÙÁ¿¿ÉÓÃÎïÀíÄÚ´æµÄʱºò
Linux ²Å¿ªÊ¼ÊÍ·ÅһЩ²»ÓõÄÒ³¡£ÒýÓÃ[1]
²é¿´ÃüÁî
vmstat
bi £º¿éÉ豸ÿÃë½ÓÊյĿéÊýÁ¿£¬ÕâÀïµÄ¿éÉ豸ÊÇָϵͳÉÏËùÓеĴÅÅÌºÍÆäËû¿éÉ豸£¬Ä¬ÈÏ¿é´óС1024byte¡£
bo£º¿éÉ豸ÿÃë·¢Ë͵ĿéÊýÁ¿£¬ÀýÈçÎÒÃǶÁÈ¡Îļþ£¬bo¾ÍÒª´óÓÚ0¡£biºÍboÒ»°ã¶¼Òª½Ó½ü0£¬²»È»¾ÍÊÇIO¹ýÓÚÆµ·±£¬ÐèÒªµ÷Õû¡£
iostat
Linux¶ÎΪ»úÆ÷ϵͳÐÅÏ¢£º ϵͳÃû³Æ¡¢hostname¡¢µ±Ç°Ê±¼ä¡¢ÏµÍ³°æ±¾.
avg-cpu¶ÎΪcpuµÄͳ¼ÆÐÅÏ¢(ƽ¾ùÖµ)£º
%user£ºÓû§¼¶±ðÔËÐÐËùʹÓõÄCPUµÄ°Ù·Ö±È.
%nice£ºnice²Ù×÷ËùʹÓõÄCPUµÄ°Ù·Ö±È.
%sys£ºÔÚϵͳ¼¶±ð(kernel)ÔËÐÐËùʹÓÃCPUµÄ°Ù·Ö±È.
%iowait£ºCPUµÈ´ýÓ²¼þI/Oʱ,ËùÕ¼ÓÃCPU°Ù·Ö±È.
%idle£ºCPU¿ÕÏÐʱ¼äµÄ°Ù·Ö±È.
Device¶Î¶ÎΪÉ豸ÐÅÏ¢(ÉÏͼÖÐÓÐÁ½¸öÅÌvdaÓëvdb)£º
tps: ÿÃëÖÓ·¢Ë͵½µÄI/OÇëÇóÊý.
Blk_read/s: ÿÃë¶ÁÈ¡µÄblockÊý.
Blk_wrtn/s: ÿÃëдÈëµÄblockÊý.
Blk_read: ¶ÁÈëµÄblock×ÜÊý.
Blk_wrtn: дÈëµÄblock×ÜÊý.
sar -d 1 1
sar -d±íʾ²é¿´´ÅÅ̱¨¸æ 1 1 ±íʾ¼ä¸ô1s£¬ÔËÐÐ1´Î
Æäʵcpu¡¢»º´æÇø¡¢Îļþ¶Áд¡¢ÏµÍ³½»»»ÇøµÈÐÅÏ¢¶¼¿ÉÒÔͨ¹ý¸ÃÃüÁî²é¿´£¬Ö»ÊÇÑ¡Ïͬ£¬¾ßÌå²Î¼û£ºhttp://blog.chinaunix.net/uid-23177306-id-2531032.html
µÚÒ»¸ö¶ÎΪ»úÆ÷ϵͳÐÅÏ¢£¬Í¬iostat
µÚ¶þ¸ö¶ÎΪÿ´ÎÔËÐеÄdev I/OÐÅÏ¢£¬ÕâÀïÒòΪֻÔËÐÐÒ»´Î£¬²¢ÓÐÁ½¸öÉ豸dev252-0Óëdev252-16£º
tps£ºÃ¿Ãë´ÓÎïÀí´ÅÅÌI/OµÄ´ÎÊý.¶à¸öÂß¼ÇëÇó»á±»ºÏ²¢ÎªÒ»¸öI/O´ÅÅÌÇëÇó,Ò»´Î´«ÊäµÄ´óСÊDz»È·¶¨µÄ.
rd_sec/s£ºÃ¿Ãë¶ÁÉÈÇøÊý
wr_sec/s£ºÃ¿ÃëдÉÈÇøÊý
avgrq-sz£ºÆ½¾ùÿ´ÎÉ豸I/O²Ù×÷µÄÊý¾Ý´óС (ÉÈÇø)
avgqu-sz£ºÆ½¾ùI/O¶ÓÁ㤶È
await£ºÎªÆ½¾ùÿ´ÎÉ豸I/O²Ù×÷µÄµÈ´ýʱ¼ä(µ¥Î»ms)£¬°üÀ¨ÇëÇóÔÚ¶ÓÁÐÖеĵȴýʱ¼äºÍ·þÎñʱ¼ä
svctm£ºÎªÆ½¾ùÿ´ÎÉ豸I/O²Ù×÷µÄ·þÎñʱ¼ä(µ¥Î»ms)
%util£º±íʾһÃëÖÐÓаٷÖÖ®¼¸µÄʱ¼äÓÃÓÚI/O²Ù×÷
Èç¹ûsvctmµÄÖµÓëawaitºÜ½Ó½ü£¬±íʾ¼¸ºõûÓÐI/OµÈ´ý£¬´ÅÅÌÐÔÄܺܺã¬Èç¹ûawaitµÄÖµÔ¶¸ßÓÚsvctmµÄÖµ£¬Ôò±íʾI/O¶ÓÁеȴýÌ«³¤£¬ÏµÍ³ÉÏÔËÐеÄÓ¦ÓóÌÐò½«±äÂý¡£
Èç¹û%util½Ó½ü100%£¬±íʾ´ÅÅ̲úÉúµÄI/OÇëÇóÌ«¶à£¬I/OϵͳÒѾÂú¸ººÉµÄÔÚ¹¤×÷£¬¸Ã´ÅÅÌÇëÇ󱥺ͣ¬¿ÉÄÜ´æÔÚÆ¿¾±¡£idleСÓÚ70%
I/OѹÁ¦¾Í½Ï´óÁË£¬Ò²¾ÍÊÇÓн϶àµÄI/O¡£ÒýÓÃ[1]
ͬʱ¿ÉÒÔ½áºÏvmstat ²é¿´b²ÎÊý(µÈ´ý×ÊÔ´µÄ½ø³ÌÊý)ºÍwa²ÎÊý(IOµÈ´ýËùÕ¼ÓõÄCPUʱ¼äµÄ°Ù·Ö±È£¬¸ß¹ý30%ʱIOѹÁ¦¸ß)¡£ÒýÓÃ[1]
·ÖÎö
±íʾϵͳ´ÅÅ̿ռäÕý³££¬Ö÷ÒªÓÐÒÔϹæÔò£º
I/OµÈ´ýµÄÇëÇó±ÈÀý <= 20%
Ìá¸ßÃüÖÐÂʵÄÒ»¸ö¼òµ¥·½Ê½¾ÍÊÇÔö´óÎļþ»º´æÇøÃæ»ý£¬»º´æÇøÔ½´óÔ¤´æµÄÒ³Ãæ¾ÍÔ½¶à£¬ÃüÖÐÂÊÒ²Ô½¸ß¡£
Linux ÄÚºËÏ£ÍûÄܾ¡¿ÉÄܲúÉú´ÎȱҳÖжϣ¨´ÓÎļþ»º´æÇø¶Á£©£¬²¢ÇÒÄܾ¡¿ÉÄܱÜÃâÖ÷ȱҳÖжϣ¨´ÓÓ²Å̶Á£©£¬ÕâÑùËæ×Å´ÎȱҳÖжϵÄÔö¶à£¬Îļþ»º´æÇøÒ²Öð²½Ôö´ó£¬Ö±µ½ÏµÍ³Ö»ÓÐÉÙÁ¿¿ÉÓÃÎïÀíÄÚ´æµÄʱºò
Linux ²Å¿ªÊ¼ÊÍ·ÅһЩ²»ÓõÄÒ³¡£ÒýÓÃ[1]
ÍøÂçI/O
˵Ã÷
Èç¹û·þÎñÆ÷ÍøÂçÁ¬½Ó¹ý¶à£¬ÄÇô»áÔì³É´óÁ¿µÄÊý¾Ý°üÔÚ»º³åÇø³¤Ê±¼äµÃ²»µ½´¦Àí£¬Ò»µ©»º³åÇø²»×㣬±ã»áÔì³ÉÊý¾Ý°ü¶ªÊ§ÎÊÌ⣬¶ÔÓÚTCP£¬Êý¾Ý°ü¶ªÊ§±ã»á½øÐÐÖØ´«£¬ÕâÓлᵼÖ´óÁ¿µÄÖØ´«£»¶ÔÓÚUDP£¬Êý¾Ý°ü¶ªÊ§²»»á½øÐÐÖØ´«£¬ÄÇôÊý¾Ý±ã»á¶ªÊ§¡£Òò´Ë£¬·þÎñÆ÷µÄÍøÂçÁ¬½Ó²»Ò˹ý¶à£¬ÐèÒª½øÐÐ¼à¿Ø¡£
·þÎñÆ÷Ò»°ã½ÓÊÕUDPÓëTCPÇëÇ󣬶¼ÊÇÎÞ״̬Á¬½Ó£¬TCP(´«Êä¿ØÖÆÐÒé)ÊÇÒ»ÖÖÌṩ¿É¿¿µÄÊý¾Ý´«ÊäÐÒ飬UDP(Óû§Êý¾Ý±¨ÐÒé)ÊÇÒ»ÖÖÃæÏòÎÞÁ¬½ÓµÄÐÒ飬¼´Æä´«Êä¼òµ¥µ«²»¿É¿¿¡£¹ØÓÚËüÃǶþÕßÖ®¼äµÄÇø±ð£¬¿ÉÒÔ²éÔÄÏà¹Ø×ÊÁÏ¡£
²é¿´ÃüÁî
netstat
UDP
(1) netstat -ludp | grep udp
Proto£ºÐÒéÃû
Recv-Q£ºÊÕµ½µÄÇëÇó¸öÊý
Send-Q£º·¢Ë͵ÄÇëÇó¸öÊý
Local Address£º±¾µØµØÖ·Óë¶Ë¿Ú
Foreign Address£ºÔ¶³ÌµØÖ·Óë¶Ë¿Ú
State£º×´Ì¬
PID/Program name£º½ø³ÌIDÓë½ø³ÌÃû
(2) ½øÒ»²½²é¿´UDP½ÓÊÕµÄÊý¾Ý°üÇé¿ö netstat -su
»È¦µÄ±ãÊÇUDPÊý¾Ý°ü¶ªÊ§Í³¼Æ£¬¸ÃÏîÖµÔö¼ÓÁË£¬ËµÃ÷´æÔÚudpÊý¾Ý°ü¶ªÊ§£¬¼´Íø¿¨ÊÕµ½ÁË£¬µ«ÊÇÓ¦ÓòãûÓÐÀ´µÃ¼°´¦Àí¶øÔì³ÉµÄ¶ª°ü¡£
TCP
(1) netstat
¸÷×ֶκ¬ÒåͬUDP
(2) ²é¿´ÖØ´«ÂÊ
ÒòΪTCPÊǿɿ¿´«ÊäÐÒ飬Èç¹ûÊý¾Ý°ü¶ªÊ§»á½øÐÐÖØ´«£¬Òò´ËTCPÐèÒª²é¿´ÆäÖØ´«ÂÊ.
cat /proc/net/snmp | grep Tcp
ÄÇÃ´ÖØ´«ÂÊΪRetransSegs/OutSegs
·ÖÎö
UDP¶ª°üÂÊ»òÕßTCPÖØ´«Âʲ»ÄܸßÓÚ¶àÉÙ£¬ÕâÁ½¸öÖµÓÉϵͳ¿ª·¢¶¨Ò壬´Ë´¦£¬ÅÄÄÔ´ü¾ö¶¨UDP°ü¶ª°üÂÊÓëTCP°üÖØ´«Âʲ»Äܳ¬¹ý1%/s¡£
Á¬½ÓÊý
˵Ã÷
¶ÔÓÚÿһ̨·þÎñÆ÷£¬¶¼Ó¦¸ÃÏÞÖÆÍ¬Ê±Á¬½ÓÊý£¬µ«ÊÇÕâ¸öãÐÖµÓÖ²»ºÃÈ·¶¨£¬Òò´Ëµ±¼à²âµ½ÏµÍ³¸ºÔعýÖØÊ±£¬È»ºóÈ¡ÆäÁ¬½ÓÊý£¬Õâ¸öÖµ±ã¿É×÷Ϊ²Î¿¼Öµ¡£
ÃüÁî
netstat
netstat
-na | sed -n '3,$p' |awk '{print $5}' | grep
-v 127\.0\.0\.1 | grep -v 0\.0\.0\.0 | wc -l
|
·ÖÎö
ϵͳ¸ºÔعýÖØÊ±£¬¸ÃÖµ×÷Ϊ·þÎñÆ÷µÄ·åÖµ²Î¿¼Öµ¡£
Èç¹û³¬¹ý1024±¨¾¯
Îļþ¾ä±úÊý
˵Ã÷
Îļþ¾ä±úÊý¼´µ±Ç°´ò¿ªµÄÎļþÊý£¬¶ÔÓÚlinux£¬ÏµÍ³Ä¬ÈÏÖ§³ÖµÄ×î´ó¾ä±úÊýÊÇ1024£¬µ±È»Ã¿¸öϵͳ¿ÉÒÔ²»Ò»Ñù£¬Ò²¿ÉÒÔÐ޸ģ¬×î´ó²»Äܳ¬¹ýÎÞ·ûºÅÕûÐÍ×î´óÖµ(65535)£¬¿ÉÒÔʹÓÃulimit
-nÃüÁî½øÐв鿴£¬¼´Òò´ËÈç¹ûͬʱ´ò¿ªµÄÎļþÊý³¬¹ýÕâ¸öÊý±ã»á·¢ÉúÒì³£¡£Òò´ËÕâ¸öÖ¸±êÒ²ÐèÒª½øÐÐ¼à¿Ø¡£
²é¿´ÃüÁî
lsof
lsof
-n | awk '{print $1,$2}' | sort | uniq -c |
sort -nr |
ÈýÁзֱðÊÇ´ò¿ªµÄÎļþ¾ä±úÊý, ½ø³ÌÃû£¬½ø³ÌºÅ
·ÖÎö
½«ËùÓеÄÐеĵÚÒ»ÁÐÏà¼Ó±ãÊÇϵͳĿǰ´ò¿ªµÄÎļþ¾ä±úÊýnum£¬Èç¹ûnum<=max_num*85%Ôò±¨¾¯¡£
ÐÔÄÜÖ¸±ê×ܽá
CPU
CPUÀûÓÃÂÊ£ºus <= 70£¬sy <= 35£¬us + sy <= 70¡£
ÉÏÏÂÎÄÇл»£ºÓëCPUÀûÓÃÂÊÏà¹ØÁª£¬Èç¹ûCPUÀûÓÃÂÊ״̬Á¼ºÃ£¬´óÁ¿µÄÉÏÏÂÎÄÇл»Ò²ÊÇ¿ÉÒÔ½ÓÊܵġ£
¿ÉÔËÐжÓÁУºÃ¿¸ö´¦ÀíÆ÷µÄ¿ÉÔËÐжÓÁÐ<=3¸öÏ̡߳£
Memory
swap in (si) == 0£¬swap out (so) == 0
¿ÉÓÃÄÚ´æ/ÎïÀíÄÚ´æ >= 30%
Disk
Use% <= 90%
Disk I/O
I/OµÈ´ýµÄÇëÇó±ÈÀý <= 20%
Network I/O
UDP°ü¶ª°üÂÊÓëTCP°üÖØ´«Âʲ»Äܳ¬¹ý1%/s¡£
Connect Num
<= 1024
File Handle Num
num/max_num <= 90%
×ܽá
½Å±¾¼ì²ânginx¡¢tomcatÓëwebappÔËÐÐÒì³£ÈÕÖ¾(°üÀ¨nginxÓëtomcatÊÇ·ñÕýÔÚÔËÐÐ)Óë·þÎñÆ÷ÐÔÄܯߏöÖ¸±ê£¬Ò»µ©·¢ÏÖÒì³£ÐÅÏ¢ºÍÐÔÄܳ¬±ê£¬ÄÇôÂíÉÏ·¢ËÍÓʼþ¸ø¹ÜÀíÔ±£¬Ò²¿ÉÒÔʹÓÃÔÆ¼à¿Øpush¸ø¹ÜÀíÔ±µÄÔÆÕ˺š£
|