إطلاق العنان لقدرات Linux الكامنة: دليل شامل لضبط النواة (Kernel Tuning)

استمع للبودكاست حوار شيق بين لمى وأبو عمر
0:00 / 0:00

مقدمة: قصة خادم تائه في بحر البيانات

بتذكر مرة، كنت شغال على مشروع كبير، خادم ويب بستقبل آلاف الطلبات في الدقيقة. كل شي كان تمام التمام في البداية، بس مع زيادة عدد المستخدمين، بلش الخادم يتصرف بغرابة. صار بطيء، وبرجع أخطاء غريبة، ومرات حتى بتوقف بالمرة. 😠

قعدت أيام وليالي وأنا بدور على المشكلة، عملت فحص لكل جزء في الكود، راجعت قواعد البيانات، بس ما لقيت شي! لحد ما خطر ببالي أراقب موارد النظام. وهون كانت المفاجأة! الخادم كان بستنفذ كل الموارد المتاحة، وبالذات عدد الملفات المفتوحة والاتصالات.

هون اكتشفت إنه إعدادات النواة الافتراضية مش كافية لتحمل هاد الكم من الضغط. وقتها، بدأت رحلة تعلم ضبط النواة (Kernel Tuning)، واليوم بدي أشارككم خبرتي بهالموضوع. 😎

ما هو ضبط النواة (Kernel Tuning)؟

النواة (Kernel) هي قلب نظام التشغيل Linux. هي المسؤولة عن إدارة الموارد، والتعامل مع الأجهزة، وتوفير واجهة للتطبيقات. نظام Linux بيجي بإعدادات افتراضية بتناسب الاستخدام العام، بس لما يكون عندك خادم بشتغل تحت ضغط عالي، لازمك تعدل هالإعدادات لتناسب احتياجاتك. هاد هو ضبط النواة!

معالجة حدود الملفات والاتصالات

في عالم Linux، كل شي هو ملف. يعني حتى الاتصال بالشبكة بعتبر ملف. الإعداد الافتراضي لعدد الملفات المفتوحة غالباً ما بيكون قليل (عادةً 1024). لما خادمك يحاول يفتح ملف رقم 1025، راح يفشل!

زيادة عدد الملفات المفتوحة (fs.file-max و ulimit)

أول خطوة هي زيادة الحد الأقصى لعدد الملفات المفتوحة على مستوى النظام. بتقدر تعدل قيمة `fs.file-max` في ملف `sysctl.conf`:


sudo nano /etc/sysctl.conf

أضف السطر التالي:


fs.file-max = 655350

بعدين شغل الأمر التالي لتطبيق التغييرات:


sudo sysctl -p

كمان لازم تعدل الحد الأقصى لعدد الملفات المفتوحة لكل مستخدم. بتقدر تعمل هيك عن طريق تعديل ملف `limits.conf`:


sudo nano /etc/security/limits.conf

أضف الأسطر التالية:


* soft nofile 65535
* hard nofile 65535

**نصيحة:** تأكد انك تعمل restart للـ session تبعك (logout ثم login) عشان التغييرات تتفعل.

زيادة حجم طابور الاتصالات المعلقة (net.core.somaxconn)

لما يجي طلب اتصال جديد (SYN)، النظام بحطه في طابور لحد ما تطبيقك (مثلاً Node.js) يقبله. إذا الطابور فل، الاتصالات الجديدة راح تترفض. لزيادة حجم الطابور، عدل قيمة `net.core.somaxconn`:


sudo nano /etc/sysctl.conf

أضف السطر التالي:


net.core.somaxconn = 65535

بعدين شغل الأمر التالي:


sudo sysctl -p

إدارة دورة حياة TCP

بروتوكول TCP مصمم ليكون حذر، وبخلي الاتصال المغلق في حالة `TIME_WAIT` لفترة طويلة (ممكن توصل لدقائق) لضمان وصول أي حزم متأخرة. في الخوادم المزدحمة، هاد الشي ممكن يؤدي لاستنفاد المنافذ المتاحة (Ephemeral Ports).

تفعيل إعادة استخدام المنافذ (net.ipv4.tcp_tw_reuse)

تفعيل `net.ipv4.tcp_tw_reuse` بسمح للنواة بإعادة استخدام المنافذ بسرعة للاتصالات الجديدة الصادرة. هاد مهم جداً لما يكون خادمك بتصل بقواعد البيانات أو الخدمات الخلفية بكثافة.


sudo nano /etc/sysctl.conf

أضف السطر التالي:


net.ipv4.tcp_tw_reuse = 1

بعدين شغل الأمر التالي:


sudo sysctl -p

**تحذير:** لا تستخدم `net.ipv4.tcp_tw_recycle`! ممكن يسبب مشاكل اتصال خطيرة للمستخدمين الي بستخدموا نفس عنوان IP (خلف NAT). هاي الخاصية تم ازالتها من النواة بسبب خطورتها.

تحسين مخازن الشبكة المؤقتة (TCP Buffers)

عشان تحصل على أقصى إنتاجية (Throughput)، وبالذات مع الملفات الكبيرة أو العملاء الي عندهم سرعات عالية، لازم تزيد حجم الذاكرة المخصصة لمخازن القراءة والكتابة لبروتوكول TCP (`tcp_rmem` و `tcp_wmem`).


sudo nano /etc/sysctl.conf

أضف الأسطر التالية:


net.ipv4.tcp_rmem = 4096 87380 33554432
net.ipv4.tcp_wmem = 4096 87380 33554432

بعدين شغل الأمر التالي:


sudo sysctl -p

الأرقام هاي بتمثل: الحد الأدنى، القيمة الافتراضية، والحد الأقصى لحجم المخزن المؤقت. بتقدر تعدلهم حسب احتياجاتك.

**نصيحة:** راقب استهلاك الذاكرة الكلي للخادم عشان تتأكد انك ما بتستهلك كل الموارد المتاحة.

خلاصة

ضبط النواة (Kernel Tuning) هو عملية مهمة جداً لتحسين أداء خوادم Linux، وبالذات الخوادم الي بتشتغل تحت ضغط عالي. من خلال تعديل بعض المعلمات، بتقدر تزيد عدد الملفات المفتوحة، وتحسن إدارة الاتصالات، وتزيد إنتاجية الشبكة. تذكر، كل خادم له احتياجاته الخاصة، لهيك لازم تجرب وتراقب الأداء بعد كل تغيير. 👍

**نصيحة أخيرة:** قبل ما تعمل أي تغيير، اعمل نسخة احتياطية من ملف `sysctl.conf`! عشان تقدر ترجع للإعدادات الأصلية إذا صار أي مشكلة. بالتوفيق! 🚀

أبو عمر

سجل دخولك لعمل نقاش تفاعلي

كافة المحادثات خاصة ولا يتم عرضها على الموقع نهائياً

آراء من النقاشات

لا توجد آراء منشورة بعد. كن أول من يشارك رأيه!

آخر المدونات

التوظيف وبناء الهوية التقنية

سيرتي الذاتية عبرت فلتر الـ ATS لكنها فشلت أمام المدير التقني: كيف أعدت بناءها لتتحدث لغة المهندسين؟

من واقع تجربة شخصية، أسرد لك كيف تحوّل سيرتك الذاتية من مجرد قائمة مهارات يتجاهلها المديرون التقنيون إلى قصة إنجازات مُقنعة تفتح لك أبواب المقابلات....

28 فبراير، 2026 قراءة المزيد
التوسع والأداء العالي والأحمال

خدمة واحدة فاشلة كادت أن تسقط النظام بأكمله: كيف أنقذني نمط ‘قاطع الدائرة’ (Circuit Breaker) من كارثة متتالية؟

أتذكر ذلك اليوم جيداً، حين كادت خدمة واحدة أن تتسبب في انهيار نظامنا بالكامل في ليلة نهاية أسبوع مزدحمة. في هذه المقالة، أشارككم قصة حقيقية...

27 فبراير، 2026 قراءة المزيد
اختبارات الاداء والجودة

لقد ‘هاجمت’ تطبيقي بنفسي عمداً: كيف كشفت لي ‘هندسة الفوضى’ نقاط الضعف التي لم تظهرها الاختبارات التقليدية

أشارككم قصة حقيقية حول إطلاق فاشل كاد أن يدمر سمعتنا، وكيف قادتنا هذه التجربة المريرة إلى تبني "هندسة الفوضى" (Chaos Engineering). اكتشفوا معنا كيف يمكن...

26 فبراير، 2026 قراءة المزيد
التوسع والأداء العالي والأحمال

عاصفة من الطلبات كادت أن تغرق تطبيقي: كيف أنقذتني طوابير الرسائل (Message Queues) من كارثة الجمعة السوداء؟

أشارككم قصة حقيقية من قلب المعركة في يوم الجمعة السوداء، وكيف تحولت كارثة محققة في أداء تطبيقي إلى نجاح باهر بفضل مفهوم بسيط وقوي اسمه...

24 فبراير، 2026 قراءة المزيد
البودكاست