cgroups و namespaces دو مکانیسم اساسی کرنل لینوکس هستند که به شما امکان میدهند منابع سیستم را محدود، مدیریت و جداسازی کنید. cgroups، namespaces، جداسازی فرایندها، مدیریت منابع لینوکس، افزایش امنیت کانتینرها. در این مقاله به طور کامل به کاربرد cgroups و namespaces، تفاوتها، نحوه کارکرد، نمونههای عملی و موارد استفاده در دنیای کانتینرها و میزبانی پرداختهام تا خواننده بتواند از آن در پروژههای واقعی استفاده کند.

-
namespaces چیست و چرا مهم است؟
Namespaces سازوکاری است که فضاهای نام مستقل برای منابع سیستم ایجاد میکند. با namespaces میتوانید فضای فرآیندها، شبکه، میزبان، کاربران و موارد دیگر را جدا کنید. این جداسازی به شما کمک میکند چندین محیط ایزوله روی یک هسته اجرا شوند و از تداخل بین آنها جلوگیری شود. namespaces نقش کلیدی در ساخت کانتینرها دارد و باعث میشود هر کانتینر احساس کند سیستم اختصاصی خود را دارد. -
انواع namespaces و کاربرد هر کدام
- PID namespace: شمارندههای فرایند را ایزوله میکند تا هر فضا PIDهای خود را داشته باشد.
- Network namespace: استک شبکه را جدا میکند و برای ایجاد رابطهای مجازی و سوییچهای داخلی کاربرد دارد.
- Mount namespace: نقاط مونت را ایزوله میکند تا سیستم فایل هر محیط متفاوت باشد.
- UTS namespace: نام میزبان و دامنه را جدا میکند.
- IPC namespace: منابع ارتباط بین فرایندی را جدا میکند.
- User namespace: کاربران و شناسههای UID/GID را ایزوله میکند و سطح دسترسی را امنتر میسازد.
هر کدام از این namespaces را میتوان بر اساس نیاز ترکیب یا جداگانه به کار برد. انتخاب صحیح نوع namespace به سناریوی شما بستگی دارد: جداسازی فرایندها، ایزولهسازی شبکه یا محدودیت سطح دسترسی. توضیحات و مثالهای عملی در ادامه کمک میکند انتخاب مناسب انجام دهید.
-
cgroups چیست و چه کاری انجام میدهد؟
cgroups (کنترل گروپها) قابلیتی در کرنل است که به شما اجازه میدهد مصرف منابع مانند CPU، حافظه، I/O و شبکه را برای گروهی از فرایندها محدود یا اولویتبندی کنید. شما میتوانید با استفاده از cgroups میزان مصرف CPU را محدود کنید، حافظه مشخصی اختصاص دهید یا محدودیتهای I/O تعیین کنید تا سرویسهای حساس از منابع کافی برخوردار باشند. در عمل، cgroups به مدیران سیستم کنترل دقیقی میدهد تا از ناپایداری و تداخل خدمات جلوگیری کنند. -
زیرسیستمهای مهم در cgroups
- cpu: تعیین سهم CPU بین گروهها و اولویتبندی اجرا.
- memory: محدود کردن استفاده از حافظه و جلوگیری از مصرف بیش از حد که منجر به OOM میشود.
- blkio: کنترل میزان I/O دیسک برای هر گروه.
- net_cls و net_prio: برچسبگذاری و اولویتبندی ترافیک شبکه.
- cpuset: تخصیص هستههای CPU به گروهها برای بهینهسازی کارایی.
به کمک این زیرسیستمها میتوانید برای هر سرویس یا کانتینر سیاست مشخص منابع تعیین کنید و رفتار کلی سرویسدهی را قابل پیشبینی نگه دارید.
-
ترکیب namespaces و cgroups در ساخت کانتینرها
ترکیب namespaces و cgroups هستهی تکنولوژی کانتینرها مانند Docker و Podman است. namespaces محیط ایزوله را فراهم میکند و cgroups مصرف منابع آن محیط را کنترل میکند. این ترکیب اجازه میدهد کانتینرها سبک، قابل حمل و ایزوله باشند بدون نیاز به ماشینهای مجازی سنگین. در نتیجه، توسعه و استقرار سرویسها سریعتر و هزینهها کمتر میشود.افزایش امنیت کانتینرها -
نمونههای عملی و دستورات پایه
برای ایجاد یک network namespace میتوانید از ip netns استفاده کنید. برای مدیریت cgroups میتوانید از systemd یا ابزارهایی مانند cgcreate و cgexec بهره ببرید. مثال سریع:
- ساخت cgroup با cgcreate و اجرای فرآیند با cgexec:
cgcreate -g memory,cpu:/webgroup
cgset -r memory.limit_in_bytes=500M webgroup
cgexec -g cpu,memory:webgroup /usr/bin/myservice - ایجاد network namespace و متصل کردن veth:
ip netns add ns1
ip link add veth0 type veth peer name veth1
ip link set veth1 netns ns1
ip netns exec ns1 ip addr add 192.168.100.2/24 dev veth1
این مثالها راهنمای عملیای برای شروع پیادهسازی هستند و در محیطهای تولید باید با تنظیمات امنیتی و مانیتورینگ ترکیب شوند.
-
مزایا و محدودیتها
مزایا:
- استفاده بهینه از منابع و کاهش هزینه سختافزار.
- جداسازی امنیتی بین سرویسها و محدود کردن اثر یک سرویس روی دیگر.
- اجرای سریعتر و مصرف کمتر نسبت به ماشینهای مجازی.
- کنترل دقیق روی عملکرد و اولویتبندی.
محدودیتها:
- نیاز به دانش فنی و درک عمیق از کرنل و ابزارهای مرتبط.
- پیکربندی نادرست میتواند ریسک امنیتی ایجاد کند.
- برخی قابلیتها نیازمند نسخههای جدید کرنل یا ماژولهای خاص هستند.
-
بهترین کاربردها و سناریوها
- میزبانی چند سرویس جدا روی یک سرور فیزیکی با تضمین اختصاص منابع.
- اجرای محیطهای توسعه ایزوله برای تیمهای توسعه.
- محدود کردن سرویسهای پرمصرف تا سایر سرویسها تحت تأثیر قرار نگیرند.
- استفاده در پلتفرمهای کلود و سرویسهای میزبانی مدیریتشده.
-
امنیت و رعایت اصول
استفاده از user namespace باعث میشود که کانتینرها توانایی اجرای عملیات با دسترسی ریشه در میزبان را نداشته باشند. با ترکیب سیاستهای امنیتی مانند SELinux یا AppArmor میتوانید سطح ایمنی را افزایش دهید. حتماً لاگها و محدودیتها را پایش کنید تا نفوذ یا استفاده نادرست سریع تشخیص داده شود. روند امنسازی باید شامل آزمونهای نفوذ و بررسی مجوزها باشد. -
یکپارچگی با systemd و ابزار مدیریت سرویس
systemd بهطور داخلی از cgroups برای مدیریت سرویسها استفاده میکند. این یکپارچگی به مدیران سیستم اجازه میدهد سرویسها را با محدودیت منابع و سیاستهای روشن اجرا کنند. Docker، Podman و Kubernetes همین رویکرد را گسترش میدهند تا مقیاسپذیری و مدیریت منابع در سطح کلستر فراهم شود.محدودیت منابع در لینوکس -
مثال پیادهسازی عملی برای سرور میزبانی
برای یک سرور میزبانی وب، میتوانید برای هر سایت یا مشتری یک cgroup و network namespace جدا بسازید و منابع CPU و حافظه مشخصی اختصاص دهید. این کار تضمین میکند که یک سایت پرمصرف، سایر سایتها را تحت تأثیر قرار ندهد. علاوه بر این، میتوانید محدودیتهای I/O را تنظیم کنید تا ترافیک دیسک نیز منصفانه توزیع شود. -
وان سرور و کاربرد cgroups و namespaces
وان سرور (One3erver) میتواند از cgroups و namespaces برای ارائه سرویسهای VPS و کانتینر مدیریتشده استفاده کند. با پیادهسازی این فناوریها، وان سرور تضمین میکند که هر VPS منابع مشخصی دارد، امنیت تقویت شده و عملکرد پایدار ارائه میشود. سرویسهای مرتبط شامل VPS ایزوله، میزبانی کانتینری، مدیریت منابع سفارشی و مانیتورینگ لحظهای است که مناسب شرکتها و توسعهدهندگان است. -
دستورالعملهای مفصل خط فرمان
برای کار عملی با namespaces و cgroups از دستورات زیر استفاده کنید:
- نمایش namespaces فعال: ls -l /proc/*/ns/
- ایجاد network namespace و اتصال به آن: ip netns add ns1 … (مراحل بالاتر)
- ایجاد cgroup با systemd: systemctl set-property myservice.service CPUShares=512 MemoryLimit=500M
- استفاده از cgcreate و cgexec برای گروهبندی و اجرای سرویسها.
-
مانیتورینگ، پایش و رفع اشکال
برای اطمینان از کارکرد صحیح محدودیتها، باید مانیتورینگ داشته باشید. ابزارهایی مانند top، htop، systemd-cgtop و cgroupfs اطلاعات مصرف را نشان میدهند. میتوانید با Prometheus و Grafana متریکهای cgroups را جمعآوری و داشبورد بسازید. در رفع اشکال رایج: اگر فرآیندها خارج از cgroup اجرا میشوند، مطمئن شوید از cgexec یا unit های systemd استفاده کردهاید. اگر OOM رخ میدهد، memory.limit_in_bytes را تنظیم کنید و swap را بررسی کنید. برای مشکلات شبکه مسیر veth و تنظیمات فایروال را بازبینی کنید. -
مثال پیشرفته: ترکیب با Kubernetes
Kubernetes از cgroups و namespaces برای مدیریت کانتینرها استفاده میکند. kubelet منابع را با cgroups مدیریت میکند و هر پاد در فضای نام خود اجرا میشود. این مدل اجازه میدهد سرویسها بر اساس درخواست منابع مقیاسپذیر باشند و سیاستهای QoS اعمال شوند. -
مزایای اقتصادی و عملیاتی
استفاده از این ابزارها هزینههای سختافزاری را کاهش میدهد چون میتوانید چند سرویس را امن روی یک سرور فیزیکی اجرا کنید. زمان استقرار کاهش مییابد و مدیریت منابع سادهتر میشود. -
چکلیست قبل از تولید
- بررسی نسخه کرنل و پشتیبانی از زیرسیستمها.
- تعریف واضح برای کاربرد cgroups و namespaces.
- تنظیم سیاستهای احراز هویت و لاگگذاری.
- راهاندازی مانیتورینگ و هشدارها برای افزایش امنیت کانتینرها.
- تست بار و سنجش عملکرد قبل از تولید.

