پرش به محتوا

تریم (رایانش)

از ویکی‌پدیا، دانشنامهٔ آزاد
یک درایو حالت جامد (ssd) از شرکت سامسونگ

یک فرمان trim (شناخته شده به عنوان TRIM در مجموعه فرمان ATA و UNMAP در مجموعه فرمان SCSI) اجازه می‌دهد تا یک سیستم عامل به یک درایو حالت جامد (SSD) اطلاع دهد که بلوک‌هایی از داده دیگر در حال استفاده در نظر گرفته نمی‌شوند و می‌تواند به صورت داخلی از بین بروند.[۱]

به محض معرفی درایوهای حالت جامد (SSDs) تریم هم معرفی شد. به دلیل تفاوت بهره‌برداری سطح پایین در SSDها با دیسک‌های سخت معمولی، در SSDها راه معمولی که سیستم‌عامل عملیاتی مثل حذف یا فرمت را انجام می‌دهد، نتایج پیش‌بینی نشده‌ای در پی دارد که باعث نزول کارایی نوشتن روی SSD می‌شود.[۲] تریم کردن SSD را قادر می‌سازد تا به نحو کاراتری به جمع‌آوری زباله رسیدگی کند، در غیر این صورت عملیات نوشتن روی بلوک‌های درگیر، در آینده آهسته می‌شود.[۳]

اگر چه ابزارهایی برای «تنظیم مجدد» برخی از درایوها به حالت تازه، قبل از معرفیِ تریم کردن در دسترس قرار داشتند، اما آن‌ها همچنین همه داده‌های روی دیسک را پاک می‌کردند، که باعث می‌شود آن‌ها برای بهینه‌سازی مداوم مناسب نباشند. .[۴] در سال ۲۰۱۴ بسیاری از SSDها مکانیزم‌های جمع‌آوری زباله داخلی داشتند که به‌طور مستقل از تریم کردن کار می‌کردند. اگر چه این موضوع باعث شد تا آن‌ها حتی در صورت وجود سیستم‌عاملی که از تریم پشتیبانی نمی‌کرد، با موفقیت کارایی خود را حفظ کنند، اما اشکالاتی مرتبط با افزایش تقویت نوشتن داشتند سلول‌های فلش را فرسوده می‌کردند.[۵]

مشکل‌های خاص فلش درایو

[ویرایش]

به علت روشی که بسیاری از فایل سیستم‌ها عملیات حذف را انجام می‌دهند، (پرچم دار کردن بلوک‌های داده به عنوان "در حال استفاده نیست")،[۶][۷] رسانه‌های ذخیره‌سازی (SSDها و همچنین دیسک‌های سخت قدیمی) به‌طور کلی نمی‌دانند کدام بخش‌ها/صفحات واقعاً در استفاده هستند و کدام‌ها را می‌توان فضای آزاد در نظر گرفت. برعکس مثلاً در یک عملیات بازنویسی، عملیات حذف نمی‌خواهد درگیر نوشتن فیزیکی روی بخش‌هایی که شامل داده هاست بشود. از آنجا که یک SSD معمول، دانشی از ساختار فایل سیستم، شامل لیست بلوک‌ها/بخش‌های استفاده نشده ندارد، رسانه ذخیره‌سازی از در دسترس بودن بلوک‌ها بی‌خبر می‌ماند. در حالی که اغلب این موضوع ابزارهای بازگردانی را برای بازیابی فایل‌ها از الکترومکانیکی هارد دیسک‌ها[۸] قادر می‌سازد، با وجود این فایل‌ها به عنوان «حذف شده» توسط سیستم عامل گزارش می‌شوند، این همچنین بدان معناست که زمانی که سیستم عامل بعداً یک عملیات نوشتن روی یکی از بخش‌ها که به عنوان فضای خالی در نظر گرفته بود را انجام می‌دهد، این عملیات از دید رسانه ذخیره‌سازی به‌طور مؤثری به یک عملیات بازنویسی تبدیل می‌شود. برای دیسک مغناطیسی این عملیات با نوشتن روی یک فضای خالی هیچ تفاوتی ندارد، اما از آنجا که SSDها روی پایین‌ترین سطح عمل می‌کنند، یک بازنویسی در مقایسه با نوشتن روی فضای خالی یک سربار قابل توجه تولید می‌کند که پتانسیل ناکارا کردن عملیات نوشتن را دارد.[۹]

SSDها داده‌ها را در سلول‌های حافظه فلش ذخیره می‌کنند که معمولاً در صفحات ۴ تا ۱۶ کیلوبایتی دسته‌بندی شده‌اند، این دسته‌ها در بلوک‌های ۱۲۸ تا ۵۱۲ صفحه‌ای دسته‌بندی شده‌اند، برای مثال، ۵۱۲ کیلوبایت به ازای هر سلول با ۴ کیلوبایت صفحه در بلوک‌های ۱۲۸ صفحه‌ای. در حافظه‌های فلش NAND سلول‌ها تنها می‌تواند به‌طور مستقیم نوشته شوند تنها در زمانی که آن‌ها خالی است. اگر آن‌ها احتمالاً حاوی اطلاعات باشند، اطلاعات باید قبل از عملیات نوشتن، پاک شوند. یک عملیات نوشتن در SSD می‌تواند در یک صفحه انحام شود، اما با توجه به محدودیت‌های سخت‌افزاری، دستورات پاک کردن همیشه تمام بلوک‌ها را تحت تأثیر قرار می‌دهد؛[۱۰] در نتیجه نوشتن داده‌ها در صفحات خالی در یک SSD بسیار سریع است، اما در صورت نیاز به بازنویسی روی صفحاتی که از پیش روی آن‌ها نوشته شده‌است، عملیات کند می‌شود. از آنجا که قبل از نوشتن، نیاز به پاک کردن سلول‌ها وجود دارد، و فقط کل بلوک‌ها را می‌توان پاک کرد، یک بازنویسی یک چرخه خواندن-پاک کردن-تغییر-نوشتن را آغاز می‌کند:[۱۱] محتویات تمام بلوک‌ها در کَش ذخیره می‌شوند، سپس کل بلوک از SSD پاک می‌شود، سپس صفحه بازنویسی شده، در بلوک کَش شده نوشته می‌شود، و تنها پس از آن می‌توان تمام بلوک جدید را روی رسانه فلش نوشت. این پدیده به عنوان تقویت نوشتن شناخته شده‌است.[۱۲][۱۳]

عملیات

[ویرایش]

دستور TRIM سیستم عامل را قادر می‌سازد تا صفحاتی را که دیگر داده معتبر در خود ندارند را به SSD اطلاع دهد. برای یک عملیات حذف فایل، سیستم عامل فایل‌ها و بخش‌ها را به عنوان «آزاد برای داده جدید» علامت گذاری می‌کند، سپس یک دستور TRIM را به SSD ارسال می‌کند. پس از تریم، زمانی SSD که داده جدید را در حافظه فلش می‌نویسد، هیچ اطلاعاتی را از بلوک حفظ نمی‌کند، در نتیجه تقویت نوشتن کمتر (نوشتن کمتر)، و توان بالاتر ایجاد می‌شود (نیازی به توالی خواندن-پاک کردن-تغییر-نوشتن نیست)، در نتیجه طول عمر درایو بیشتر می‌شود.

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

تریم به SSD می‌گوید که یک محدوده LBA (LOOSE balls & attachments) را غیر معتبر علامت گذاری کند، در نتیجه خواندن از آن محدوده، هیچ داده معناداری را برنمی‌گرداند. با این حال، داده می‌تواند همچنان در حافظه فلش به صورت داخلی وجود داشته باشد. یک forensicist ممکن است قادر به بازگردانی داده‌های تریم شده باشد.

منابع

[ویرایش]
  1. "Intel High Performance Solid State Drive - Advantages of TRIM". Intel.com. Intel. 2010-09-14. Retrieved 2012-02-21.
  2. Shimpi, Anand Lal (2009-03-18). "The SSD Anthology". AnandTech.com. p. 4. Retrieved 2010-06-19.
  3. Shimpi, Anand Lal. (2009-03-18). p. 10.
  4. Shimpi, Anand Lal. (2009-03-18). p. 11.
  5. "Kingston SSDNow V Plus 100 Review". AnandTech.com. Anand Lal Shimpi. 2010-11-11. Retrieved 2010-12-10.
  6. Savill, John (2009-04-21). "I heard solid-state disks (SSDs) suffer from a decline in write performance as they're used. Why?". WindowsITPro. Archived from the original on 30 June 2012. Retrieved 2010-06-19.
  7. Shimpi, Anand Lal. (2009-03-18). p. 7.
  8. Savill, John (2009-04-22). "What is the TRIM function for solid-state disks (SSDs) and why is it important?". WindowsITPro. Archived from the original on 9 February 2013. Retrieved 2010-06-19.
  9. Malventano, Allyn (13 February 2009). "Long-term performance analysis of Intel Mainstream SSDs". PC Perspective. Archived from the original on 28 February 2012. Retrieved 10 February 2012.
  10. Shimpi, Anand Lal. (2009-03-18). p. 5.
  11. Shimpi, Anand Lal. (2009-03-18). p. 8.
  12. "Write Amplification: Intel's Secret Sauce". ExtremeTech.com. Archived from the original on 15 November 2010. Retrieved 2010-11-06.
  13. "Inside the X25-M Controller: Wear Leveling, Write Amplification Control". TomsHardware.com. 2008-09-08. Retrieved 2010-11-06.