Changes between Initial Version and Version 1 of zadaca3katerina


Ignore:
Timestamp:
06/10/18 02:08:18 (7 years ago)
Author:
Katerina Chichakovska
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • zadaca3katerina

    v1 v1  
     1
     2== Процес за развој на информациски систем
     3
     4**Избор на процес за развој**
     5
     6На почетокот кога почнале да се конструираат софтверските системи, истите се имплементирале без притоа да се прави одредена анализа за софтверскиот продукт. Целата работа околу создавањето на софтверскиот продукт била препуштена на програмерите и главен процес притоа било програмирањето. Програмерите добивале документ со корисничките побарувања и според нив и нивното искуство тие го конструирале бараниот софтвер. Се разбира тогаш бараните софтвери биле едноставни и не многу обемни и комплицирани. Во денешно време не е можно да се конструира софтвер без притоа да се искористи некоја од познатите методологии.
     7
     8Техника која ќе ја користиме за да го изработиме ERP системот на !TrainTraveller е објектно ориентираната методологија – RUP развојниот процес.
     9
     10**Дефиниција – Што е RUP?**
     11
     12RUP e добро дефиниран и структуриран процес за развој на софтверски систем којшто користи техники и алатки, коишто го помагаат програмирањето и имплементацијата на продуктот. Со други зборови RUP му обезбедува на продуктот индивидуализирана рамка за развојот на процесот, која што е прилагодлива и компанијата за која се развива системот сама ги бира елементите од процесот потребни за негов развој, т.е. RUP не е единствен конкретен утврден процес.
     13
     14RUP бил креиран и првично се развивал во рамките на компанијата Rational Software Corporation, а потоа оваа компанија ја завзема компанијата IBM, а со неа и RUP.
     15
     16**RUP - карактеристики**
     17
     18Како и секој друг процес така и RUP има главни карактеристики кои целосно го опишуваат. Според главните карактеристики на RUP, тој се опишува како процесот што:
     19
     201.      се води според корисничките случаи
     21
     222.      е централизиран на архитектура
     23
     243.      е повторлив и постепен.
     25
     26Овој процес не може без ниту една од наведените карактеристики, т.е. и трите карактеристики му се потребни за успешно развивање на системот. Покрај тоа и користењето техники, алатки и компоненти е неизбежно.
     27
     28**Воден од корисничките случаи**
     29
     30Согласно со карактеристиката дека се води според корисничките случаи, побарувањата на клиентите се изразуваат преку тие кориснички случаи. Тие ја доловуваат целосната функционалност на системот, но не само тоа, истите се користат за дизајнирање на системот, спроведување на развојниот процес и крајното тестирање на системот, со цел да се увиди дека системот ги исполнува барањата на клиентот, затоа што како што знаеме, клиентот и неговите побарувања се суштината на системот.
     31
     32**Централизиран на архитектурата**
     33
     34Што се однесува до архитектурата, RUP најмногу се фокусира на архитектурата со цел да се претстави и увиде системот уште пред да се имплементира. Содржи детали за платформата на системот и неговите нефункционалности. Најпрво се поставува опис на архитектурата во кратки црти, а потоа со развојот на процесот низ фазите на RUP истата се менува и детално се опишува. RUP подржува повеќе архитектурни модели и погледи и нуди методичен и системски начин на дизајнирање и валидирање на архитектурата. Сето тоа, т.е. имањето робустна архитектура при развојот на системот овозможува паралелен развој, минимизација на потребата од постојано преизработување на процесот и зголемување на повторното користење на компонентите на системот којшто се развива.
     35
     36**Итеративен и постепен процес**
     37
     38Последната, но не и помалку важна карактеристика на RUP e тоа што е повторлив и постепен. Поради сложеноста на системите кои се развиваат, потребно е барањата постепено да се развиваат и да се додефинираат, затоа што тие неможат да бидат целосно прецизни и добро дефинирани уште при првото дефинирање. Како што се менуваат условите и како што се стекнува разбирање со клиентите истите постепено се развиваат. Па според тоа процесот на развој се дефинира како серија контролирани повторувања. Од таа причина RUP процесот е составен од четири фази и секоја фаза се состои од неколку итерации во зависност од системот кој се развива.
     39 
     40**Архитектура на RUP**
     41
     42Во делот каде што опишавме дека RUP е итеративен и постепен процес, увидовме дека овој процес е составен од четири фази (иницијација, елаборација, конструкција и транзиција) и секоја фаза од неколку итерации.
     43
     44Како што знаеме, RUP не е конкретно дефиниран, па според тоа фазите можат да се повторуваат, секоја фаза повеќе пати едно по друго или целото множество да се повтори повеќе пати во рамките на работните текови, се со цел успешно развивање на процесот.
     45
     46Работните текови, секвенци на активности, кои се користат во RUP се :
     47
     48•       Деловно (бизнис) моделирање – се моделираат бизнис процесите преку кориснички случаи, се утврдува контекстот на системот
     49
     50•       Барања – се развиваат корисничките случаи и визијата на системот
     51
     52•       Анализа и дизајн – опис на архитектурата на системот, преку модели на компоненти, архитектурни модели, модели на секвенци и сл.
     53
     54•       Имплементација – користење на моделите на дизајн за имплементација на подсистемите и генерирање на код
     55
     56•       Тестирање – итеративен процес што се одвива низ сите фази, паралелно со имплементацијата и се користи за утврдување дали се исполнети барањата, функционалностите, сигурноста и перформансите на системот
     57
     58•       Поставување – се поставува комплетиран систем кај корисниците, истиот се инсталира, а корисниците се обучуваат
     59
     60•       Конфигурација и менаџирање со промени – се одржува и следи системот, се утврдуваат и се извршуваат промените во системот, доколку постојат
     61
     62•       Менаџирање со проектот – надгледување и управување со проектот, користејќи техники и алатки, со цел утврдување на успешноста на системот
     63
     64•       Околина – избор и набавка на соодветни алатки кои ќе се користат при развој на процесот
     65
     66**Иницијација (Зачеток)**
     67
     68Иницијацијата е првата од четирите фази кои го сочинуваат RUP процесот. Оваа фаза е многу кратка и служи за поставување на идејата на системот и утврдување на придонесот и ресурсите. Според тоа најпрво се реализира и пишува визијата на системот, па се дефинираат бизнис случаите, со кои овој систем е засегнат, се идентификуваат ризиците и се дефинира опсегот на системот. Покрај тоа се пресметува колкав ќе биде придонесот на системот и дали е вреден за понатамошно развивање. 
     69
     70**Елаборација**
     71
     72Во фазата на елаборација најпрво се поставува и опишува архитектурата на системот. Притоа се дизајнираат дијаграми на кориснички случаи, класни и архитектурни дијаграми. Оваа фаза се состои од повеќе временски ограничени итерации за постигнување на целта. Во оваа фаза се пресметуваат и ризичните фактори и утврдување дека избраната архитектура ќе одговара на спецификациите на системот.  Со завршување на споменатото, за крај на оваа фаза се поставува и план за фазата на конструкција.
     73
     74**Конструкција**
     75
     76Оваа е најголемата фаза од процесот. По поставената архитектура, системот се дизајнира, т.е. имплементира на делови, а  потоа и се тестира. Како и елаборациската фаза и оваа фаза е составена од повеќе временски ограничени итерации. Со завршување на оваа фаза имаме готов функционален систем, заедно со негова документација.
     77
     78**Транзиција (премин)**
     79
     80При оваа фаза, системот се пренесува и инсталира во околината на крајните корисници. Во зависност од повратната информација на корисниците, системот може да се доработи и ажурира. Покрај конверзијата на системот оваа фаза и вклучува и обука на крајните корисници. Доколку се е во ред, овде завршува процесот на развој на систем – RUP.
     81
     82
     83== Примена на RUP во !TrainTraveller
     84
     85**Иницијализација за !TrainTraveller    **
     86
     87Како почеток ја имаме фазата за иницијализација на проектот. Во оваа фаза би имале две итерации, каде што ќе ги креираме корисничките барања, визијата на системот и анализата на ризиците.
     88
     89''1 - итерација''
     90
     91На почеток треба да се одржи состанок со компанијата којашто го нарачува системот и со сите заинтересирани страни. На овој состанок треба клиентот да ги изложи своите барања. Откако ќе заврши состанокот на тимот со клиентот, тимот се состанува и дискутира за системот. Потоа се пишува визијата на системот,  и се составуваат корисничките барања според забелешките од состанокот. Со готова визија и првично дефинирани кориснички барања се завршува оваа итерација.
     92
     93''2 - итерација''
     94
     95Откако ќе заврши првата итерација, тимот повторно се состанува со клиентот, со што му ги презентира визијата и корисничките барања. На овој состанок тимот проверува дали правилно ги разбрал корисничките барања за да продолжи со развивање на системот понатаму. После состанокот тимот ги доработува и детализира визијата и корисничките барања и прави анализа на ризиците и придонесите од овој систем, со што одлучува да продолжи понатаму со развивање на истиот. На крај од оваа итерација тимот прави план за фазата на елаборација.
     96
     97Доколку бидат потребни повеќе итерации при развојот на системот истите ќе бидат овозможени.
     98
     99**Елаборација за !TrainTraveller**
     100
     101После фазата на иницијација, следува фазата на елаборација. Оваа фаза е подолга од фазата на иницијација. Во оваа фаза може да има од две до четири итерации во зависност од состаноците со клиентите и соработката меѓу тимот. Да претпоставиме дека оваа фаза ќе се содржи од четири итерации со цел да можеме да го пресметаме максималното време потребно за изработка на овој информациски систем.
     102
     103''1 – итерација''       
     104
     105На почеток ја поставуваме прелиминарната архитектура на системот. Имаме повторна средба со клиентот за собирање на детали за корисничките барања и дефинирање на конечниот use case модел. Користејќи ја техниката на UML дијаграмите се опишува поставената архитектура.
     106
     107''2 – итерација''
     108
     109Во втората итерација ќе извршиме анализа на корисничките случаи и операциска анализа. Притоа ќе почнеме со детализирање на дијаграмите кои ја опишуваат кандидат архитектурата. Со тоа ќе го креираме првиот архитектурен прототип.
     110
     111''3 – итерација''
     112
     113Во следните две итерации повторно ќе се состанеме со клиентите, со цел собирање на повеќе детали и претставување на архитектурните прототипови. Исто така ќе продолжиме да ги детализираме UML дијаграмите (класни, секвенцни и дијаграми на активности) со цел да го достигнеме посакуваниот модел.
     114
     115''4 – итерација''
     116
     117На крај ги доработуваме графиците кои ја опишуваат архитектурата на информацискиот систем, со што го достигнуваме нивниот краен модел и му го претставуваме на клиентот конечниот архитектурен прототип. Исто така на крајот од оваа фаза во оваа итерација го дефинираме планот за фазата на конструкција.
     118
     119**Конструкција за !TrainTraveller**
     120
     121Откако ја дефиниравме визијата, корисничките барања и архитектурата на системот, ќе почнеме со негова имплементација. Фазата на конструкција одзема најмногу време. Нашиот систем содржи 18 кориснички барања (use cases), па според тоа во оваа фаза е потребно секој use case посебно да се развие, да се дизајнира и имплементира. Потоа секој use case се интегрира во системот и накрај секој се тестира и се поправаат грешките доколку се појават. 
     122
     123''1 – итерација''
     124
     125Најпрвин ги дизајнираме и имплементираме еден по еден секој од дефинираните кориснички барања. Како што ќе се комплетираат еден по еден секој од нив ќе се интегрира во системот. Накрај го извршуваме првиот прототип и му го претставуваме на клиентот.
     126
     127''2 – итерација''       
     128
     129Во втората итерација ќе ги тестираме корисничките барања еден по еден и ќе ги поправаме грешките. Исто така доколку има забелешки од состанокот со клиентот истите ќе се досредат. Накрај од оваа итерација се прави документацијата за корисникот и правиме план за фазата на Транзиција.
     130
     131**Транзиција за !TrainTraveller**
     132
     133Во оваа фаза потребно е системот којшто го развивме, да го пренесеме во околината на корисниците, а потоа да ги обучиме корисниците за работа со истиот. Според тоа сметаме дека сето ова може да го завршиме во една итерација.
     134
     135''1 – итерација''       
     136
     137Во оваа итерација најпрво ќе го пренесеме готовиот систем во околината на корисниците и ќе го инсталираме таму каде што ќе биде потребно. По сето ова ќе ја извршиме потребната обука на корисниците за користење на системот. Со тоа се завршува и целиот развој на нашиот систем користејќи го RUP просецот.
     138