Транзакцияны өңдеу - Transaction processing

Транзакцияны өңдеу - ақпаратты өңдеу Информатика деп аталатын жеке, бөлінбейтін операцияларға бөлінеді транзакциялар. Әрбір транзакция сәтті болуы керек немесе сәтсіздік толық бірлік ретінде; ол ешқашан жартылай ғана аяқтала алмайды.

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

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

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

Сипаттама

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

Мысалы, клиенттің жинақ шотынан 700 долларды клиенттің есепшотына ауыстыруды көздейтін әдеттегі банктік операцияны қарастырыңыз. Бұл транзакция компьютерлік терминдер бойынша кем дегенде екі операцияны қамтиды: жинақ шотының дебеті 700 долларға, чек шотын 700 долларға есептеу. Егер бір операция сәтті болып, ал екіншісі болмаса, банктің кітаптары күннің соңында теңгерімге ие болмайды. Демек, екі операцияның да сәтті болуын немесе екеуінің де сәтсіздігін қамтамасыз ету әдісі болуы керек, сонда тұтастай алғанда банктің мәліметтер базасында сәйкессіздіктер болмайды.

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

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

Әдетте, мәмілелер бір уақытта шығарылады. Егер олар қабаттасса (яғни мәліметтер базасының сол бөлігін түрту керек болса), бұл қайшылықтарды тудыруы мүмкін. Мысалы, егер жоғарыда келтірілген мысалда айтылған клиенттің жинақ шотында 150 доллар болса және 100 доллар басқа адамға аударуға тырысып, сол кезде 100 долларды чек шотына аударуға тырысса, олардың тек біреуі ғана жетістікке жете алады. Алайда транзакцияларды дәйекті түрде өңдеуге мәжбүрлеу тиімсіз. Демек, транзакцияны өңдеуді бір уақытта жүзеге асыру түпкілікті нәтиже қайшылықсыз нәтижені көрсететініне кепілдік беру үшін бағдарламаланған, егер транзакция кез-келген тәртіппен кезек-кезек орындалса, сол нәтижеге қол жеткізуге болады (меншік деп аталады) сериялылық ). Біздің мысалда, бұл қандай операция бірінші кезекте жасалса да, басқа адамға аудару немесе тексеру шотына көшу сәтті болса, екіншісі сәтсіз болғандығын білдіреді.

Әдістеме

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

Қайтару

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

Rollforward

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

Тығырық

Кейбір жағдайларда, екі транзакция оларды өңдеу барысында бір уақытта мәліметтер базасының сол бөлігіне қол жеткізуге тырысуы мүмкін, бұл оларды жалғастыруға мүмкіндік бермейді. Мысалы, А транзакциясы мәліметтер базасының Х бөліміне, ал В транзакциясы мәліметтер базасының Я бөлігіне қол жеткізе алады. Егер сол кезде А транзакциясы мәліметтер қорының Y бөлігіне, ал В транзакциясы X, a бөлімдеріне қол жеткізуге тырысады тығырық пайда болады, және екі мәміле де алға жылжи алмайды. Транзакцияны өңдеу жүйелері осы тығырықтар пайда болған кезде оларды анықтауға арналған. Әдетте екі транзакцияның күші жойылады және кері қайтарылады, содан кейін олар тығырыққа қайта оралмас үшін автоматты түрде басқа тәртіпте басталады. Немесе кейде тығырыққа тірелген транзакциялардың біреуі ғана жойылады, кері қайтарылады және қысқа кідірістен кейін автоматты түрде қайта басталады.

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

Транзакцияны өтеу

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

Қышқыл қышқылының өлшемдері

Джим Грей қысқартылған 1970 жылдардың соңында сенімді транзакция жүйесінің қасиеттерін анықтады Қышқыл - атомдық, дәйектілік, оқшаулану және беріктік.[1]

Атомия

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

Жүйелілік

Жүйелілік: Мәміле - бұл мемлекеттің дұрыс өзгеруі. Топ болып қабылданған әрекеттер мемлекетке қатысты тұтастық шектеулерінің ешқайсысын бұзбайды.

Оқшаулау

Транзакциялар бір уақытта орындалғанымен, әр T операциясына басқалары не T-ге дейін, не Т-дан кейін орындалатын көрінеді, бірақ екеуі де емес.

Төзімділік

Транзакция сәтті аяқталғаннан кейін (жасалады), оның мәліметтер базасындағы өзгерістері сәтсіздіктерден аман қалады және өзгерістері сақталады.

Артықшылықтары

Транзакцияны өңдеудің келесі артықшылықтары бар:

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

Кемшіліктері

  • Олардың орнату шығындары салыстырмалы түрде қымбат
  • Стандартты форматтар жетіспейді
  • Аппараттық және бағдарламалық жасақтаманың сәйкес келмеуі

Іске асыру

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

Бір күш - бұл X / Ашық таратылған транзакцияны өңдеу (DTP) (тағы қараңыз Java Transaction API (JTA). Алайда, IBM сияқты меншікті транзакцияны өңдеу орталары CICS әлі де өте танымал,[дәйексөз қажет ] дегенмен, CICS дамып, ашық өнеркәсіп стандарттарын да қамтыды.

Экстремалды транзакцияларды өңдеу (XTP) термині транзакцияны өңдеу жүйелерін әдеттегідей күрделі емес талаптармен, әсіресе өткізу қабілеттілігімен (секундына транзакциялармен) сипаттау үшін пайдаланылды. Мұндай жүйелер үлестірілген немесе кластерлік архитектура арқылы жүзеге асырылуы мүмкін. Ол кем дегенде 2011 жылға дейін қолданылды.[2][3]

Пайдаланылған әдебиеттер

  1. ^ Сұр, Джим; Ройтер, Андреас. «Транзакцияны өңдеу - түсініктер мен әдістер (Powerpoint)». Алынған 12 қараша, 2012.
  2. ^ Коен Вандеркимпен және Дирк Дериддер. «Денсаулық сақтау үшін eXtreme». Devoxx 2011 тұсаукесері. Алынған 18 наурыз, 2017.
  3. ^ Кевин Ребак (2011). Транзакцияны төтенше өңдеу. Найзағай көзі. ISBN  978-1-74304-266-3.

Әрі қарай оқу

  • Герхард Вайкум, Готфрид Воссен, Транзакциялық ақпараттық жүйелер: теория, алгоритмдер және параллельді бақылау мен қалпына келтіру практикасы, Морган Кауфман, 2002, ISBN  1-55860-508-8
  • Джим Грей, Андреас Ройтер, Транзакцияны өңдеу - тұжырымдамалар мен әдістер, 1993, Морган Кауфман, ISBN  1-55860-190-2
  • Филипп Бернштейн, Эрик Ньюкомер, Транзакцияны өңдеу принциптері, 1997 ж., Морган Кауфман, ISBN  1-55860-415-4
  • Ахмед К. Элмагармид (редактор), мәліметтер қорының қосымша қосымшаларына арналған транзакция модельдері, Morgan-Kaufmann, 1992, ISBN  1-55860-214-3

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