شهریار بیات
شهریار بیات
خواندن ۲ دقیقه·۳ ماه پیش

آشنایی و بررسی اولیه ترافیک - Traefik


ترافیک (Traefik) یه reverse proxy مدرن و داینامیکه که به خاطر سادگی و ویژگی‌های قدرتمندش محبوب شده. تو این پست، یه نگاهی بهش بندازیم و با فیچر هاش یکم آشنا بشیم و ببینیم چه قابلیت هایی رو بهمون میده و ببینیم چطوری میتونیم ازش برای زیرساخت وب استفاده کنیم و همچنین تفاوت هاش و با رقیباش مثل nginx و بقیه بررسی کنیم و ببینیم چه برتری ها چه ضعف هایی در برابر اونا داره.

ترافیک ابزاریه که برای معماری‌های میکروسرویس طراحی شده. این ابزار به عنوان یه پروکسی معکوس عمل می‌کنه و بدون نیاز به کانفیگ دستی، سرویس‌های بک‌اند رو به صورت خودکار شناسایی می‌کنه و ترافیک ورودی رو بهشون هدایت می‌کنه. از ویژگی‌های اصلی ترافیک میشه به این موارد اشاره کرد:

شناسایی خودکار سرویس‌ها: ترافیک بصورت داینامیک سرویس‌های بک‌اند جدید رو شناسایی می‌کنه و به درد محیط‌های داینامیک مثل اپلیکیشن‌های کانتینری می‌خوره.

کانفیگ از طریق لیبل‌ها: از لیبل‌ها برای تعریف قوانین مسیریابی، تنظیمات لود بالانسینگ و بقیه کانفیگ‌هاش استفاده می‌کنه که کار رو توی تعریف اپ‌ها و کانتینرها خیلی راحت‌تر می‌کنه.

ادغام با Let’s Encrypt: ترافیک فرآیند دریافت و تمدید گواهینامه‌های SSL/TLS رو با ادغام مستقیم با Let’s Encrypt خیلی راحت‌تر می‌کنه. انقدر راحت که یه ایمیل از شما میگیره خودش گواهینامه ssl میگیره و تمدید میکنه.

لود بالانسینگ: ترافیک از روش‌های مختلف لود بالانسینگ مثل Round Robin و Least Connections پشتیبانی می‌کنه تا ترافیک ورودی به‌طور بهینه بین سرورهای بک‌اند توزیع بشه.

وب UI و متریک‌ها: ترافیک یه داشبورد وب کاربردی داره که به کمکش می‌تونی همه چیز رو مانیتور کنی و همچنین متریک‌هایی برای ابزارهای مانیتورینگ مثل Prometheus ارائه می‌ده.




به طور کلی، Traefik یه ابزار قدرتمنده که با ادغام بومی با پلتفرم‌های مدیریت کانتینر مثل Docker و Kubernetes، کارها رو تو محیط‌های کانتینری راحت‌تر و اتوماتیک‌تر می‌کنه.

یه قابلیت خیلی خوبی که Traefik داره اینه که با محیط‌های کلاستر و کانتینر خیلی خوب کار می‌کنه و کارهارو اتوماتیک میکنه و آسون تر میشه همه چیز. برعکس ابزارهای سنتی مثل NGINX،  ابزار Traefik خودکار با سرویس‌های کانتینری مثل Docker، Kubernetes، و Rancher سازگاره و خیلی راحت باهاشون ارتباط می‌گیره. این یعنی وقتی سرویس جدیدی اضافه می‌کنی، Traefik اتوماتیک اون رو شناسایی و کانفیگ می‌کنه.




مقایسه با nginx و caddy

وب سرور NGINX هم می‌تونه به عنوان Load Balancer و Reverse Proxy استفاده بشه. اما نسبت به Traefik، کانفیگ کردنش پیچیدگی بیشتری داره. مثلا اگه بخوای به طور خودکار یه سرویس جدید توی Docker اضافه کنی، لازمه که کانفیگ NGINX رو دستی آپدیت کنی. ولی Traefik این کار رو اتوماتیک انجام میده.

وب سرور Caddy شبیه به Traefik، یک وب سرور سبک و ساده‌ست که ویژگی‌هایی مثل SSL اتوماتیک و کانفیگ ساده رو داره. اما بیشتر برای سرویس‌های کوچک و متوسط مناسبه. اما Traefik، مخصوصا توی محیط‌های کانتینری بزرگ، مثل Kubernetes، خیلی بهتر عمل می‌کنه و امکانات بیشتری میده.

امیدوارم این پست مفید و کاربردی بوده باشه براتون

روزهای آینده تک تک فیچر های ترافیک و بررسی میکنم با مثال


ترافیک traefiknginxcaddyweb serverdevops
شهریار بیات هستم برنامه نویس مهندس نرم افزار و مدیر فنی پلتفرم هومسا علاقه مند به تکنولوزی های روز و مباحث مرتبط به SRE و devops اینجا تجربیاتمو باهاتون به اشتراک میزارم
شاید از این پست‌ها خوشتان بیاید