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

أبو عمر

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

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

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

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

آخر المدونات

ادارة الفرق والتنمية البشرية

من جحيم الاعتماد على شخص واحد إلى ذاكرة فريق جماعية: قصة نجاحنا مع سجلات قرارات الهندسة (ADRs)

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

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

فريقنا كان يغرق في النقرات: كيف أنقذتنا ‘أتمتة العمليات الروبوتية’ (RPA) من جحيم المهام اليدوية؟

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

15 أبريل، 2026 قراءة المزيد
ذكاء اصطناعي

نماذجنا اللغوية كانت تهلوس: كيف أنقذنا ‘الاسترجاع المعزز للتوليد’ (RAG) من جحيم الإجابات الخاطئة؟

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

15 أبريل، 2026 قراءة المزيد
خوارزميات

حساباتنا كانت تعيد اختراع العجلة: كيف أنقذتنا البرمجة الديناميكية من جحيم التكرار؟

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

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

ميزانيتنا كانت تتبخر: كيف أنقذتنا ‘نماذج الإحالة المبنية على البيانات’ من جحيم تخمين عائد الاستثمار؟

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

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