Қолдану интерфейсінің сипаттамасы - Application Interface Specification - Wikipedia

The Қолдану интерфейсінің сипаттамасы (ААЖ) анықтайтын ашық сипаттамалардың жиынтығы бағдарламалық интерфейстер Қолданбалы компьютерлік бағдарламалық қамтамасыздандыруға арналған (API). Ол әзірледі және жариялады Қызметтің қол жетімділігі форумы (SA форумы) және еркін қол жетімді болды. Қол жетімділігі жоғары қосымшалардың күрделілігін төмендетуден және әзірлеу уақытын қысқартудан басқа, сипаттамалар әртүрлі орта бағдарламалық жасақтамалар арасындағы қосымшалардың портативтілігін жеңілдетуге және үшінші тарап әзірлеушілерін бұрын меншікті болған салаға жіберуге бағытталған.

Тарих

ААЖ SA форумының сервистік қол жетімділік интерфейстерінің (SAI) бөлігі болып табылады. 2003 жылы 14 сәуірде шыққан бастапқы сипаттамалар қол жетімділікті басқару шеңбері (АМФ), кластерге мүшелік қызметі (CLM) және тағы төрт коммуналдық қызметтер (Checkpoint, Event, Message, Lock) болды.

ААЖ қызметтерінің жіктелуі
ААЖ қызметтерінің жіктелуі.

Қосымша қызметтер келесі шығарылымдарда қосылды.

  • 3 шығарылымы (18 қаңтар, 2006 ж.) Басқару қызметтерінің бірінші жиынтығын қосты: журнал, хабарлама және ақпараттық модельді басқару (IMM).
  • 4 шығарылымы (27 ақпан, 2007 ж.) Коммуналдық қызметтерді Timer және Nameing көмегімен кеңейтті.
  • 5 шығарылымы (2007 ж. 16 қазан) қауіпсіздік қызметін басқару қызметін кеңейтіп, бағдарламалық жасақтаманы басқару шеңберін қосты.
  • 6 шығарылымы (21 қазан, 2008 ж.) AIS мен HPI арасындағы алшақтықты жою үшін платформаны басқару қызметін қосты (Аппараттық платформа интерфейсі ).

ААЖ 12 қызмет пен екі шеңберден тұрады. Қызметтер үш функционалды топқа жіктеледі - ААЖ шеңберлерінен басқа, ААЖ платформалық қызметтері, негізгі AIS басқару қызметтері және жалпы AIS коммуналдық қызметтері.

Бастапқыда API интерфейсі анықталды C бағдарламалау тілі тек, бірақ 2008 жылдың шілдесіндегі жағдай бойынша Java әр түрлі қызмет API интерфейстерінің картасы біртіндеп шығарылады.

Қызметке тәуелділік

IMM арқылы барлық қызметтерге арналған әкімшілік API.
2-сурет: ААЖ қызметтері арасындағы типтік тәуелділік қатынастары.

Интерфейстің спецификациясының әр түрлі қызметтері мен құрылымдары жасалынған модульдік және белгілі бір дәрежеде, бір-біріне тәуелсіз. Бұл тек AIS және HPI жоқ жүйені өмір сүруге мүмкіндік береді және керісінше.

Бірден-бір қажетті архитектуралық тәуелділік - Кластерге мүшелік қызметке (CLM) тәуелділік. Платформаларды басқару қызметі (PLM) мен таймер қызметі (TMR) қоспағанда, барлық AIS қызметтері CLM-ге тәуелді.

Барлық AIS қызметтері өздерінің әкімшілік интерфейстерін, конфигурациясын және жұмыс уақытын басқару туралы ақпаратты ашу үшін AIS Management Services қолдануы керек деп күтілуде (2-сурет).

Платформа бойынша қызметтер

PLM, CLM сыныптары
PLM, CLM және AMF нысандары арасындағы картаға түсіру

Platform Management Service (PLM) аппараттық құралдың логикалық көрінісін және жүйенің төменгі деңгейлі бағдарламалық жасақтамасын ұсынады. Төмен деңгейлі бағдарламалық жасақтама осы тұрғыдан барлық бағдарламалық жасақтама үшін қоршаған ортаны қамтамасыз ететін операциялық жүйе мен виртуалдандыру қабаттарын қамтиды.

PLM жүзеге асыратын негізгі логикалық нысандар:

PLM, CLM сыныптары
PLM ақпараттық моделіндегі виртуалдандырылған архитектуралар.
  • Аппараттық элемент (HE) - Аппараттық элемент дегеніміз, мысалы, шасси, Процессордың жүзі, немесе енгізу-шығару құрылғысы. Әдетте, барлығы Өрісті ауыстыруға болатын қондырғылар (FRU) аппараттық элементтер ретінде модельденеді.
  • Орындау ортасы (EE) - Орындау ортасы - бұл кейбір бағдарламалық жасақтамаларды басқаруға қабілетті ортаны білдіретін логикалық тұлға. Мысалы, процессордың жүзі немесе SMP машина орындау ортасы ретінде модельденген бір амалдық жүйенің данасын басқарады. Әр түрлі виртуализация архитектураларына қолдау көрсетіледі (сурет 4).

PLM мемлекет сақтайды ақпараттық модельдегі осы нысандардың және құралдарын ұсынады бақылау оларды және трек кез келген күй өзгереді. Жоғары оқу орындарына арналған осы тапсырмаларды орындау үшін PLM қызметі әдетте HPI пайдаланады. EE болған жағдайда, PLM операциялық жүйенің және кез-келген қол жетімді виртуализация деңгейінің денсаулығы туралы барлық қажетті ақпаратты алуға жауапты.

Кластерге мүшелік қызметі (CLM) бағдарламаларға кластерлік конфигурацияда әкімшілік конфигурацияланған түйіндер туралы мүшелік туралы ақпаратты ұсынады (бұл түйіндер кластер түйіндері немесе конфигурацияланған түйіндер деп те аталады) және кез-келген кластерлік жүйенің өзегі болып табылады. Кластер осы теңшелген түйіндер жиынтығынан тұрады, олардың әрқайсысы ерекше түйін атауы бар.

Кластерге мүшелік қызметі жүзеге асыратын екі логикалық тұлға:

  • Кластер - кластердің өзін білдіреді және ол кластер түйіні объектілерінің басты объектісі болып табылады.
  • Кластерлік түйін - Конфигурацияланған кластер түйінін ұсынады.

CLM ағымдағы кластер мүшелігі туралы ақпаратты алу және мүшелік өзгерістерді бақылау үшін API ұсынады (мысалы, түйінге шығу, түйінге қосылу). Барлық кластерлік AIS қызметтері мүшелікті анықтау үшін CLM трек API қолдануы керек.

Басқару қызметтері

AIS қызметтерімен жүзеге асырылатын әртүрлі нысандар (мысалы, орындау ортасы, бақылау нүктелері, компоненттер және т.б.) ретінде ұсынылған басқарылатын нысандар SA форумында Ақпараттық модель (IM), оны а ретінде қарастыруға болады конфигурацияны басқару дерекқоры. Басқарылатын объектілер - бұл сынып атрибуттары мен әкімшілік әрекеттерді анықтайтын, тиісті AIS қызметінің спецификациясымен анықталған объект сыныптарының даналары. Объект кластары үшін көрсетілген әкімшілік операциялар объектілер ұсынатын нысандарда орындалуы мүмкін операцияларды ұсынады, мысалы. сервистік блокты құлыптау немесе жедел хабардың мазмұнын XML форматында экспорттау. ЖЖ-дағы объектілер ағаш иерархиясында сақталады, онда объект, ең көп дегенде, бір ата-ана және кез-келген еншілес объектілер болуы мүмкін.

IMM схемалық шолуы
Ақпараттық модель басқару қызметі ұсынатын API

ХБ-дағы объектілермен ұсынылған логикалық нысандарды IMM сервисінің өзі негізінен жүзеге асырмайды; оның орнына қолданушы қосымшалары және AIS қызметтері, мысалы, Checkpoint қызметі немесе қол жетімділікті басқару шеңбері олардың орындалуын қамтамасыз етеді. Сондықтан бұлар аталады объектіні жүзеге асырушылар (OI). Басқару мақсатында барлық ААЖ қызметтері жүзеге асырылатын объектілерді IMM қызметі арқылы басқарылатын объектілер ретінде көрсетеді.

АЖ-да объектілер мен атрибуттардың екі санаты бар: жұмыс уақыты және конфигурация.

Жұмыс уақыты объектілері мен атрибуттары олар ұсынатын субъектілердің ағымдағы жағдайын көрсетеді - олар сипаттама табиғат.

Қайта, конфигурация нысандары мен атрибуттары болып табылады нұсқаулық басқару қосымшаларына қатысты - немесе объект менеджерлері (OM) - бұл объектілерді іске асырушыларға қандай объектілерді енгізу керек екендігі туралы ақпарат берудің құралы.

Конфигурация нысандары теңшелімді де, жұмыс уақыты атрибуттарын да қамтуы мүмкін, ал жұмыс уақытының нысандары тек орындалу атрибуттарын қамтуы мүмкін. Әкімшілік операциялар объектінің екі санаты бойынша да анықталуы мүмкін.

Тиісінше, IMM қызметі «оңтүстікке ”Интерфейсі - IMM-OI API - объектіні іске асырушыларға және“солтүстікке ”Интерфейсі - IMM-OM API - басқару қосымшаларына (сурет 5), мысалы. SNMP агенттері және осы екі тарап арасында делдалдық етеді. Ол тұрақты нысандар мен атрибуттарды сақтау үшін де жауап береді.

Журнал

Журнал қызметі арналған оқиғаларды тіркеу, яғни жүйелік администраторларға немесе автоматтандырылған құралдарға сәйкес келетін жүйе туралы, кластер бойынша, функцияларға негізделген (іске асырудың ерекшеліктеріне қарағанда) ақпарат жинау үшін.

Журнал қызметі сервистерге журнал ағындары арқылы журнал жазбаларын экспрессияға және жазуға мүмкіндік береді, мысалы, белгілі файл сияқты шығыс бағыттарына апарады. Шығу мақсатына жеткеннен кейін, журнал жазбасы конфигурацияланатын және жалпыға қол жетімді болатын шығыс пішімдеу ережелеріне бағынады. Тіркеуге арналған бағдарлама осы аспектілердің кез-келгенін білуі қажет емес (мысалы, тағайындалған файлдың орналасуы, файлды айналдыру немесе пішімдеу және т.б.), өйткені журнал қызметі оларды журналға бағытталған ағынның ағымдағы параметрлері негізінде өңдейді. Шығару форматы ашық болғандықтан, үшінші тарап құралдары бұл журнал файлдарын оқи алады.

Журнал ағындарының төрт түрі көрсетілген: дабыл (ITU X.733 және ITU X.736 негізіндегі журнал жазбалары), хабарлама (ITU X.730 және ITU X.731 негізіндегі журнал жазбалары), жүйе және қолдану. Бағдарлама типі қолданбалы арнайы журнал ағындарын анықтау үшін қолданбалар арқылы қолданылады. SA Forum кластеріндегі дабыл, хабарлама және жүйелік журнал ағындарының әрқайсысы үшін нақты бір алдын ала анықталған журнал ағыны бар. Пайдаланушы қосымшаларына алдын ала анықталған ағындардың кез-келгенін пайдалануға немесе қосымшаға арналған жаңа журнал ағындарын жасауға рұқсат етіледі.

Хабарлама

Хабарландыру қызметі - үлкен дәрежеде - негізделген ITU-T Ақауларды басқару моделі (X.700 құжаттар сериясында көрсетілген), сондай-ақ көптеген басқа ұсыныстар бойынша.

Хабарландыру қызметі a тұжырымдамасына негізделген хабарлама, бұл оқиғаны немесе жағдайдың өзгеруін түсіндіреді. «Хабарлама» термині AIS Event Service анықтаған «оқиғадан» айқын ажырату үшін «оқиға» орнына қолданылады.

NTF қызметі негізделеді жариялау-жазылу парадигма. Ол хабарламаның алты түрін анықтайды: дабыл, қауіпсіздік дабылы, объектіні құру / жою, күйді өзгерту, атрибуттардың мәнін өзгерту және басқалар. Хабарламалар жасалған / жарияланған өндірушілер хабарландыру өндірушісі API қолдану. Хабарлама тұтынушылары да болуы мүмкін жазылушылар, хабарламаларға жазылатын және оларды болған жағдайда алатындар; немесе оқырмандар, тұтынушы API хабарландыруын қолданумен тұрақты журналдардан хабарламалар шығаратын. Тұтынушылар хабарламаның екі түрін де алуға немесе оқуға мүдделі хабарламалардың сипаттамаларын көрсететін сүзгілерді анықтай алады.

Хабарламалар AIS қызметтері арқылы, сондай-ақ қосымшалар арқылы жасалуы мүмкін. Хабарламалар жасайтын AIS қызметтерінде олардың хабарландыруларын сипаттайтын бөлім бар.

Қауіпсіздік

Қауіпсіздік қызметі AIS Services қолдана алатын механизмдерді ұсынады түпнұсқалық растама AIS қызметі (және басқа ықтимал) клиенттің кластер ішіндегі процестері және дейін рұқсат ету оларды белгілі бір іс-әрекеттерді орындау. Бұл механизмдерді сақтау үшін пайдалануға болады тұтастық қол жетімді инфрақұрылым және SA Forum қосымшалары, оның ішінде олардың деректері, рұқсатсыз кіруден қорғау.

Қауіпсіздікті қамтамасыз ету AIS қызметінің іске асырылуының өздеріне жүктелген: Қауіпсіздігі бар AIS қызметтері әр түрлі іс-әрекеттерді бастаған кезде клиенттер процестері атынан ӘКК іске асырудан авторизация сұрайды. ӘКК осы авторизация сұраныстарына берілген немесе жоққа шығарылған белгілермен жауап береді және сәйкесінше операцияға рұқсат беру немесе рұқсат бермеу AIS қызметінде. ӘКК бұл көрсеткіштерді жиынтық негізінде ұсынады қауіпсіздік саясаты IMM арқылы конфигурацияланған. Сондай-ақ, ол абоненттерге саясаттың өзгеруі туралы тиісті кері байланыстарды қолдана отырып хабарлайды.

Фреймворктар

Қол жетімділікті басқару негіздері

Қол жетімділікті басқару шеңбері мүмкіндік береді қызметтің қол жетімділігі SA Forum үйлесімді жүйелерінде. Ол қызмет көрсетуге дайын болу жағдайына байланысты бақылаудағы әр түрлі субъектілердің жүктемесін үйлестіреді. Осы мақсатта қосымшаны AMF үшін көрсетілген ақпараттық модельге сәйкес сипаттау қажет. Бұл модель кластерге қандай ресурстардың қосымшаға жататынын және қосымша қандай қызметтерді ұсынатындығын сипаттайды.

Бұл ақпараттық модельдің негізгі логикалық мәні болып табылады компонент, бұл қол жетімділікті басқарудың кейбір нақты функционалды мүмкіндіктерін жинайтын ресурстар жиынтығын ұсынады. АМФ құрамдас бөлікке тағайындайтын кейбір қызметтерді ұсыну арқылы туындаған жұмыс жүктемесі а түрінде ұсынылған компоненттік қызмет данасы (CSI). Компонент қызметті белсенді ұсынған кезде, оған қызметті ұсынатын CSI атынан белсенді күй тағайындалады.

Негізгі принципі ақаулыққа төзімді дизайн жиынтығы бойынша қызметтерді ұсыну болып табылады артық ұйымдар сондықтан компоненттер CSI атынан күту режимінде бола алады. Күту режиміндегі компоненттер белсенді тағайындалған компонент сәтсіздікке ұшыраған жағдайда, олар қызмет көрсетуді өздері қабылдай алатындай күйде болады. AMF рөлі компонент күйі мен жүйені конфигурациялау функциясы ретінде қосымшаның компоненттеріне белсенді немесе күту режиміндегі жұмыс жүктемелерін тағайындау болып табылады.

Тиісінше, қол жетімділікті басқару шеңберінде ұсынылған API интерфейсі компоненттерді тіркеуге, өмірлік циклды басқаруға және жұмыс жүктемесін тағайындауға мүмкіндік береді. Олар қателіктер туралы есеп беру және денсаулық жағдайын бақылау функцияларын қамтиды. Олар сонымен қатар CSI-ді қорғайтын компоненттер жиынтығы арасында компоненттерге қызмет көрсету даналарын тағайындауға мүмкіндік береді.

Қол жетімділікті басқару шеңберінің конфигурациясы қалпына келтіру және жөндеу саясаттарын қамтиды. Бұл ресурстардың басымдылығын анықтауға мүмкіндік береді және әртүрлі артық модельдерді ұсынады. Олар қарапайым 2N моделінен (1 + 1 немесе белсенді күту деп те аталады) бастап, бір компоненттің қызмет данасы атынан бірнеше күтуге тағайындалуға мүмкіндік беретін N-әдіспен резервтеу моделі сияқты неғұрлым жетілдірілгенге дейін. бірнеше белсенді тағайындауға мүмкіндік беретін N-әдіс-белсенді.

Әкімшілендіруді жеңілдету үшін АМФ компоненттерді сервистік блоктар мен қызмет топтарына, ал компоненттер қызмет даналарын қызмет даналарына топтайды. Мұның бәрі өтініш жасайды. IMM арқылы әкімшілік операциялардың жиынтығы осы логикалық нысандарда қол жетімді.

Бағдарламалық жасақтаманы басқару мақсатында бір бағдарламалық жасақтаманы басқаратын субъектілер типтерге топтастырылған, бұл осы құрылымдардың конфигурациясы үшін бір нүктелік жазба енгізуге мүмкіндік береді.

Бағдарламалық жасақтаманы басқару

SA Forum үйлесімді жүйесін барлық конфигурацияланған бағдарламалық жасақтамамен бірге жүйеде орналастырылған бағдарламалық жасақтамадан тұратын орналастыру конфигурациясымен сипаттауға болады. Орналастыру конфигурациясы IMM қызметі басқаратын ақпараттық модельдің маңызды бөлігін құрайды.

Бағдарламалық жасақтаманы басқару шеңбері (SMF) кластер үшін қол жетімді және орналастырылған бағдарламалық жасақтаманы сипаттайтын ақпараттық модельдің бөлігін қолдайды. Бірақ SMF-тің негізгі мақсаты - бір орналастыру конфигурациясынан екіншісіне қоныс аударуды ұйымдастыру арқылы тірі жүйенің эволюциясын қамтамасыз ету. SMF терминдерінде бұл көші-қон процесі an деп аталады жаңарту науқаны.

Бағдарламалық жасақтаманы басқару шеңбері жаңарту науқанын көрсету үшін қолданылатын XML схемасын анықтайды. SMF бағдарламасы жүйені бір орналастыру конфигурациясынан жаңа XML файлына негізделген қалағанына ауыстырады, бұл негізінен сценарий жаңа конфигурацияға әкелетін реттелген әрекеттер мен конфигурацияның өзгеруі.

Осы көші-қон кезінде SMF

  • науқанның мемлекеттік моделін қолдайды,
  • көшуге байланысты ықтимал қателік жағдайларын бақылайды және
  • қажет болған жағдайда қателерді қалпына келтіру процедураларын қолданады.

Осы міндеттерді орындау үшін SMF іске асырылуы қол жетімділігін сақтау үшін (1) АМФ-мен, (2) ақпараттық модельге өзгерістер енгізу үшін IMM-мен, және (3) NTF-пен қате көрсетуі мүмкін хабарламалар алу үшін өзара іс-қимыл жасайды. жүргізіліп жатқан науқаннан туындаған жағдайлар.

Бағдарламалық жасақтаманы басқару шеңбері клиенттік процестерге кластерде тиісті жаңарту науқаны басталған кезде және ол маңызды кезеңдерде алға басқан кезде қоңырау шалуды қабылдауға қызығушылықтарын тіркеу үшін API ұсынады. Бұл қолданбалы әрекеттерді жаңартумен үйлестіруге мүмкіндік береді. Бұл бағдарлама кейбір маңызды тапсырмаларды орындаған кезде жаңарту науқанының бастамасын бұғаттаудан бастап, дерекқор схемасын жаңарту немесе жаңа хаттамаларды орналастыру сияқты бағдарлама деңгейіндегі жаңарту әрекеттерін үйлестіруге дейін болуы мүмкін.

SA Forum кластеріне орналастырылатын бағдарламаларды жеткізушілер үшін Бағдарламалық жасақтаманы басқару шеңбері сонымен қатар XML схемасын анықтайды файл типіқосымшамен іске асырылатын бағдарламалық жасақтама түрлерін сипаттайтын. Бұл ақпарат тиісті орналастыру конфигурацияларын ойлап табу үшін қолданылады.

Коммуналдық қызметтер

Бақылау пункті

Checkpoint қызметі процестерді жазуға мүмкіндік береді бақылау пункті қосымшаны сәтсіздіктерден қорғау үшін қолдануға болатын деректер біртіндеп. Процесс сәтсіздіктен қалпына келтірілгенде (қайта қосумен немесе а құлату процедурасы), бақылау нүктесі қызметі бұрын тексерілген деректерді шығарып алуға және жазба күйінен орындалуды қалпына келтіруге, осылайша сәтсіздіктің әсерін азайтуға пайдаланылуы мүмкін.

Бақылау пункттері - бұл кластерлік құрылым. Бақылау пунктінде сақталған деректердің көшірмесі бақылау нүктесінің репликасы деп аталады, ол көбінесе өнімділік себептері үшін дискіде емес, негізгі жадта сақталады. Тексеру пунктінде түйіннің бұзылуынан қорғау үшін кластердің әртүрлі түйіндерінде бірнеше бақылау нүктелерінің көшірмелері болуы мүмкін. Бақылау пунктін құру процесі синхронды және асинхронды репликаны жаңарту саясаттары арасында таңдау жасай алады. Асинхронды репликация кезінде жаңартудың өнімділігін оңтайландыру үшін қосалқы орынды таңдауға болады.

Оқиғалар

Іс-шара қызметі - бұл оқиғалар арналары тұжырымдамасына негізделген жариялау / жазылуға арналған көп нүктеден көп нүктеге дейінгі байланыс механизмі: бір немесе бірнеше баспагерлер бір немесе бірнеше белгісіз жазылушылармен оқиғалар арнасы арқылы оқиғаларды пайдалану арқылы синхронды емес байланысады. Іс-шаралар арналары - бұл іс-шараларды барынша күшейтуді қамтамасыз ететін кластерлік атаулы ұйымдар. Баспагерлер сол іс-шара арнасының жазылушылары бола алады.

Оқиғалар стандартты тақырыптан және нөлдік немесе одан көп байттан тұратын жарияланған оқиғалардан тұрады. Event Service API жарияланған іс-шаралар деректері үшін нақты орналасуды таңдамайды.

Процесс жарияланған оқиғаларды алу үшін іс-шаралар арнасына жазылған кезде, жарияланған іс-шараларға қолданылатын сүзгілерді анықтайды. Іс-шаралар тек берілген сүзгілерді қанағаттандырған жағдайда ғана жеткізіледі.

Құлыптар

Құлыптау қызметі - бұл таратылған құлыптау қызметі, бұл кластерде қолдануға арналған, онда әртүрлі түйіндердегі процестер бір-бірімен ортақ ресурсқа қол жеткізу үшін бәсекелесе алады. Бұлар үшін Құлыптау қызметі бұғаттау ресурстары деп аталатын нысандарды ұсынады, бұл өз кезегінде қолданбалы процестер сол ортақ ресурстарға қол жетімділікті үйлестіру үшін қолданады.

Құлыптау қызметі эксклюзивті кіру үшін бір құлыптау режимін, ал басқасына жалпы қол жетімділікті қолдайтын қарапайым құлыптау моделін ұсынады. Құлыптау қызметі ұсынған құлыптар рекурсивті емес. Осылайша, бір құлыпты талап ету басқа құлыпты жасырын түрде талап етпейді; керісінше, әр құлыпқа жеке-жеке талап қою керек.

Хабарламалар

Хабарлама қызметі жалпы кластерге арналған API-ді анықтайды процессаралық коммуникация жүйесі. Байланыс логикалық атпен анықталған хабарлама кезектеріне негізделген. Процестердің кез-келген саны хабарламалар кезегіне хабарлама жібере алады, бірақ бір уақытта ең көп дегенде бір процесс оны қабылдау үшін аша алады. Бір хабарлама кезегі осылайша қолдайды нүкте-нүкте немесе көп нүктеден байланыс үлгілері.

Хабарлама кезегіне хабарлама жіберу процестері қабылдау процесінің жеке басын білмейді; сондықтан бастапқыда бұл хабарламаларды алған процесс а кезінде басқа процеске ауыстырылған болуы мүмкін құлату немесе ауыстыру.

Хабар кезектерін топтастыру үшін хабарлама кезектерін біріктіруге болады. Хабарлар кезегінің топтары көп нүктеден көп нүктеге дейін байланыс орнатуға мүмкіндік береді. Олар логикалық атаулармен анықталады, сондықтан жіберуші процесі хабарлама кезектерінің санын және ол байланысатын кластердегі хабарламалар кезектерінің орнын білмейді. Хабарлар кезегінің топтары хабарламалар кезегі тобына қатысты хабарламалар кезектері арасында хабарламаларды тарату үшін қолданыла алады. MSG үшеуін анықтайды біржолғы тарату саясаты - жүктемені бірдей бөлу, жергілікті жүктемені тең бөлу және жергілікті кезек - және таратылым (мультикаст ) саясат.

Сұраныс бойынша Хабарлама қызметі хабарлама кезектерінде және бір хабарламаға кезек топтарында жеткізудің әртүрлі кепілдіктерін ұсынады (мысалы, растау, хабарламаның тұрақтылығы және т.б.).

Атау

Атау қызметі адамдарға ыңғайлы атауларды объектілермен байланыстыратын («байланыстырылған») механизмді ұсынады, осылайша бұл объектілерді олардың аттарын ескере отырып іздеуге болады. Нысандар әдетте қызметтерге қол жеткізу нүктелерін, байланыс нүктелерін және қандай да бір қызмет түрін ұсынатын басқа ресурстарды ұсынады.

Атау қызметі екі атқа да белгілі бір макет немесе конвенция жүктемейді (UTF-8 кодталған) немесе олар байланысты объектілер. Бұл қызметтің пайдаланушыларына қандай да бір арнайы аппараттық немесе логикалық бағдарламалық жасақтаманы қабылдамай, өздерінің атау схемаларын таңдауға және пайдалануға мүмкіндік береді. Атау қызметі клиенттері іште сақтауға және қызметтен шығуға ниеттенген объектінің байланысының құрылымын, орналасуын және семантикасын түсінуі керек.

Таймерлер

Таймер қызметі клиенттік процестер таймерлерді орната алатын және таймер біткен кезде хабардар болатын механизмді ұсынады. Таймер - бұл динамикалық түрде құрылған және оның аяқталу уақытын абсолютті уақыт немесе ағымдағы уақыттан бастап ұсынатын логикалық объект.

Таймер қызметі таймердің екі түрін ұсынады: бір оқиғалы таймер және мерзімді таймер. Бір реттік таймердің мерзімі бір рет аяқталады және хабарламадан кейін жойылады. Белгіленген уақытқа жеткен сайын мерзімді таймерлердің уақыты аяқталады және бұл мерзім аяқталғаны туралы хабардар етіледі. Таймерді жою функциясын шақыру арқылы мерзімді таймерлерді нақты жою керек.

Бағдарламалау моделі

Барлық AIS қызметтері бірдей бағдарламалау моделіне ие. Спецификация кезінде бірдей ат қою конвенциялары, стандартты алдын-ала анықталған типтер мен тұрақтылықтар, API семантикасы, кітапхананың өмірлік циклын басқару және т.б.

SA форумының қолданбалы интерфейсі а процесс және интерфейсті жүзеге асыратын кітапхана. Интерфейс көп ағынды және бір ағынды қолданбалы процестерде қолдануға арналған. 'Процесс' термині POSIX стандартымен анықталған процеске балама ретінде қарастырылуы мүмкін; дегенмен, AIS а POSIX процесс, бірақ жүйенің бағдарламалық жасақтаманы басқаруға беретін кез-келген баламалы құрылымы.

The аймақ сервері - бұл спецификацияға қызмет көрсететін серверді білдіретін абстракция аудан (Қол жетімділікті басқару негіздері, кластерге мүшелік қызметі, бақылау пункті қызметі және т.б.). Әр облыста жеке логикалық аймақ сервері болады, дегенмен іске асырушы әр аймақ сервері үшін жеке физикалық модуль жасай алады немесе бір немесе бірнеше аймақ серверлерін жеке физикалық модульге біріктіреді.

SA Forum AIS қызметтерін бағдарламалау / қолдану моделі.
6-сурет: SA Forum AIS қызметтерін бағдарламалау / қолдану моделі.

Аумақты енгізу кітапханалары бір немесе бірнеше физикалық кітапханаларда жүзеге асырылуы мүмкін; дегенмен, инициализациялау, тіркеу және операциялық жүйені таңдау объектісін әр аймақтың енгізу кітапханасы үшін бөлек алу үшін процесс қажет. Осылайша, бағдарламалау тұрғысынан оларды бөлек кітапханалар ретінде қарастырған пайдалы.

Қолдану моделі оқиғаларға негізделген архитектураға тән, бұл бағдарлама қондырғыны орнатады, содан кейін оқиғалар болған кезде кері қоңыраулар қабылдайды (6-сурет).

Қызметтің қол жетімділігі кітапханасын пайдалану кез-келген динамикалық кодты жүктейтін және процессте орындалатын асинхронды қоңырауларды байланыстыратын кітапхананы инициализациялауға шақырудан басталады. Процесс бұдан әрі аймақ функцияларын пайдалануды қажет етпеген кезде, ол процесті интерфейс аймағының іске асырылу данасынан ажыратып, кез келген байланысты ресурстарды қалпына келтіретін аймақты аяқтау функциясын шақырады.

ААЖ синхронды және асинхронды бағдарламалау модельдерін қолданады. Синхронды API интерфейстер үшін әдетте кітапхана мен ассоциация үшін қолданылады. Көптеген AIS қызметтері олар жүзеге асыратын ұйымдардағы өзгерістерді бақылау мүмкіндігін қамтамасыз етеді. Әдетте API трегі үш функциядан тұрады: клиент шақыратын нысанды бақылауды бастау және тоқтату; және қадағаланатын ұйымның өзгеруі туралы (күтіп тұрған) клиентке хабарлау үшін қызметке шақырылған қоңырау.

Кері үйлесімділік

AIS спецификациясын дамытуда кері үйлесімділікке жету үшін бірнеше ережелер сақталады:

  • Функцияның немесе типтің анықтамасы SA форумының белгілі бір шығарылымы үшін ешқашан өзгермейді.
  • Функцияның немесе типтің анықтамасындағы өзгерістер (функцияға жаңа аргумент қосу, деректер құрылымына жаңа өріс қосу) жаңа функцияны немесе тип атауын анықтауға мәжбүр етеді. Жаңа функция немесе түр атауы алдыңғы нұсқадағы бастапқы аттан функция / түр өзгерген нұсқаны көрсететін жұрнақпен құрастырылған (мысалы, saAmfComponentRegister_3 ()).
  • Алдыңғы ережеге ерекше жағдай ретінде, енумның, жалаушаның немесе кәсіподақтың өрістерін енімнің, жалаушаның немесе кәсіподақтың өлшемі болған жағдайда, түрдің атын өзгертпестен бар энумға, жалаушаға немесе одақ түріне қосуға болады. түрі өзгермейді.
  • ААЖ-ді қолданушылар кітапхананы инициализациялағанда қолданба ұсынған нұсқа нөмірлеріне құрметпен қарауды және ескі нұсқаларды қолданатын қосымшаларға жаңа enum мәндерін көрсетпеуін қамтамасыз етуі керек.
  • ААЖ-ді енгізушілер кітапхана инициализацияланған кезде жаңа немесе өзгертілген қате кодтарына қатысты қолданба ұсынған нұсқа нөмірлерін құрметтеуін және спецификацияның ең соңғы нұсқасындағы функцияларға қатысты қате кодтарын қолданбаларға шығармауын қамтамасыз етуі керек. спецификацияның ескі нұсқасына жазылған.

Мысал ретінде, берілген қызметтің f () функциясын қамтитын majorVersion Vx-ті қарастырайық және f () -ды жаңа VV (Vy> Vx) негізгі модификациялауға тура келді, бұл f_y ( ) қазір Vy-де f () ауыстыратын нұсқа.

Vx және Vy нұсқаларын қолдайтын AIS енгізуді қарастыра отырып, процесс кітапхананы Vx немесе Vy көрсете отырып инициалдауы мүмкін:

  • егер процесс Vx-пен кітапхананың дескрипторын инициализацияласа, бұл дескриптор Vx-тен жаңа нұсқаларында енгізілген функцияларға қол жеткізуді қамтамасыз етпейді. Атап айтқанда, бұл дескриптор процесті f_y () сәтті шақыруға мүмкіндік бермейді
  • егер процесс Vy-мен кітапхананың дескрипторын инициализацияласа, бұл дескриптор Vy-ден ескі нұсқаларында енгізілген функцияға қол жеткізе алмайды, содан кейін сол функцияның жаңа нұсқасымен ауыстырылады. Атап айтқанда, бұл дескриптор процесті f () сәтті шақыруға мүмкіндік бермейді.

Алайда, процесс кітапхана алуды мақсат еткен функционалдылыққа сәйкес нұсқамен әр рет бірнеше рет инициализациялауы мүмкін екенін ескеріңіз.

Vy-ге арналған AIS қызметінің техникалық құжатына тек функцияның соңғы нұсқасы немесе Vy қолдайтын типтің анықтамасы кіреді.

Техникалық сипаттаманың шығарылымдары келесі түрде шығарылады: <шығарылым коды>. <Үлкен нұсқа>. <Кіші нұсқа>

Шығару коды - бас әріп. Артқа үйлесімділік тек сол шығарылым кодының нұсқалары арасында сақталады. Негізгі нұсқа және кіші нұсқа - бұл қосымша сандар. Сандардың үлкен өзгерісімен шығарылымдар жаңа мүмкіндіктер енгізіп, API-ді жоғарыда сипатталғандай артқа үйлесімді түрде өзгерте алады. Санды аз өзгертетін шығарылымдар API өзгертпейді. Олар қате түзетулерін, редакторлық өзгерістерді және предшественникке түсініктеме береді.

Іске асыру тізілімі

SA форумын енгізу тізілімі SA форумының техникалық сипаттамаларын жүзеге асыруды тіркеуге және жалпыға қол жетімді етуге мүмкіндік беретін процесс. Іске асыруды тіркеу үшін мүшелік қажет емес. Сәтті тіркелген іс-шаралар «деп аталуы мүмкінҚызметтің қол жетімділігі форумы тіркелген[тұрақты өлі сілтеме ].”

Сондай-ақ қараңыз

Сыртқы сілтемелер