View in Telegram
یه مقاله جذاب در مورد نوشتن کد سریع از Shopify درسته که درباره Ruby on Rails نوشته شده اما اکثر نکاتش به خیلی از زبان و فریمورک های دیگه از جمله گولنگ هم قابل تعمیم دادن هست. دقت کنید که Shopify در یک مقیاس خیلی بزرگ کار میکنه و نکاتش مهمه. کدی که با Ruby on Rails نوشته میشه معروفه به کند بودن اما در Shopify در مقیاس میلیون درخواست در دقیقه داره از Ruby on Rails استفاده میشه تو این مقاله نکات جالبی رو اشاره میکنه برای اینکه کد سریعتری نوشته بشه اولین نکته ش در مورد ORM یا همون ActiveRecord هست که باید درک کنید توابع مختلف orm چه رفتاری با دیتابیس دارند. تو گولنگ همین مشکل با gorm وجود داره که به شدت میتونه لود زیادی روی دیتابیس بندازه بدون اینکه برنامه نویس متوجه این قضیه بشه. دومین نکته ش باز در مورد دیتابیس هست که میگه از select * پرهیز کنید و فقط ستون هایی که لازم دارید رو انتخاب کنید. نکته دیگه پرهیز از کوئری زدن به ستون هایی هست که index ندارن و در مقیاس بالا باعث میشه که full scan رخ بده البته ایندکس اضافه کردن باعث lock شدن دیتابیس ممکنه بشه برای writeها و باید مواظب مایگریشن ایندکس باشیم نکته بعدی کش کردن همه چیز هست… Cache All The Things If you can’t make something faster, a good alternative is to cache it. Things like complex view compilation and external API calls benefit greatly from caching. Especially if the resultant data doesn’t change often. یه سری چیزارو میشه throttle کرد Throttle Bottlenecks But what about operations you can’t cache? Things like delivering an email, sending a webhook, or even logging in can be abused by users of an application. Essentially, any expensive operation that can’t be cached should be throttled. برای یه سری پروسه ها هم میشه job queue و مکانیزم های async در نظر گرفت Do It Later (In a Job) Jobs allow us to defer work to another process through queueing systems often backed by Redis. Exporting a dataset, activating a subscription, or processing a payment are all great examples of job-worthy work پرهیز از متاپروگرمینگ Use Metaprogramming Sparingly Changing a program’s structure at runtime is a powerful feature. In a highly dynamic language like Ruby, there are significant performance costs associated to metaprogramming. دونستن تفاوت O(1) و O(n) برای مقیاس پذیر بودن خیلی مهمه Know the difference between O(n) and O(1) What O(n) and O(1) mean is that there are two kinds of operations. O(n) is an operation that scales in time with size, and O(1) is one that is constant in time regardless of size. مثلا جای آرایه بهتره از hash استفاده بشه چون lookup کردن تو hash فارغ از اندازه O(1) هست Allocate Less استفاده و مدیریت Garbage Collector If used improperly, dangerous methods can lead to unwanted side effects in your code. A best practice to follow is to avoid mutating global state while leveraging mutation on local state. https://shopify.engineering/write-fast-code-ruby-rails ✍️👩‍💻 @BarnamNavisi
Please open Telegram to view this post
VIEW IN TELEGRAM
Love Center - Dating, Friends & Matches, NY, LA, Dubai, Global
Love Center - Dating, Friends & Matches, NY, LA, Dubai, Global
Find friends or serious relationships easily