نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول
نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول
من السهل جدًا تثبيت وتهيئة Apache ، ولكنه يأتي مع العديد من الوحدات المثبتة مسبقًا ونتيجة لذلك قد تواجه مشاكل في الأداء عند تشغيله على ذاكرة وصول عشوائي منخفضة VPS RAM.
لذلك ، ليست هناك حاجة دائمًا لخادم أكبر ، ولكن يمكنك ببساطة تكوين إعدادات Apache بالطريقة الصحيحة والحصول على أفضل أداء ممكن. إليك بعض الأشياء التي يجب عليك القيام بها لتحقيق ذلك.
هذا البرنامج التعليمي لـ Ubuntu 14.04 LTS لكن المبادئ مشابهة للإصدارات السابقة أيضًا.
يمكنك رؤية قائمة بجميع الوحدات المثبتة مع الأمر ls /etc/apache2/mods-available/
وجميع الوحدات النشطة حاليًا ls /etc/apache2/mods-enabled/
.
عند التثبيت الأولي لأباتشي ، يتم تمكين 15 وحدة أو أكثر بشكل افتراضي. هذه كثيرة للغاية ولا حاجة لها.
بادئ ذي بدء ، يجب عليك إنشاء قائمة بجميع الوحدات النشطة حاليًا وحفظها للرجوع إليها مستقبلاً في حالة تعطيل شيء مطلوب وعليك إعادة تمكينه. ثم ببساطة قم بتعطيل الوحدات النمطية واحدًا تلو الآخر باستخدام الأمر (باستخدام moduleName كمثال):
sudo a2dismod moduleName
... وأعد تشغيل Apache بعد كل تغيير لمعرفة ما إذا حدث أي خطأ.
بعض الوحدات التي يجب عليك تعطيلها إذا لم تكن بحاجة إليها:
بعد تعطيل الوحدة وإعادة تحميل تكوين Apache ، يمكنك التحقق من الأخطاء عن طريق فتح سجل أخطاء Apache باستخدام محرر نصوص مثل nano.
sudo nano /var/log/apache2/error.log
إذا تلقيت خطأ ، فأعد تمكين الوحدة المقابلة باستخدام:
sudo a2enmod moduleName
ثم ، أعد تشغيل Apache مرة أخرى حتى تحصل على الحد الأدنى من قائمة الترتيب!
باستخدام تكوين Apache الافتراضي (وهو غير متوازن جيدًا للخوادم الصغيرة) ، يمكن استنفاد الذاكرة بسرعة ويمكن أن يصبح خادم السحابة الخاص بك زائدًا. سيؤدي ذلك إلى تعليق صفحة الويب في حالة تحميل مستمر. من المحتمل أن يحافظ الخادم على عمليات Apache الميتة هذه نشطة ، محاولًا عرض المحتوى دون داع ، مما يقلل من عدد العمليات المتاحة للعرض.
لحل هذه المشكلة ، عليك أولاً معرفة مقدار ذاكرة الوصول العشوائي التي يحتاجها خادمك بعيدًا عن Apache ومتوسط حجم الذاكرة الذي تستخدمه عمليات Apache.
أثناء تشغيل Apache ، افتح الأمر العلوي على الخادم.
top -bn 1
على جدول النتائج:
الخطوة التالية ، قم بتحرير ملف تكوين وحدة mpm_prefork:
sudo nano /etc/apache2/mods-enabled/mpm_prefork.conf
قد يبدو مثل هذا:
<IfModule mpm_prefork_module>
StartServers 2
MinSpareServers 2
MaxSpareServers 5
MaxRequestWorkers 30
MaxConnectionsPerChild 0
</IfModule>
أين:
في إعداد MaxRequestWorkers ، يجب عليك تغييره إلى كل ما وجدته في القسم أعلاه.
الآن ، إذا تم تحميل VPS الخاص بك بشكل زائد ووصل إلى الحد الأقصى من العملاء الذين يمكن أن يخدمهم في وقت واحد ، فإنه سيخدم هؤلاء المستخدمين وغيرهم ببساطة سيحصلون على فشل سريع. يمكنهم بعد ذلك إعادة تحميل الصفحة لإعادة المحاولة. من الأفضل أن يتم إغلاق هذه الاتصالات بسرعة ولكن اترك الخادم في حالة صحية بدلاً من تعليقه إلى الأبد.
لتحقيق أقصى قدر من الأداء ، يمكنك بالتأكيد تسجيل معلومات أقل. في إعداد Apache الافتراضي ، تم تعيين إعداد LogLevel على التحذير . يمكنك تغيير ذلك إلى الخطأ للاحتفاظ برسائل الخطأ فقط.
افتح ملف تكوين Apache:
sudo nano /etc/apache2/apache2.conf
ابحث عن الخط:
LogLevel warn
... وقم بتغييرها إلى:
LogLevel error
ثم احفظ الملف وأعد تشغيل Apache باستخدام:
sudo service apache2 restart
الملف الافتراضي الذي تحتفظ به Apache في السجلات هو /var/log/apache2/error.log .
إذا قمت بتشغيل موقع PHP ، فهناك احتمال كبير بأنك تستخدم وحدة mod_php. يمكن أن تتسبب هذه الوحدة في أن تستخدم كل عملية تابعة لـ Apache أكثر من 100 ميغابايت من ذاكرة الوصول العشوائي حتى إذا كانت الطلبات لموارد ثابتة مثل الصور و css و javascript.
بديل رائع هو وحدة php-fpm ، وهي عملية منفصلة تستخدم بروتوكول fastcgi. باستخدام php-fpm ، يمكن أن تنخفض ذاكرة عمليات Apache إلى 10 ميجابايت للمحتوى الثابت و 60 ميجابايت للديناميكية.
على الرغم من أنه قد يكون من الصعب قليلاً الحصول على أشياء للعمل مع هذا التغيير ، إلا أنه يستحق الجهد.
تستخدم معظم تكوينات Apache الوحدة النمطية mpm_prefork التي تعتبر آمنة لمؤشر الترابط وتستخدم عمليات تابعة متعددة مع مؤشر ترابط واحد وتعالج كل عملية اتصال واحد في كل مرة. إذا لم تكن بحاجة إلى وحدات خارجية مثل PHP أو Rails ، فيمكنك استبدالها بوحدة apache2-mpm-worker ، والتي غالبًا ما تكون أسرع. يستخدم عامل MPM عدة عمليات تابعة مع العديد من مؤشرات الترابط يعالج كل مؤشر ترابط اتصال واحد في كل مرة.
من أجل تمكين الوحدة العاملة ، يجب عليك تثبيتها.
sudo apt-get install apache2-mpm-worker
سيقوم هذا الأمر بإلغاء تثبيت mpm_prefork و mos_php وغيرها من الوحدات الإضافية غير المتوافقة.
نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول
يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".
هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.
اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.
اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.
لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟
مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.
ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!
ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.
أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد