ट्यूनिंग Apache2 प्रीफॉर्क मैक्सक्लाइंट सर्वरलिमिट


22

मेरे पास 128 जीबी राम वाली एक मशीन है जो Apache2 का उपयोग वेबसर्वर के रूप में कर रही है (इस मशीन में कोई डेटाबेस सर्वर नहीं है, डेटाबेस मशीन 64 जीबी रैम मशीन है जो 2000 अधिकतम कनेक्शन को संभाल सकती है)। मैं एक निगरानी उपकरण के साथ देखता हूं कि इस समय 44 व्यस्त श्रमिकों और 12 निष्क्रिय श्रमिकों के बारे में हैं, मेरे प्रीफ़ोर्क मॉड्यूल के लिए सबसे अच्छा सैद्धांतिक मूल्य क्या हैं?

मुझे कभी-कभी उच्च लोड घंटों पर वेबसाइटों को लोड करने के लिए खाली पृष्ठ मिलते हैं और मेरी अपाचे त्रुटि लॉग पर यह त्रुटि मिली है:

[सूचना] बच्चे को १३५ ९ ५ एक्जिट सिग्नल सेगमेंटेशन दोष (११)

इस मुद्दे को भी कैसे हल कर सकते हैं?

मेरा Apache2 Prefork मॉड्यूल कॉन्फ़िगरेशन:

StartServers          3
MinSpareServers       3
MaxSpareServers       5
ServerLimit           3200
MaxClients            3100
MaxRequestsPerChild   0

Www -hh पर www मशीन :

कुल: 128 G मुफ़्त: 97GB (अपाचे 2 के साथ) ने 0b बफ़र 1.9G कैश 23G साझा किया

अपाचे 2 और अन्य कार्यक्रमों द्वारा राम का उपयोग:

Private  +   Shared  =  RAM used    Program

 96.0 KiB +  61.0 KiB = 157.0 KiB   sh
176.0 KiB +  26.0 KiB = 202.0 KiB   atd
176.0 KiB +  35.5 KiB = 211.5 KiB   acpid
208.0 KiB +  19.5 KiB = 227.5 KiB   mdadm
204.0 KiB +  30.0 KiB = 234.0 KiB   init
248.0 KiB +  62.0 KiB = 310.0 KiB   sendmail
376.0 KiB +  36.0 KiB = 412.0 KiB   dbus-daemon
388.0 KiB + 285.5 KiB = 673.5 KiB   cron (2)
820.0 KiB +  42.0 KiB = 862.0 KiB   gam_server
920.0 KiB + 108.0 KiB =   1.0 MiB   ntpd
968.0 KiB + 243.0 KiB =   1.2 MiB   getty (6)
  1.3 MiB + 351.5 KiB =   1.6 MiB   udevd (3)
  1.5 MiB + 343.0 KiB =   1.8 MiB   sendmail-msp
  2.0 MiB + 910.0 KiB =   2.9 MiB   plugin-localresources2
  3.4 MiB +  50.0 KiB =   3.4 MiB   rsyslogd
  3.6 MiB +  68.5 KiB =   3.7 MiB   bash
  1.9 MiB +   2.1 MiB =   4.0 MiB   sendmail-mta (4)
  3.8 MiB + 556.0 KiB =   4.3 MiB   sshd (2)
  3.7 MiB +   1.2 MiB =   4.8 MiB   plugin-apache2
  5.1 MiB +   1.2 MiB =   6.3 MiB   agent-service
  7.0 MiB + 654.0 KiB =   7.6 MiB   fail2ban-server
  9.6 MiB +   2.6 MiB =  12.2 MiB   proftpd (8)
 59.2 MiB +  70.0 KiB =  59.3 MiB   miniserv.pl
 96.8 MiB +   3.6 MiB = 100.4 MiB   php5-cgi (2)
196.4 MiB +  35.9 MiB = 232.3 MiB   apache2 (40)
---------------------------------
                     tot 450.0 MiB

2
वेब सर्वर के भीतर चलने वाला एप्लिकेशन कोड क्या है? इसकी सबसे अधिक संभावना अपराधी है।
शेन झुंझलाना

कृपया apache2ctl स्टेटस के कुछ नमूने भेजें; क्या error_log में कुछ है?
हिरोवेज jarपोलर

जवाबों:


63

Apache prefork सेटिंग्स, अपाचे प्रदर्शन ट्यूनिंग दिशानिर्देशों के अनुसार

बोली:

The single biggest hardware issue affecting webserver performance is RAM.
A webserver should never ever have to swap, as swapping increases the latency
of each request beyond a point that users consider "fast enough". 
This causes users to hit stop and reload, further increasing the load.
You can, and should, control the MaxClients setting so that your server does
not spawn so many children it starts swapping. This procedure for doing this
is simple: determine the size of your average Apache process, by looking at
your process list via a tool such as top, and divide this into your total 
available memory, leaving some room for other processes.

आपको इसे अपने इनपुट के आधार पर इस तरह सेट करना चाहिए:

  • कुल मेमोरी: 128 जीबी
  • अपाचे को छोड़कर सभी के लिए -10% मेमोरी: 115 जीबी
  • अब हमें यह पता लगाने की आवश्यकता है कि एकल अपाचे प्रक्रिया कितना उपयोग कर रही है।

इसकी गणना करने के लिए आप निम्नलिखित स्क्रिप्ट का उपयोग कर सकते हैं:

pgrep apache2 | xargs -n1 -I{} cat /proc/{}/smaps | \
  awk '{if ($0 ~ /stack/) {pids+=1} else if ($0 ~/^Shared_/) 
    {shared+=$2} else if ($0 ~ /^Pss:/) {priv+=$2}} END {
      printf "%.2f MB\n",(priv+shared/(pids*pids))/1024}'

यह सबसे अच्छा अनुमान है कि सक्रिय अपाचे प्रक्रियाओं की संख्या के अनुपात में साझा उपयोग को आनुपातिक रूप से विभाजित करने की कोशिश करते हुए और इसे Pss (आनुपातिक सेट आकार) के शीर्ष पर जोड़ने के दौरान एकल अपाचे प्रक्रिया स्मृति का उपयोग कर रही है।

अंत में आप इस आंकड़े के साथ 115 जीबी विभाजित करते हैं और आपको मिलता है MaxClients/ServerLimit। यहां से आप अन्य आंकड़ों की तरह अपेक्षाकृत गणना कर सकते हैं

  • StartServers अधिकतम 30% ग्राहक
  • MinSpareServers MaxClients का 5%
  • MaxSpareServers MaxClients का 10%
  • ServerLimit == MaxClients
  • MaxConnectionsPerChild 10000 (मेमोरी लीक ऐप्स के साथ संभावित समस्या के समाधान के लिए रूढ़िवादी विकल्प के रूप में)

2
मुझे आशा है कि मुझसे अधिक प्रतिनिधि बिंदु वाले कोई व्यक्ति आपको इस उत्तर के लिए वोट देगा, बहुत बहुत धन्यवाद!
यूजर-एन

2
आपकी गणना स्क्रिप्ट मुझे 842.13 एमबी प्रदान करती है। यह परिमाण के एक आदेश के बारे में है जो मैं करूँगा (Apache 2.2 on CentOS 6.7)।
क्विन कॉमेंडेंट

1
यह प्रीफ़ॉर्क मोड में है। यहाँ से आउटपुट है /server-info: i.imgur.com/SS2gIXI.png
क्विन कॉमेंडेंट

1
@ क्विनकैमडेन दुष्ट ट्रिक हालांकि इफमॉड्यूल सही होगा यदि प्रीफोर्क मॉड्यूल उपलब्ध है (जो कि यह है), और वास्तव में दोनों विकल्प उपलब्ध कार्यकर्ता और एमपीएम हैं ... मेरे पास कार्यकर्ता के लिए मेरे सर्वर पर समान सर्वर और मेमोरी का उपयोग ~ 850 एमबी है। वहाँ कोई रास्ता नहीं है prefork 1 प्रक्रिया 800 एमबी मेमोरी के लिए उपयोग कर सकते हैं। आपने स्क्रिप्ट में लाइन बदल दी है, जहां यह प्रक्रिया नाम apache2 httpd सही है?
हिरोवेज

1
@shawn आप ऐसा क्यों कहेंगे? आप कैसे मानते हैं कि इसकी गणना की जानी चाहिए?
--रवोजे jarपोलर
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.