Mangle در میکروتیک ابزاری قدرتمند برای تغییر یا علامتگذاری بستههای ترافیکی است و معمولاً برای مدیریت پهنای باند، کیفیت سرویس (QoS) و اعمال سیاستهای مسیریابی خاص (Policy Routing) استفاده میشود. Mangle در فایروال میکروتیک به شما اجازه میدهد که بستههای ترافیک شبکه را قبل از اینکه در روتر پردازش شوند، علامتگذاری کرده و ویژگیهای آنها را تغییر دهید تا بتوانید قوانین پیچیدهتری اعمال کنید.
کاربردهای Mangle در میکروتیک
علامتگذاری بستهها (Packet Marking) با Mangle در میکروتیک
علامتگذاری بستهها برای اعمال قوانین بعدی، یکی از کاربردهای Mangle در میکروتیک است. مثل کنترل پهنای باند یا فیلتر کردن ترافیک. در زیر مثالی آورده ایم که نشان میدهد چطور میتوان بستههای مربوط به پروتکل HTTP را علامتگذاری کرد.
/ip firewall mangle add chain=prerouting protocol=tcp dst-port=80 action=mark-packet new-packet-mark=http_traffic
این قانون تمام ترافیک HTTP را علامتگذاری کرده و به آن یک برچسب به نام “http_traffic” میدهد. این برچسب میتواند در قوانین بعدی برای کنترل پهنای باند یا فیلتر ترافیک استفاده شود.
علامتگذاری اتصالها (Connection Marking) با Mangle در میکروتیک
اتصالها را علامتگذاری میکند و میتوانید برای مجموعهای از بستهها (که یک اتصال خاص را تشکیل میدهند) قوانین خاص اعمال کنید. در این اینجا مثالی هست که با آن اتصالهای مربوط به FTP علامتگذاری میشوند تا بعداً بتوانید پهنای باند آن را مدیریت کنید:
/ip firewall mangle add chain=prerouting protocol=tcp dst-port=21 action=mark-connection new-connection-mark=ftp_conn
این قانون تمام اتصالهای FTP را علامتگذاری کرده و به آنها برچسب “ftp_conn” میدهد. این برچسب برای مدیریت پهنای باند یا مسیریابی استفاده میشود.
تنظیم TTL (Time To Live) با Mangle در میکروتیک
تغییر مقدار TTL بستهها برای کنترل نحوه عبور بستهها از روتر و تعداد روترهایی که یک بسته میتواند از آنها عبور کند. در زیر برای تغییر TTL بستهها با استفاده از Mangle در میکروتیک یک مثال مشاهده میکنید. مثلاً برای کاهش بار ترافیکی روی شبکه میتوان از دستور زیر استفاده کرد:
/ip firewall mangle add chain=postrouting action=change-ttl new-ttl=set:128
این قانون TTL بستههای خروجی از روتر را به 128 تغییر میدهد.
Pre-routing و Post-routing
با استفاده از Mangle در میکروتیک میتوان برای تغییر بستهها در مراحل مختلف پردازش ترافیک استفاده کرد. دو مرحله بسیار مهم در پردازش بستهها، Pre-routing و Post-routing هستند. در مرحله Pre-routing، بستهها قبل از اینکه توسط روتر مسیریابی شوند، پردازش میشوند. در مرحله Post-routing، بستهها پس از مسیریابی و قبل از خروج از روتر پردازش میشوند.
Pre-routing
این مرحله قبل از اینکه بستهها وارد فرآیند مسیریابی روتر شوند، اعمال میشود. اینجا میتوانید بر اساس مبدا یا مقصد بستهها، تغییرات یا علامتگذاریهایی روی بستهها انجام دهید.
Post-routing
این مرحله پس از اینکه بستهها مسیریابی شدند، اما قبل از اینکه از روتر خارج شوند، اعمال میشود. این مرحله مناسب برای اعمال تغییرات نهایی بر روی بستهها مانند تغییر TTL یا انجام NAT است.
در این قسمت برای آشنایی بیشتر با گزینه های action موجود در Mangle میکروتیک به توضیح آنها پرداخته ایم:
accept: پردازش بسته را متوقف میکند و اجازه میدهد که به مقصد خود برود.
add dst to address list: آدرس مقصد بسته را به لیست آدرسهای مشخص شده اضافه میکند.
add src to address list: آدرس مبدأ بسته را به لیست آدرسهای مشخص شده اضافه میکند.
change DSCP (TOS): تغییر DSCP (Differentiated Services Code Point) بسته برای اعمال اولویتبندی.
change MSS: تغییر Maximum Segment Size برای بستههای TCP.
change TTL: تغییر Time To Live برای بستهها.
clear DF: پاک کردن بیت DF (Don’t Fragment) در بستههای IP.
fasttrack connection: فعال کردن قابلیت FastTrack برای بستههای مشخصشده (برای بهینهسازی عملکرد).
jump: به زنجیره دیگری بپرید تا پردازش بیشتری انجام شود.
log: ثبت بستهها در لاگ برای بررسی.
mark connection: علامتگذاری روی یک اتصال.
mark packet: علامتگذاری روی یک بسته.
mark routing: علامتگذاری برای مسیریابی بستهها.
passthrough: اجازه میدهد پردازش بسته در زنجیره بعدی ادامه پیدا کند.
return: به زنجیره قبلی بازمیگردد.
route: مشخص کردن مسیری خاص برای بستهها.
set priority: تنظیم اولویت برای بسته.
sniff PC/TZSP: شروع به ضبط بستهها برای تحلیل.
strip IPv4 options: حذف گزینههای خاص در بستههای IPv4.
مثال عملی برای استفاده از Mangle در میکروتیک
مدیریت و مسیریابی ترافیک شبکه داخلی با استفاده از Pre-routing و Post-routing
فرض کنید دو لینک اینترنت دارید (ISP1 و ISP2) و میخواهید ترافیک شبکه داخلی (192.168.1.0/24) را از طریق ISP1 ارسال کنید و ترافیک یک سرویس خاص (مثل FTP) را از طریق ISP2 مسیریابی کنید. برای این کار از Pre-routing و Post-routing استفاده میکنیم.
مرحله اول: علامتگذاری بستهها در Pre-routing
در این مرحله، ما بستههای شبکه داخلی (192.168.1.0/24) و بستههای مربوط به سرویس FTP (پورت 21) را علامتگذاری میکنیم تا بعداً بتوانیم آنها را به مسیرهای مختلف هدایت کنیم.
/ip firewall mangle add chain=prerouting src-address=192.168.1.0/24 action=mark-routing new-routing-mark=to_ISP1
/ip firewall mangle add chain=prerouting protocol=tcp dst-port=21 action=mark-routing new-routing-mark=to_ISP2
توضیح دستور بالا
در قانون اول تمام بستههایی که از شبکه داخلی 192.168.1.0/24 میآیند، با برچسب to_ISP1 علامتگذاری میشوند. این به معنای این است که ما میخواهیم این ترافیک از طریق ISP1 ارسال شود.
در قانون دوم بستههایی که از پروتکل FTP استفاده میکنند (پورت 21) با برچسب to_ISP2 علامتگذاری میشوند و قرار است از ISP2 مسیریابی شوند.
مرحله دوم: اعمال مسیریابی بر اساس برچسبها
حال که بستهها را علامتگذاری کردهایم، میتوانیم از Routing Table استفاده کنیم تا ترافیک را از مسیرهای مختلف هدایت کنیم.
/ip route add gateway=ISP1_Gateway routing-mark=to_ISP1
/ip route add gateway=ISP2_Gateway routing-mark=to_ISP2
توضیح دستورات بالا
در قانون اول بستههایی که با to_ISP1 علامتگذاری شدهاند، از طریق درگاه ISP1 مسیریابی میشوند.
در قانون دوم بستههایی که با to_ISP2 علامتگذاری شدهاند (ترافیک FTP)، از طریق درگاه ISP2 مسیریابی میشوند.
مرحله سوم: تغییر بستهها در Post-routing
در این مرحله، بستهها قبل از خروج از روتر، پردازش نهایی میشوند. به عنوان مثال، میخواهیم مقدار TTL بستههای خروجی از ISP1 را تغییر دهیم.
/ip firewall mangle add chain=postrouting routing-mark=to_ISP1 action=change-ttl new-ttl=set:64
توضیح دستور بالا
این قانون مقدار TTL بستههای خروجی که از طریق ISP1 (علامتگذاری شده با to_ISP1) عبور میکنند را به 64 تنظیم میکند. تغییر TTL میتواند برای جلوگیری از حملات یا کاهش بار روی شبکه استفاده شود.
کنترل پهنای باند و مدیریت ترافیک با استفاده از Mangle در میکروتیک
با علامتگذاری بستهها میتوانید اقدام به کنترل پهنای باند و ترافیک کاربران کنید. این بخش در کنار Queue Trees استفاده میشود.
در این مثال، ترافیک مربوط به HTTP علامتگذاری شده و سپس پهنای باند آن توسط Queue Treesمحدود میشود. این کار را باید در دو مرحله انجام دهید:
مرحله اول: علامتگذاری ترافیک HTTP
/ip firewall mangle add chain=prerouting protocol=tcp dst-port=80 action=mark-packet new-packet-mark=http_traffic
مرحله دوم: ایجاد Queue برای مدیریت پهنای باند
/queue tree add name=”http_traffic_queue” parent=global packet-mark=http_traffic limit-at=1M max-limit=2M
در اینجا ابتدا ترافیک HTTP علامتگذاری شده و سپس در مرحله دوم یک Queue تعریف شده که پهنای باند ترافیک HTTP را به 1 مگابیت در ثانیه محدود میکند و در صورت نیاز میتواند تا 2 مگابیت برود.
از Mangle در میکروتیک برای تنظیم مسیریابی بر اساس قوانین مشخص استفاده میشود. مثلاً میتوانید ترافیک مشخصی را از یک رابط (interface) خاص عبور دهید. فرض کنید میخواهید ترافیک شبکه داخلی (192.168.1.0/24) را از طریق یک لینک اینترنت خاص هدایت کنید برای این کار میتوانید از روش زیر استفاده کنید:
/ip firewall mangle add chain=prerouting src-address=192.168.1.0/24 action=mark-routing new-routing-mark=link1
این قانون ترافیک شبکه داخلی را علامتگذاری میکند تا بعداً از طریق مسیر خاصی مسیریابی شود.
سربرگ Mangle در میکروتیک ابزاری بسیار کاربردی برای مدیریت و کنترل پیشرفته ترافیک است. از طریق آن میتوانید بستههای ترافیکی را علامتگذاری کنید، تغییر دهید و سیاستهای خاص مسیریابی و پهنای باند را اعمال کنید.
نظر خود را در مورد این مقاله بنویسید