Comparthing Logo
اشکال زداییسیستم‌های توزیع‌شدهزیرساخت ابریمشاهده پذیریمهندسی نرم‌افزارتوسعه‌دهندگان

اشکال‌زدایی سیستم‌های توزیع‌شده در مقابل اشکال‌زدایی سیستم‌های محلی

اشکال‌زدایی سیستم‌های توزیع‌شده، به بررسی خرابی‌ها در چندین ماشین و سرویس شبکه‌ای می‌پردازد، در حالی که اشکال‌زدایی سیستم محلی بر مشکلات درون یک ماشین یا برنامه واحد تمرکز دارد. هر رویکرد، ابزارها، مدل‌های ذهنی و استراتژی‌های متفاوتی را برای جداسازی و حل مؤثر مشکلات می‌طلبد.

برجسته‌ها

  • اشکال‌زدایی توزیع‌شده، رویدادها را پس از وقوع بازسازی می‌کند؛ اشکال‌زدایی محلی به شما امکان می‌دهد تا مکث کرده و وضعیت زنده را بررسی کنید.
  • عدم اطمینان شبکه و خرابی‌های جزئی، اشکال‌زدایی توزیع‌شده را اساساً دشوارتر از کار محلی می‌کند.
  • ابزارهای مشاهده‌پذیری جایگزین اشکال‌زداهای تعاملی به عنوان لنز اصلی برای سیستم‌های توزیع‌شده می‌شوند.
  • اشکال‌زدایی محلی برای مسائل تک‌فرآیندی و گردش‌های کاری توسعه، سریع‌تر و شهودی‌تر باقی می‌ماند.

اشکال‌زدایی سیستم‌های توزیع‌شده چیست؟

عمل تشخیص و رفع خرابی‌ها در چندین سرویس، ماشین و مرز شبکه به هم پیوسته در یک معماری توزیع‌شده.

  • برای پیگیری درخواست‌ها در سراسر مرزهای سرویس، به شدت به ابزارهای ردیابی توزیع‌شده مانند Jaeger، Zipkin و OpenTelemetry متکی است.
  • اغلب به شناسه‌های همبستگی و گزارش‌گیری ساختاریافته برای کنار هم قرار دادن رویدادها از سرویس‌های مستقل نیاز دارد.
  • تأخیر شبکه، خرابی‌های جزئی و ثبات نهایی، تحلیل ریشه‌ای مشکلات را به طور قابل توجهی سخت‌تر از تنظیمات یکپارچه می‌کند.
  • ابزارهایی مانند پلتفرم‌های مهندسی آشوب (Chaos Monkey، Gremlin) معمولاً برای شناسایی پیشگیرانه‌ی حالت‌های خرابی توزیع‌شده استفاده می‌شوند.
  • ارکان مشاهده‌پذیری - معیارها، لاگ‌ها و ردپاها - ضروری هستند زیرا اشکال‌زدایی گام‌به‌گام سنتی به ندرت در بین ماشین‌ها کار می‌کند.

اشکال‌زدایی سیستم محلی چیست؟

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

  • معمولاً از اشکال‌زداهای تعاملی مانند GDB، LLDB، pdb یا ابزارهای یکپارچه با IDE برای مکث اجرا و بررسی وضعیت استفاده می‌کند.
  • برای برنامه‌های تک‌رشته‌ای یا تک‌پردازشی که حالت کامل در یک فضای حافظه قرار دارد، به خوبی کار می‌کند.
  • تولید مثل باگ‌ها معمولاً ساده است زیرا محیط محدود و قطعی است.
  • اشکال‌زدایی چاپ، چارچوب‌های ثبت وقایع و ردیابی پشته‌ها همچنان رایج‌ترین تکنیک‌ها برای عیب‌یابی روزمره هستند.
  • پروفایلرهای عملکردی مانند perf، Valgrind یا پروفایلرهای مختص زبان، مستقیماً به فرآیند در حال اجرا متصل می‌شوند.

جدول مقایسه

ویژگی اشکال‌زدایی سیستم‌های توزیع‌شده اشکال‌زدایی سیستم محلی
محدوده سرویس‌ها، ماشین‌ها و جهش‌های شبکه‌ای چندگانه یک فرآیند، دستگاه یا برنامه کاربردی
ابزارهای اولیه ردیابی توزیع‌شده، تجمیع لاگ، پلتفرم‌های مشاهده‌پذیری اشکال‌زداهای تعاملی، پروفایلرها، دستورات چاپ
تکرارپذیری به دلیل زمان‌بندی، خرابی‌های جزئی و تغییرپذیری شبکه، دشوار است عموماً در یک محیط کنترل‌شده، سرراست است
قابلیت مشاهده ایالت برای بازسازی به شناسه‌های همبستگی و ثبت وقایع متمرکز نیاز دارد وضعیت کامل در زمان اجرا در حافظه قابل دسترسی است
حالت‌های خرابی پارتیشن‌های شبکه، انحراف ساعت، خرابی‌های آبشاری، ناسازگاری داده‌ها اشاره‌گرهای تهی، نشت حافظه، خطاهای منطقی، از کار افتادن‌ها
الزامات مهارتی تفکر سیستمی، دانش شبکه‌سازی، تخصص در رصدپذیری تسلط به زبان، آشنایی با دیباگر، کدخوانی
هزینه از کارافتادگی زیاد - بسیاری از کاربران و سرویس‌های پایین‌دستی را تحت تأثیر قرار می‌دهد پایین‌تر - معمولاً محدود به توسعه‌دهنده یا کاربر واحد
رویکرد اشکال‌زدایی فرضیه‌محور، اغلب گذشته‌نگر از گزارش‌ها و ردپاها تعاملی، گام به گام یا مبتنی بر نقطه شکست

مقایسه دقیق

فلسفه اصلی و مدل ذهنی

اشکال‌زدایی محلی فرض می‌کند که شما می‌توانید جهان را متوقف کنید و هر اتفاقی را که درون یک فرآیند واحد رخ می‌دهد، بررسی کنید. مدل ذهنی خطی است: کد اجرا می‌شود، به یک نقطه توقف می‌رسد و شما متغیرها را بررسی می‌کنید. اشکال‌زدایی توزیع‌شده این را برعکس می‌کند زیرا شما نمی‌توانید ناوگانی از سرویس‌ها را بدون از کار انداختن سیستم متوقف کنید. در عوض، شما با استفاده از گزارش‌ها، ردیابی‌ها و معیارها، آنچه را که پس از وقوع اتفاق افتاده است، بازسازی می‌کنید، که مستلزم یک روش اساساً متفاوت برای تفکر در مورد علیت است.

ابزار و ابزار دقیق

یک توسعه‌دهنده که کار محلی انجام می‌دهد، ممکن است Visual Studio Code را اجرا کند، یک نقطه توقف تعیین کند و کد را خط به خط بررسی کند. در یک محیط توزیع‌شده، این تجمل از بین می‌رود. مهندسان برای ابزار دقیق به ابزارهایی مانند OpenTelemetry، برای تجسم ردیابی به Jaeger یا Honeycomb و برای جمع‌آوری گزارش‌ها به پلتفرم‌هایی مانند Datadog یا Grafana Loki متکی هستند. سرمایه‌گذاری در ابزار دقیق از قبل اتفاق می‌افتد، اغلب در خود کد برنامه تعبیه شده است، نه اینکه در صورت تقاضا اضافه شود.

تولید مثل و جداسازی حشرات

وقتی یک اشکال به صورت محلی ظاهر می‌شود، معمولاً می‌توانید کد را دوباره اجرا کنید و شاهد شکست دوباره آن باشید. سیستم‌های توزیع‌شده به ندرت به این شکل همکاری می‌کنند. یک وضعیت رقابتی ممکن است فقط تحت تأخیر شبکه خاصی ایجاد شود، یا یک مشکل مسمومیت با حافظه پنهان ممکن است به زمان‌بندی در سه مرکز داده بستگی داشته باشد. مهندسان اغلب نمی‌توانند شرایط دقیق را بازتولید کنند، بنابراین برای نزدیک شدن به شکست اصلی، به بازپخش ترافیک تولید، محیط‌های سایه یا آزمایش‌های هرج و مرج متکی هستند.

بررسی عملکرد و تأخیر

پروفایلرهای محلی مانند perf یا async-profiler تصویر واضحی از محل صرف زمان یا حافظه CPU در یک فرآیند به شما می‌دهند. مشکلات عملکرد توزیع‌شده پیچیده‌تر هستند - یک درخواست کند ممکن است به مکث جمع‌آوری زباله در یک سرویس، یک پرس‌وجوی کند پایگاه داده در سرویس دیگر و لرزش شبکه بین آنها برگردد. ردیابی توزیع‌شده به کنار هم قرار دادن این موارد کمک می‌کند، اما تفسیر نتایج مستلزم درک کل مسیر درخواست است نه یک پشته فراخوانی تابع واحد.

همکاری تیمی و اشتراک دانش

اشکال‌زدایی محلی اغلب یک فعالیت انفرادی است - یک توسعه‌دهنده، یک دستگاه، یک جلسه اشکال‌زدایی. اشکال‌زدایی توزیع‌شده معمولاً یک ورزش تیمی است. وقتی یک سرویس پرداخت از کار می‌افتد، ممکن است به مهندسان backend، SREها، مدیران پایگاه داده و متخصصان شبکه نیاز داشته باشید که همگی به داشبوردهای یکسانی نگاه کنند. بررسی‌های پس از حادثه و دفترچه‌های راهنمای مشترک بسیار مهم می‌شوند زیرا هیچ‌کس به تنهایی تصویر کاملی از یک سیستم پیچیده ندارد.

مزایا و معایب

اشکال‌زدایی سیستم‌های توزیع‌شده

مزایا

  • + خطاهای پیچیده چند سرویسی را مدیریت می‌کند
  • + قابلیت مقیاس‌پذیری در محیط‌های تولیدی
  • + تست آشوب پیشگیرانه را فعال می‌کند
  • + دانش عمیق سیستم‌ها را ایجاد می‌کند

مصرف شده

  • منحنی یادگیری شیب‌دار
  • نیاز به ابزار دقیق سنگین
  • بازتولید مسائل دشوار است
  • هزینه‌های بالاتر ابزارسازی

اشکال‌زدایی سیستم محلی

مزایا

  • + حلقه‌های بازخورد سریع
  • + الزامات ابزار ساده
  • + تکثیر آسان حشرات
  • + عالی برای یادگیری کدبیس‌ها

مصرف شده

  • محدود به فرآیندهای تکی
  • اشکالات مربوط به شبکه را از دست می‌دهد
  • غیر واقع‌بینانه از نظر تولید
  • از نظر مشکلات همزمانی ضعیف است

تصورات نادرست رایج

افسانه

اشکال‌زدایی توزیع‌شده، همان اشکال‌زدایی محلی است که روی ماشین‌های بیشتری اعمال می‌شود.

واقعیت

این دو رویکرد اساساً با هم تفاوت دارند. اشکال‌زدایی محلی به توقف اجرا و بررسی حافظه متکی است که در یک سیستم توزیع‌شده غیرممکن است. اشکال‌زدایی توزیع‌شده نیازمند بازسازی وضعیت از روی لاگ‌ها، ردپاها و معیارها پس از اجرا است و به مهارت‌ها، ابزارها و مدل‌های ذهنی متفاوتی نیاز دارد.

افسانه

اگر به صورت محلی کار کند، در محیط تولید نیز کار خواهد کرد.

واقعیت

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

افسانه

لاگ‌های بیشتر همیشه اشکال‌زدایی را آسان‌تر می‌کنند.

واقعیت

ثبت بیش از حد داده‌ها باعث ایجاد نویز می‌شود، هزینه‌های ذخیره‌سازی را افزایش می‌دهد و در واقع می‌تواند سیستم‌ها را کند کند. اشکال‌زدایی توزیع‌شده‌ی مؤثر به گزارش‌های ساختاریافته و هم‌بسته با سطوح شدت مناسب بستگی دارد، نه فقط حجم آنها. دانستن اینکه چه چیزی را و چه زمانی ثبت کنید، خود یک مهارت است.

افسانه

ردیابی توزیع‌شده جایگزین ثبت وقایع سنتی می‌شود.

واقعیت

ردیابی‌ها و گزارش‌ها اهداف مکملی را دنبال می‌کنند. ردیابی‌ها مسیر و زمان‌بندی یک درخواست را در بین سرویس‌ها نشان می‌دهند، در حالی که گزارش‌ها جزئیات زمینه، خطاها و منطق کسب‌وکار را در هر سرویس ثبت می‌کنند. اکثر تیم‌ها از هر دو به عنوان بخشی از یک استراتژی مشاهده‌پذیری گسترده‌تر استفاده می‌کنند.

افسانه

اشکال‌زدایی محلی در عصر میکروسرویس‌ها منسوخ شده است.

واقعیت

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

سوالات متداول

بزرگترین چالش در اشکال‌زدایی سیستم‌های توزیع‌شده چیست؟
سخت‌ترین بخش معمولاً بازسازی علیت در سرویس‌هایی است که به طور مستقل اجرا می‌شوند. یک درخواست کاربر ممکن است ده‌ها سرویس را تحت تأثیر قرار دهد و وقتی چیزی با شکست مواجه می‌شود، باید بفهمید کدام سرویس باعث ایجاد مشکل شده و چرا. تأخیر شبکه، تلاش‌های مجدد و پردازش ناهمزمان، این کار را بسیار دشوارتر از اشکال‌زدایی یک برنامه واحد می‌کند که در آن می‌توانید مراحل اجرا را به ترتیب طی کنید.
آیا می‌توان از یک اشکال‌زدای سنتی در سیستم‌های توزیع‌شده استفاده کرد؟
نه واقعاً به معنای سنتی. شما می‌توانید یک اشکال‌زدا را به یک نمونه سرویس واحد متصل کنید، اما نمی‌توانید کل یک سیستم توزیع‌شده را بدون از کار انداختن آن متوقف کنید. در عوض، مهندسان از ردیابی توزیع‌شده، گزارش‌گیری ساختاریافته و معیارها برای مشاهده رفتار استفاده می‌کنند. برخی از تنظیمات پیشرفته از تکنیک‌هایی مانند اشکال‌زدایی سفر در زمان یا ابزارهای اشکال‌زدایی در مرحله تولید استفاده می‌کنند، اما اینها تخصصی هستند و عادی نیستند.
برای اشکال‌زدایی سیستم‌های توزیع‌شده به چه مهارت‌هایی نیاز دارم؟
فراتر از کدنویسی، شما به درک کاملی از مفاهیم شبکه مانند TCP، DNS و تعادل بار نیاز دارید. آشنایی با ابزارهای مشاهده‌پذیری مانند Prometheus، Grafana، Jaeger یا OpenTelemetry ضروری است. همچنین باید به جای توابع منفرد، به صورت سیستمی فکر کنید، نحوه‌ی وقوع خطاها را درک کنید و نحوه‌ی استدلال در مورد حالت‌های جزئی را بیاموزید.
آیا اشکال‌زدایی محلی هنوز برای برنامه‌های ابری بومی مفید است؟
کاملاً. اشکال‌زدایی محلی هنوز سریع‌ترین راه برای درک منطق کد، رفع اشکالات ساده و توسعه ویژگی‌های جدید است. اکثر تیم‌ها قبل از استقرار سرویس‌های تکی، آنها را به صورت محلی اشکال‌زدایی می‌کنند. نکته این است که بدانید چه زمانی به ابزارهای اشکال‌زدایی توزیع‌شده روی آورید - معمولاً زمانی که مشکل شامل تعاملات بین سرویس‌ها می‌شود یا فقط در محیط‌های شبیه به تولید ظاهر می‌شود.
مشاهده‌پذیری چیست و چرا برای اشکال‌زدایی توزیع‌شده اهمیت دارد؟
قابلیت مشاهده، توانایی درک وضعیت داخلی یک سیستم از خروجی‌های خارجی آن است - که عمدتاً شامل لاگ‌ها، معیارها و ردیابی‌ها می‌شود. در سیستم‌های توزیع‌شده، شما نمی‌توانید وضعیت داخلی را مستقیماً بررسی کنید، بنابراین این سه رکن به چشم و گوش شما تبدیل می‌شوند. بدون قابلیت مشاهده خوب، اشکال‌زدایی سیستم‌های توزیع‌شده به جای مهندسی، به حدس و گمان تبدیل می‌شود.
چگونه شناسه‌های همبستگی در اشکال‌زدایی توزیع‌شده کمک می‌کنند؟
شناسه همبستگی، شناسه منحصر به فردی است که به یک درخواست در حین جریان آن از طریق چندین سرویس متصل می‌شود. هر ورودی لاگ، محدوده ردیابی یا پیام خطا شامل این شناسه است و به مهندسان اجازه می‌دهد تا مسیر کامل یک درخواست واحد را در کل سیستم مشاهده کنند. بدون شناسه‌های همبستگی، شما باید لاگ‌های سرویس‌های مختلف را بر اساس زمان به صورت دستی به هم بچسبانید، که این کار کند و مستعد خطا است.
مهندسی آشوب چیست و چه ارتباطی با اشکال‌زدایی دارد؟
مهندسی آشوب، عملی است که در آن عمداً خرابی‌هایی - مانند از بین بردن نمونه‌ها، تزریق تأخیر یا تقسیم‌بندی شبکه‌ها - را معرفی می‌کنند تا ببینند سیستم‌ها چگونه واکنش نشان می‌دهند. ابزارهایی مانند Chaos Monkey، Litmus و Gremlin به تیم‌ها کمک می‌کنند تا نقاط ضعف را قبل از ایجاد قطعی‌های واقعی کشف کنند. بینش‌های به‌دست‌آمده مستقیماً به کتابچه‌های راهنمای اشکال‌زدایی بهتر و معماری‌های مقاوم‌تر کمک می‌کنند.
معمولاً چقدر طول می‌کشد تا یک مشکل سیستم توزیع‌شده اشکال‌زدایی شود؟
این موضوع به شدت متفاوت است. مسائل ساده‌ای مانند پیکربندی نادرست متعادل‌کننده بار ممکن است چند دقیقه طول بکشد، در حالی که خرابی‌های پیچیده آبشاری می‌توانند ساعت‌ها یا حتی روزها طول بکشند. مطالعات صنعتی نشان می‌دهد که مهندسان بخش قابل توجهی از وقت خود - گاهی اوقات 20٪ یا بیشتر - را صرف وظایف عملیاتی از جمله اشکال‌زدایی می‌کنند. به همین دلیل است که سرمایه‌گذاری روی قابلیت مشاهده خوب به سرعت نتیجه می‌دهد.
نقش مش‌های سرویس در اشکال‌زدایی توزیع‌شده چیست؟
شبکه‌های سرویس مانند Istio یا Linkerd بین سرویس‌ها قرار می‌گیرند و ارتباطات، تلاش‌های مجدد و قابلیت مشاهده را به طور خودکار مدیریت می‌کنند. آن‌ها معیارها و ردیابی‌های دقیقی را برای هر درخواست بدون نیاز به تغییر در کد برنامه ایجاد می‌کنند. این امر اشکال‌زدایی را بسیار آسان‌تر می‌کند زیرا شما بدون توجه به اینکه از چه زبان یا چارچوبی استفاده می‌کنید، در تمام سرویس‌ها تله‌متری (دورسنجی) ثابتی خواهید داشت.
آیا باید در محیط تولید اشکال‌زدایی کنم یا در محیط آزمایشی؟
هر زمان که ممکن است، در محیط‌های آزمایشی یا محلی اشکال‌زدایی کنید تا از تأثیر بر کاربران جلوگیری شود. با این حال، برخی از اشکالات فقط به دلیل مقیاس، داده‌های واقعی یا شرایط منحصر به فرد شبکه در محیط عملیاتی ظاهر می‌شوند. در این موارد، تکنیک‌های ایمن مانند پرچم‌های ویژگی، استقرار قناری و ابزارهای اشکال‌زدایی فقط خواندنی، امکان بررسی را بدون خطر آسیب بیشتر فراهم می‌کنند. نکته کلیدی این است که قبل از نیاز به قابلیت مشاهده، آن را در محل خود داشته باشید.

حکم

وقتی روی یک برنامه واحد کار می‌کنید، در حال نمونه‌سازی ویژگی‌های جدید هستید یا مسائلی را بررسی می‌کنید که به وضوح در یک پایگاه کد وجود دارند، اشکال‌زدایی سیستم محلی را انتخاب کنید. هر زمان که معماری شما شامل چندین سرویس، کانتینر یا مرکز داده می‌شود، به ویژه هنگامی که خرابی‌ها شامل زمان‌بندی، شبکه یا ارتباط بین سرویس‌ها می‌شوند، به سراغ اشکال‌زدایی سیستم‌های توزیع‌شده بروید. در عمل، اکثر مهندسان مدرن به تسلط در هر دو نیاز دارند، زیرا حتی میکروسرویس‌ها اغلب اجزایی دارند که از تکنیک‌های اشکال‌زدایی سنتی بهره‌مند می‌شوند.

مقایسه‌های مرتبط

AWS در مقابل Google Cloud

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

آموزش یادگیری ماشینی مبتنی بر محاسبات لبه‌ای در مقابل آموزش یادگیری ماشینی مبتنی بر ابر

محاسبات لبه‌ای یادگیری ماشینی (ML) استنتاج را مستقیماً روی دستگاه‌های محلی اجرا می‌کند و تأخیر و استفاده از پهنای باند را کاهش می‌دهد، در حالی که آموزش یادگیری ماشینی مبتنی بر ابر، از سرورهای قدرتمند از راه دور برای ساخت و اصلاح مدل‌های عظیم استفاده می‌کند. هر رویکرد متناسب با مراحل مختلف چرخه عمر یادگیری ماشینی و تقاضاهای عملیاتی مختلف است.

استراتژی‌های ذخیره‌سازی در سیستم‌های یادگیری ماشینی در مقابل محاسبات بر اساس تقاضا

استراتژی‌های ذخیره‌سازی در سیستم‌های یادگیری ماشین، خروجی‌های مدل از پیش محاسبه‌شده یا داده‌های میانی را برای تسریع پرس‌وجوهای مکرر ذخیره می‌کنند، در حالی که محاسبات بر اساس تقاضا، هر بار نتایج تازه‌ای تولید می‌کنند و سرعت را فدای سادگی و سربار ذخیره‌سازی کمتر می‌کنند.

برنامه‌ریزی زیرساخت بلاکچین در مقابل برنامه‌ریزی زیرساخت ابری

برنامه‌ریزی زیرساخت بلاکچین بر طراحی شبکه‌های غیرمتمرکز و توزیع‌شده با دفترکل‌های تغییرناپذیر و سازوکارهای اجماع تمرکز دارد، در حالی که برنامه‌ریزی زیرساخت ابری بر ساخت منابع محاسباتی مقیاس‌پذیر و بر اساس تقاضا از طریق ارائه‌دهندگان متمرکز مانند AWS، Azure و Google Cloud متمرکز است.

بهره‌وری شبکه در سیستم‌های یادگیری ماشینی در مقابل بهره‌وری محاسبات در سیستم‌های یادگیری ماشینی

کارایی شبکه بر سرعت انتقال داده‌ها بین پردازنده‌های گرافیکی (GPU)، سرورها و فضای ذخیره‌سازی در طول آموزش توزیع‌شده تمرکز دارد، در حالی که کارایی محاسباتی، میزان اثربخشی منابع سخت‌افزاری مانند پردازنده‌های گرافیکی (GPU) و پردازنده‌های محاسباتی چند لایه (TPU) را در انجام عملیات ریاضی واقعی اندازه‌گیری می‌کند. هر دو برای مقیاس‌بندی حجم کار هوش مصنوعی مدرن حیاتی هستند، اما اساساً به گلوگاه‌های متفاوتی در زیرساخت‌های یادگیری ماشین می‌پردازند.