تو نسخههای قدیمیتر mariadb, وقتی دادهای تغییر میکرد و نیاز به ثبت اون تغییرات داشتیم، این تغییرات بهصورت undo log در سیستم جداول ذخیره میشد. حالا، تو نسخه 10.11 mariadb, داستان یه کم فرق کرده. تو این نسخه، به جای اینکه همه چیز تو یه فضای مشترک (یا همون system tablespace) نوشته بشه، سه تا فایل جداگانه برای ثبت این تغییرات در نظر گرفته شده که هر کدوم تو یه دایرکتوری جداگانه به نام innodb_undo_directory ذخیره میشن. اینجوری هم performance بالاتر میره و هم مدیریت راحتتر.
تو نسخههای قبلی، عدد پیشفرض برای innodb_undo_tablespaces صفر بود. یعنی همه تغییرات تو همون فضای اصلی ثبت میشد. ولی الان این عدد به 3 رسیده که یعنی سه تا فضای جداگانه برای ثبت این تغییرات در نظر گرفته شده. نکته مهم اینجاست که تو نسخههای قدیمیتر mariadb، بعد از ساخت دیتابیس، نمیشد این مقدار رو تغییر داد. اما تو نسخههای جدید این مشکل حل شده.
اول ببینیم undo log چی هست و چیکار میکنه؟
توی دیتابیسی مثل undo log ,mariadb بخشی از فرایند تراکنشهاست که نقش خیلی مهمی تو حفظ یکپارچگی دادهها داره. وقتی شما یه تراکنش رو اجرا میکنید، مثل insert کردن رکورد جدید، یا آپدیت کردن یا حتی حذف ، این تغییرات بهصورت موقتی ثبت میشن تا زمانی که تراکنش کامل بشه. حالا اینجا undo log وارد میشه.
وظیفه undo log اینه که در صورت بروز خطا، یا اگر به هر دلیلی تراکنش لغو بشه، بتونه تغییرات رو به حالت قبل برگردونه. به زبان سادهتر، undo log یه کپی از دادههای اصلی رو قبل از تغییرات نگه میداره. اگه مثلاً وسط یه عملیات آپدیت یه مشکل پیش بیاد یا شما بخواید تغییرات رو لغو کنید، سیستم با استفاده از این undo log برمیگرده به حالت قبلی، انگار که اصلاً هیچ تغییری انجام نشده.
این کار باعث میشه که دیتابیس همیشه در حالت پایداری باشه و اطلاعات نهایی فقط وقتی ثبت بشه که همه مراحل تراکنش به درستی انجام شده باشن. به این صورت، اگه یه مشکل غیرمنتظره پیش بیاد، اطلاعات شما از دست نمیره و دیتابیس به حالت قبلی خودش برمیگرده.
توی mariadb، این undo log ها بهصورت فایلهایی در undo tablespaces ذخیره میشن و همونطور که قبلاً گفتم، تو نسخههای جدید، شما میتونید چندین undo tablespaces داشته باشید که این کار باعث بهبود عملکرد و افزایش امنیت دادهها میشه.
حالا ببینیم چرا این تغییر مهمه
وقتی چندین undo log داریم، میتونید دادههای بیشتری رو همزمان پردازش کنید. این کار باعث میشه که سیستم با سرعت بیشتری کار کنه و در عین حال، از تداخل دادهها جلوگیری کنه. اگه تو نسخههای قدیمی، یکی از undo log ها مشکلی پیدا میکرد، کل فرآیند ممکن بود به مشکل بخوره. ولی حالا با داشتن سه تا فایل جداگانه، اگر یکی خراب بشه، دو تای دیگه هنوز سالم هستن و کار رو ادامه میدن.
از نظر فنی، وقتی شما تغییری تو دادهها ایجاد میکنید، این تغییرات اول تو undo log ثبت میشن تا اگه به هر دلیلی لازم شد، بتونید به وضعیت قبلی برگردید. حالا، وقتی این undo log ها تو سه فضای جداگانه ذخیره میشن، سیستم بهتر میتونه این تغییرات رو مدیریت کنه و اگر بخوایم برگردیم به حالت قبل، این کار سریعتر و مطمئنتر انجام میشه.
بنابراین، این تغییرات جدید تو نسخه 10.11 mariadb باعث میشه که هم کارایی بهتر بشه و هم مدیریت undo log ها راحتتر و مطمئنتر بشه. این یه ویژگی مهمه که باعث میشه دیتابیس شما با اطمینان بیشتری کار کنه و از خطرات احتمالی که ممکن بود تو نسخههای قبلی پیش بیاد، جلوگیری بشه.