ISCSI muvofiqligini sinash va sinov vositalariga talab - ISCSI Conformance Testing and Testing Tool Requirement

iSCSI muvofiqligini sinovdan o'tkazish iSCSI Initiator / Target iSCSI standartiga mos kelishini aniqlash uchun sinovdan o'tkazmoqda.

SCSI va iSCSI protokoli

Kichik kompyuter tizimining interfeysi (SCSI ) - bu kiritish-chiqarish moslamalari, ayniqsa saqlash qurilmalari bilan aloqa qilish uchun protokollar oilasi. SCSI mijoz-server modeliga asoslangan. "Tashabbuskorlar" deb nomlangan SCSI mijozlari "maqsad" deb nomlanuvchi serverning tarkibiy qismlari, mantiqiy bo'linmalaridan xizmatlarni so'rash uchun SCSI buyruqlarini beradilar. "SCSI transporti" mijoz-server SCSI protokolini ma'lum bir o'zaro bog'lanish uchun xaritalaydi. Tashabbuskor - bu SCSI transportining bir so'nggi nuqtasi, va boshqa bir so'nggi nuqta.

Internet kichik kompyuter tizimining interfeysi (iSCSI ) protokoli SCCP tashish sifatida TCP / IP dan foydalanadi. SCSI paketlarini TCP / IP orqali tashish orqali iSCSI mavjud bo'lgan Internet-infratuzilma, Internetni boshqarish vositalari va masofadagi cheklovlarga murojaat qilish uchun birgalikda ishlaydigan echimlarni taqdim etadi. An'anaviy Fiber Kanaldan farqli o'laroq, bu maxsus maqsadli kabellarni talab qiladi, iSCSI mavjud tarmoq infratuzilmasida ishlaydi. Uning miqyosi va iqtisodiy foydalari tufayli u mashhur xotira tarmog'i (SAN) protokoliga aylandi. Protokol RFC 3720 va yangilangan RFC 5048.

iSCSI muvofiqligini sinovdan o'tkazish

SCSI transport qatlamining an'anaviy ishonchli avtobus tuzilmasidan ancha ishonchsiz TCP / IP tarmog'iga o'tishi bilan iSCSI-ga juda murakkablik kiritildi:

  • Kirish / chiqish jarayonlari kerak.
  • Kirish paytida xavfsizlik / operatsion parametrlarni muhokama qilish kerak.
  • Kirish paytida CHAP yoki boshqa autentifikatsiya qilish usulidan foydalanish mumkin.
  • Bir nechta seanslar / ulanishlar talab qilinishi mumkin.
  • Bir nechta xatolarni tiklash darajasi amalga oshirilishi mumkin.
  • ...

Bir so'z bilan aytganda, iSCSI-ning iqtisodiy qiymati boshqalarnikidan past bo'lishi mumkin bo'lsa-da, protokolning o'zi bu qadar oddiy emas.

Protokol tasdiqlangandan beri, iSCSI doimiy ravishda oxirgi foydalanuvchilar va saqlash sotuvchilari tomonidan qabul qilinmoqda. Bugungi kunda bozorda iSCSI tashabbuskorlari / maqsadli dasturlari juda ko'p yoki tijorat yoki bepul / ochiq manbalar mavjud. Ushbu dasturlar funktsional imkoniyatlari va protokolga muvofiqligi bilan farq qiladi.

Muvofiqlikni sinovdan o'tkazish tizim ba'zi bir standartlarga javob berishini aniqlash uchun sinovdan o'tkazmoqda. Ko'pincha tashqi tashkilotlar, ba'zida standartlar idorasi tomonidan amalga oshiriladi, ularga muvofiqlikning katta kafolatlari beriladi. Bunday usulda sinovdan o'tgan mahsulotlar keyinchalik ushbu tashqi tashkilot tomonidan standartga muvofiq sertifikatlangan deb e'lon qilinadi. ISCSI protokoli (yoki boshqa ma'lumotlar tarmoqlari va saqlash protokollari) uchun The Nyu-Xempshir universiteti o'zaro ishlash laboratoriyasi (UNH-IOL) - neytral, uchinchi tomon laboratoriyasidan biri bo'lib, u iSCSI muvofiqligini sinovdan o'tkazish uchun sinov to'plamlarini taklif etadi.

Ushbu test paketlarining kirish qismida aytilganidek:

Ushbu testlar iSCSI mahsulotining ikkala IETF-da belgilangan xususiyatlarga muvofiqligini aniqlash uchun mo'ljallangan RFC 3720 iSCSI (bundan buyon matnda "iSCSI standarti" deb yuritiladi), shuningdek IETF tarkibidagi yangilanishlar RFC 5048 iSCSI tuzatishlari va tushuntirishlari RFC (bundan keyin "iSCSI tuzatishlari va tushuntirishlari" deb nomlanadi). Ushbu to'plamdagi barcha testlarni muvaffaqiyatli yakunlash sinovdan o'tgan qurilmaning boshqa iSCSI mahsulotlari bilan muvaffaqiyatli ishlashiga kafolat bermaydi. Shu bilan birga, IOLning o'zaro ishlash qobiliyatini sinab ko'rishda qoniqarli ishlash bilan birlashganda, ushbu testlar sinovdan o'tgan qurilmaning (DUT) ko'plab iSCSI muhitlarida to'g'ri ishlashiga ishonchni oqilona ta'minlaydi.

iSCSI muvofiqligini sinash asosan quyidagi jihatlarni o'z ichiga oladi:

  • Kirish bosqichining muvofiqligi
Sinov muzokaralarining kalit-qiymat juftliklari; turli xil bayroqlarni sinab ko'ring: CSG, NSG, C bit, T bit ...
  • To'liq xususiyatning fazaga muvofiqligi
Sinovning navbatdagi raqamlari (CmdSN, DataSN, R2TSN); test SCSI Buyruq / Javob, Vazifalarni Boshqarish Funktsiyasi So'rovi / Javob, Matn So'rovi / Javob, NOP-In / NOP-Out, SNACK Request ...
  • CHAP muvofiqligi
CHAP maydonlarini sinab ko'ring: CHAP_A, CHAP_C, CHAP_I, CHAP_N, CHAP_R ...
  • Ko'p ulanish mosligi
Ulanishni yaratish, to'xtatish, parametrlarni muhokama qilish, tartib raqami va vazifalarni boshqarish bo'yicha ko'p ulanishlarni qo'llab-quvvatlashni sinab ko'ring ...
  • Qayta tiklashda xatolik
Sinov tashabbuskori / maqsadni xatolarni tiklashni qo'llab-quvvatlash

iSCSI muvofiqligini sinashning umumiy stsenariylari

DUTning iSCSI protokoliga javob berish-qilmasligini tekshirish uchun asosan ikki xil amallarni bajarish mumkin edi:

  • Biz narsalarni to'g'rilaymiz va DUT o'zini to'g'ri tutishini tekshiramiz.
    Bunday holda, asosiy vazifa - DUT-ga iSCSI PDU-larining to'g'ri ketma-ketligini yuborish va DUT-ning to'g'ri PDU / PDU maydonlari bilan javob berishini tekshirish.
  • Biz noto'g'ri ishlarni qilamiz va DUT buni aniqlay oladimi yoki shunga mos ravishda o'zini tuta oladimi-yo'qmi.
    Bunday holda biz DUT-ga yuborilgan PDU ketma-ketligini ma'lum darajada o'zgartirishimiz kerak (masalan, buyruqning CmdSN-ni o'zgartiring, yaroqsiz ma'lumotlar dayjestini o'rnating ...) va DUT protokolga muvofiq reaksiyaga kirishishini tekshirishimiz kerak (masalan, yuborish a PDU-ni rad eting, ulanishni yoping ...).

Ba'zi keng tarqalgan stsenariylarni iSCSI muvofiqligini tekshirishda topish mumkin:

  • iSCSI funktsional testi
ISCSI topshirig'ining to'g'ri bajarilishini tekshirish uchun (Vazifalarni boshqarish funktsiyasi, NOP-In / NOP-Out Ping, bir nechta ulanishlarni boshqarish ...)
  • PDU formatidagi xato
Masalan, WS va F bitlari ikkalasi ham SCSI Buyruq PDU da 0 ga o'rnatilgan bo'lsa, bu xato.
  • PDU sessiyasi / bosqichidagi xato
Masalan, kirish bosqichida yoki kashfiyot seansida SCSI buyrug'i PDU paydo bo'lsa, bu xato.
  • Sarlavha / Ma'lumotlarni hazm qilishda xato
Digest xatosi Target / Initiator-ning Rad etish / SNACK PDU-ni yuborishiga olib kelishi mumkin.
  • Ketma-ketlikda xato
CmdSN / StatSN / DataSN / R2T har biri har xil ko'lamga va turli xil qoidalarga ega.
  • Muzokarada xato
Matn parametrlari key = value formatida, keyin bitta NULL ("0x00") ajratuvchi bo'lishi kerak. Har bir matn parametri ham o'z bosqichi va muzokara qoidalariga ega. Masalan, FirstBurstLength MaxBurstLength dan oshmasligi kerak, SendTargets faqat to'liq xususiyat fazasida paydo bo'lishi kerak va hokazo.
  • Ma'lumot uzunligida xato
Maqsadga juda ko'p yoki juda kam ma'lumotlar yuboriladi.
  • Yo'qotilgan PDU
Kiruvchi PDU-ni tashlang, keyin SNACK-ni oling, chiqadigan PDU-ni tashlang va qaytadan urinib ko'ring.

Yuqoridagi stsenariylarning aksariyati chiqish PDU tarkibini o'zgartirish orqali taqlid qilinishi mumkin. Masalan, ma'lumotlar hazm qilish xatosiga taqlid qilish uchun PDU-dagi DataDigest maydonini o'zgartirishimiz kerak.

iSCSI muvofiqligini sinash vositasi talabi

ISCSI muvofiqlikni sinash vositasi iSCSI Initiator emulyatori (iSCSI Target-ni sinash uchun) yoki iSCSI Maqsadli emulyatori (iSCSI Initiator-ni sinash uchun) sifatida qaralishi mumkin. Yaxshi iSCSI muvofiqligini sinash vositasi quyidagi talablarga javob berishi kerak:

  • Bajariladigan test skriptlari
Har bir sinov uchun bajariladigan skript kerak. U PDU ketma-ketligi va tasdiqlash punktlarini belgilaydigan test ishi tavsifiga muvofiq yozilishi kerak.
  • ISCSI Dvigatel yadrosi
ISCSI Dvigatel yadrosi DUT-ga (sinov ostida uskuna) iSCSI PDU-larini yuborish / qabul qilish bilan shug'ullanadi. Bir tomondan, u test skriptidan ma'lumotlarni qabul qiladi, PDUlarni yuboradi yoki nazorat nuqtalarini tekshiradi; ikkinchidan, u iSCSI protokolini ma'lum darajada tushunishi kerak, shunda zarur avtomatlashtirishga erishish mumkin, masalan, iSCSI PDU-larini avtomatik ravishda yaratish (muzokaralar paytida Kirish / Matn so'rovi, Nop-Out ping javobi) va ba'zi PDU maydonlari (ITT) , TTT, CmdSN, ma'lumotlar, dayjest ...).
  • PDU formatini tasdiqlash
Qabul qilingan PDUlar uchun iSCSI Engine yadrosi noto'g'ri PDU ni aniqlash uchun tekshirishni tekshirishi kerak.
  • PDU tarkibini o'zgartirish qobiliyati
Noto'g'ri shakllangan PDU ko'pincha PDU formatidagi xato yoki hazm qilish xatosini simulyatsiya qilish uchun DUT-ga yuboriladi.
  • PDUni tashlash qobiliyati
PDU uzatish paytida yo'qolgan PDU ni simulyatsiya qilish uchun tashlanishi mumkin.
  • Bir nechta seanslarni / ulanishlarni saqlash qobiliyati
Xatolarni tiklash kabi, bir nechta seanslar / ulanishlarni qo'llab-quvvatlash iSCSI protokolidagi rivojlangan maydon.
  • Natija va jurnal
Sinov ishidan o'tish yoki muvaffaqiyatsizlik aniq ko'rsatmalarga ega bo'lishi kerak. Tahlil qilish uchun batafsil jurnal kerak. PDU damp fayllarini tahlil qilish uchun grafik interfeysga ega bo'lish yaxshiroqdir.
  • Ommaviy tizim
Sinov to'plamlari va test holatlarini boshqarish uchun ommaviy tizim kerak, shunda ko'p sonli test skriptlari foydalanuvchi aralashuvisiz avtomatik ravishda ishlaydi.

Mavjud iSCSI muvofiqligini tekshirish vositalari

  • UNH-IOL sinov xizmati
    ISCSI konsortsiumi iSCSI mahsulotlarini va dasturiy ta'minotni o'zaro muvofiqlik va muvofiqlik nuqtai nazaridan sinab ko'rish xizmatini taqdim etadi. A'zolik zamonaviy sinov uskunalari va IOL sinov vositalarini tayyorlash uchun zarur.
  • iSCSISim
    Ochiq manbali dasturiy ta'minot. iSCSISim shuningdek, iSCSI maqsadlarini sinash uchun iSCSI tashabbuskor emulyatoridir. Python-da yozilgan, uning qobiliyatiga SCSI buyrug'ini kiritish, xato kiritish va qutqarish sinovlari kiradi.
  • libisssi
    Ochiq manbali dasturiy ta'minot. libiscsi - iSCSI tashabbuskorini amalga oshiradigan foydalanuvchi maydoni kutubxonasi. C tilida yozilgan, maqsadga muvofiqligini sinab ko'rishga qodir bo'lgan iscsi-test-cu deb nomlangan iSCSI / SCSI test-to'plami bilan birga keladi.
  • Calsoftning iSCSI protokoliga muvofiqligi test to'plami
    Tijorat dasturlari. Sinov to'plami har qanday iSCSI maqsadini amalga oshirish uchun iSCSI protokoliga mos kelishiga yordam beradi.

Shuningdek qarang