استفاده از قابلیت ISR
ISR یا Incremental Static Regeneration یک ویژگی در NextJS است که به شما اجازه میدهد تا صفحات استاتیک را به صورت انتخابی و بدون نیاز به بازسازی کل سایت، بهروزرسانی کنید. این قابلیت ترکیبی از مزایای Static Site Generation (SSG) و انعطافپذیری Server-Side Rendering (SSR) را ارائه میدهد. در واقع، عملکرد ISR به شکل زیر است:
- ساخت تدریجی صفحات: صفحات استاتیک میتوانند پس از بیلد اولیه سایت، در صورت نیاز (با request کاربر)، build یا بهروز شوند.
- پیکربندی از طریق revalidate: شما میتوانید زمانبندی بهروزرسانی صفحات را با استفاده از ویژگی revalidate تعیین کنید. برای مثال، اگر مقدار revalidate را برابر با ۱۰ قرار دهید، صفحه هر ۱۰ ثانیه یکبار بهروزرسانی میشود.
- پاسخدهی سریع: در زمان درخواست کاربر، نسخه موجود در کش به سرعت ارائه میشود و بهروزرسانیها به صورت پسزمینه انجام میشوند.
همانطور که گفته شد، ISR امکان بهروزرسانی صفحات استاتیک بهصورت انتخابی و بدون نیاز به بازسازی کل سایت را فراهم میکند. این کار با استفاده از یک ویژگی کلیدی به نام revalidate در متد getStaticProps انجام میشود. مقدار revalidate تعیین میکند که یک صفحه استاتیک چه زمانی نیاز به بازسازی در پسزمینه دارد. زمانی که کاربران از صفحهای بازدید میکنند، اگر زمان تعیینشده در revalidate گذشته باشد، یک نسخه جدید از صفحه ساخته میشود، در حالی که کاربران همچنان نسخه قدیمی را مشاهده میکنند.
در این فرآیند، NextJS از کش (Cache) برای ارائه سریع نسخه موجود صفحه استفاده میکند. این باعث میشود تا کاربران تجربه سریعی داشته باشند، حتی اگر دادههای صفحه در حال بهروزرسانی باشد. هنگامی که فرآیند بازسازی کامل شد، نسخه جدید جایگزین نسخه قدیمی میشود و برای درخواستهای بعدی ارائه خواهد شد. این ویژگی برای وبسایتهایی که شامل محتوای متغیر یا صفحات زیادی هستند، مانند فروشگاههای آنلاین یا سایتهای خبری، بسیار ایدهآل است.
نحوه استفاده
مثال زیر نحوه پیادهسازی ISR را نشان میدهد. این کد دادهها را از یک API فرضی دریافت کرده و هر ۱۰ ثانیه، صفحه را بهروز میکند:
در پروژههای واقعی ممکن است دادهها ناقص باشند یا API به درستی پاسخ ندهد. در چنین مواردی، میتوانید مانند قطعه کد زیر، عمل کنید:
نحوه استفاده در لیارا
از آنجایی که فضای نوشتن در حالتِ پیشفرضِ Writable، متغیر است و در حالت فایلسیستم ReadOnly فضایی برای نوشتن وجود ندارد؛ ممکن است که به افزایش فضا برای ذخیرهسازی صفحات ساخته شده مبتنی بر ISR، نیاز داشته باشید. برای این کار کافیست تا طبق مراحل زیر، عمل کنید:
ایجاد دیسک
طبق مستندات ساخت دیسک، یک دیسک با نام و اندازه دلخواه ایجاد کنید.
تعریف مسیر برای دیسک
طبق مستندات تعریف مسیر دیسک، دیسک ایجاد شده را به مسیر next/server/pages. متصل کنید.
با انجام کارهای فوق، فضای پوشه مدنظر، افزایش خواهد یافت.
در صورتی که به دایرکتوری اشاره شده، دیسک متصل نکرده باشید و فایلسیستم بر روی Writable باشد، با هر بار استقرار جدید یا ریاستارت شدن برنامه، تمامی فایلهای cache شده، حذف میشوند.