إطلاق العنان لقدرات 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`! عشان تقدر ترجع للإعدادات الأصلية إذا صار أي مشكلة. بالتوفيق! 🚀

أبو عمر

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

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

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

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

آخر المدونات

تجربة المستخدم والابداع البصري

كل زر بلون مختلف وكل أيقونة بقصة: كيف أنقذني ‘نظام التصميم’ (Design System) من فوضى الواجهات؟

أشارككم قصة من قلب المعركة، كيف انتقلنا من فوضى الألوان والأزرار المتضاربة في مشاريعنا إلى التناغم والكفاءة. هذه المقالة هي دليلك العملي لفهم وبناء "نظام...

18 مارس، 2026 قراءة المزيد
الحوسبة السحابية

كل نقرة في لوحة التحكم كانت قنبلة موقوتة: كيف أنقذتني ‘البنية التحتية كشيفرة’ (IaC) من كارثة محققة؟

أشارككم قصة حقيقية عن كارثة كادت أن تدمر مشروعاً كاملاً بسبب نقرة خاطئة في لوحة التحكم السحابية. اكتشفوا كيف أنقذتني منهجية "البنية التحتية كشيفرة" (IaC)...

17 مارس، 2026 قراءة المزيد
التوظيف وبناء الهوية التقنية

مقابلاتي السلوكية كانت كارثة: كيف أنقذتني طريقة STAR من أسئلة ‘حدثنا عن موقف صعب…؟’

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

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

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

أشارككم قصة حقيقية من قلب المعركة البرمجية، حيث كادت خدمة واحدة بطيئة أن تُسقط نظامنا بالكامل. سأشرح لكم بالتفصيل نمط "قاطع الدائرة" (Circuit Breaker)، وكيف...

16 مارس، 2026 قراءة المزيد
التكنلوجيا المالية Fintech

كنا نخزن بطاقات الائتمان مباشرة… قصة تسريب بيانات وكيف أنقذني الترميز (Tokenization)

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

15 مارس، 2026 قراءة المزيد
أتمتة العمليات

استيقظتُ في الثالثة فجراً لإعادة تشغيل سيرفر: كيف علّمتُ نظامي أن يشفي نفسه بنفسه عبر الأتمتة؟

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

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