Xavfsiz semantik - Safe semantics

Xavfsiz semantik a kompyuter texnikasi izchillik modeli. Bu kafolatning bir turini tavsiflaydi a ma'lumotlar registri bir necha kishi tomonidan baham ko'rilganda taqdim etadi protsessorlar a parallel kompyuter yoki birgalikda ishlaydigan kompyuterlar tarmog'ida.

Tarix

Xavfsiz semantika birinchi tomonidan aniqlangan Lesli Lamport 1985 yilda.[1] Bu Lamportning 1986 yilda "Jarayonlararo aloqa to'g'risida" da rasmiy ravishda aniqlangan.[2]

Xavfsiz registr ko'plab tarqatilgan tizimlarda joriy qilingan.

Tavsif

Xavfsiz semantika bitta yozuvchiga ega, lekin ko'p o'quvchi (SWMR) o'zgaruvchisi uchun aniqlanadi. Agar har bir o'qish jarayoni quyidagi xususiyatlarga javob bersa, SWMR registri xavfsizdir:

Xavfsiz ro'yxatdan o'tish - bir-biriga mos kelmaydi
  1. Hech qanday yozish bilan bir vaqtda bo'lmagan o'qish jarayoni eng so'nggi yozish jarayoni tomonidan yozilgan qiymatni qaytaradi.
  2. Yozish jarayoni bilan bir vaqtda o'qiladigan operatsiya registrning ruxsat berilgan qiymatlari doirasidagi har qanday qiymatni qaytarishi mumkin (masalan, 0,1,2, ...).
    xavfsiz ro'yxatga olish bilan bir-birining ustiga chiqish

Xususan, o'qish va yozish operatsiyasining bir xilligi berilgan bo'lsa, o'qish yozma tomonidan yozilmagan qiymatni qaytarishi mumkin. Qaytish qiymati faqat registr domeniga tegishli.

Ikkilik xavfsiz registrni biroz miltillovchi modellashtirish sifatida ko'rish mumkin. Registrning avvalgi qiymati qanday bo'lishidan qat'i nazar, yozish tugaguniga qadar uning qiymati miltillashi mumkin. Shuning uchun, yozish bilan bir-biriga mos keladigan o'qish 0 yoki 1 ni qaytarishi mumkin.

Churn tarqatilgan tizimga serverlarning kirishi va chiqishini bildiradi. Baldoni va boshq. shuni ko'rsatadiki, hech qanday registr yanada kuchli xususiyatga ega bo'lolmaydi muntazam semantik a sinxron tizim doimiy shovqin ostida.[3] Shu bilan birga, xavfsiz ro'yxatga olish sinxron bo'lmagan tizimda doimiy churn ostida amalga oshirilishi mumkin.[4] Saqlash xotirasi turini (Xavfsiz Ro'yxatdan o'tish) tinchlantirishsiz modellashtirish va amalga oshirish mijoz va server tizimlari kabi ba'zi tizim modellarini talab qiladi.[4] Mijoz tizimlarida server tizimini o'qish va yozish uchun mas'ul bo'lgan cheklangan, o'zboshimchalik sonli jarayonlar mavjud. Biroq, server tizimi o'qish va yozish operatsiyalari to'g'ri bajarilishini ta'minlashi kerak.

Amalga oshirish

Xavfsiz ro'yxatga olishni amalga oshirish quyidagilarni o'z ichiga oladi:

Xavfsiz ro'yxatdan o'tish faol serverlar to'plami tomonidan amalga oshiriladi.

Mijozlar ro'yxatga olish ma'lumotlari yo'q.

Oxir-oqibat sinxron tizim

Quora (server yoki mijoz tizimlari to'plami)

Quora bo'yicha bajarilgan o'qish va yozish operatsiyasining hajmi = n - f - J (n - serverlar soni, J - kiradigan va chiqadigan serverlar soni, f - soni Vizantiya muvaffaqiyatsizliklari.

Birlashtirish, o'qish va yozish kabi algoritmlar.[4]

Qo'shiling

Server (si) server tizimiga kirishni istagan boshqa serverlarga kirish to'g'risida xabar berish uchun so'rov xabarini tarqatadi, si registrning joriy qiymatini so'raydi. Boshqa serverlar ushbu so'rovni olgandan so'ng, si-ga javob xabarlarini yuborishadi. Si boshqa serverlardan etarlicha javob olgandan so'ng, javoblarni to'playdi va ularni javoblar to'plamiga saqlaydi. Si boshqa serverlardan etarlicha javoblarni (n-f-j) olguncha kutadi, so'ngra u eng ko'p qabul qilingan qiymatni tanlaydi. Si shuningdek:

  • Reyestrning mahalliy nusxasini yangilaydi
  • Faol bo'ladi
  • Javoblar to'plamidagi jarayonlarga javoblar
  • Agar u faol bo'lsa, u boshqa serverlarga javob xabarlarini yuboradi. Aks holda, u so'rovlarni saqlaydi, faollashganda javob beradi.
  • Boshqa serverlardan javob olganda, javoblar to'plamiga yangi javob qo'shiladi va eski qiymat bekor qilinadi.
  • Agar javob beradigan serverning qiymati si qiymatidan katta bo'lsa, si yangi qiymatni saqlab qoladi.

O'qing

O'qish algoritmi qo'shilishning asosiy versiyasidir. Farqi o'qish operatsiyasi tomonidan ishlatiladigan translyatsiya mexanizmidir. Mijoz (cw) tizimga xabar tarqatadi va server so'rovni qabul qilgandan so'ng, mijozga javob xabarini yuboradi. Mijoz etarli javoblarni olganidan so'ng (n-f-j) so'rov yuborishni to'xtatadi.

o'qish jarayoni

Yozing

Mijoz (cw) turli xil turlarda tizimga so'rov yuboradi va ikkita tasdiqni olguncha kutadi. (sn = tartib raqami)

yozish jarayoni
yozish jarayoni

Ikki tasdiqni olishning sababi tizimdagi xavfdan saqlanishdir. Jarayon tasdiqnoma yuborganida (ak), u bir millisekundadan keyin o'lishi mumkin. Shuning uchun mijoz tomonidan tasdiqnoma olinmaydi.

Xavfsiz registrning haqiqiyligi (agar o'qish biron bir yozish bilan mos kelmasa, yozilgan oxirgi qiymatni qaytaring) kvorum tizimiga asoslanib tasdiqlandi.[4] Ikki kvorum tizimida (Qw, Qr) berilgan Qw so'nggi qiymat haqida biladigan serverlarni, Qr esa o'qilgan javoblarning qiymatlarini bildiradi. Har bir kvorumning hajmi n-f-j ga teng.[4] Xavfsiz registrning haqiqiyligini isbotlash isbotlashni talab qiladi

edi B - Vizantiya muvaffaqiyatsizliklar soni.

Isbot: Qizil mintaqa (Qw∩Qr) B ni va ko'k mintaqa Qr∩B ni bildiradi. Taxminlarga ko'ra, har bir kvorumning hajmi n-f-j, shuning uchun qizil mintaqada n-3f-2j faol serverlari mavjud. Shuning uchun,

f dan katta.

amal qilish muddati

Izohlar

  1. ^ Lamport, Lesli (1986 yil iyun). "Jarayonlararo aloqa to'g'risida: I qism: Asosiy rasmiyatchilik" (PDF). Tarqatilgan hisoblash. 1 (2): 77–85. doi:10.1007 / BF01786227. ISSN  0178-2770.
  2. ^ Lamport, Lesli (1986 yil iyun). "Jarayonlararo aloqa to'g'risida: I qism: Asosiy formalizm". Tarqatilgan hisoblash. 1 (2): 77–85. doi:10.1007 / BF01786227. ISSN  0178-2770.
  3. ^ Baldoni, Roberto; Bonomi, Silviya; Raynal, Mishel (2012 yil yanvar). "Muntazam ravishda o'zgarishga moyil bo'lgan oxir-oqibat sinxron taqsimlangan tizimda muntazam ro'yxatga olishni amalga oshirish". Parallel va taqsimlangan tizimlarda IEEE operatsiyalari. 23 (1): 102–109. doi:10.1109 / TPDS.2011.97. ISSN  1045-9219.
  4. ^ a b v d e Baldoni, Roberto; Bonomi, Silviya; Nejad, Amir Soltani (2013 yil noyabr). "Vurushga moyil taqsimlangan tizimlarda vizantiya saqlashni amalga oshirish uchun protokol". Nazariy kompyuter fanlari. 512: 28–40. doi:10.1016 / j.tcs.2013.04.005.

Shuningdek qarang