Главная страница
Навигация по странице:

  • Вспомогательные процессы

  • Организационные процессы

  • Верификация

  • Структура жизненного цикла информационной системы

  • Модели жизненного цикла информационной системы

  • Каскадная модель жизненного цикла информационной системы

  • Основные этапы разработки по каскадной модели

  • Последний этап

  • Недостатки каскадной модели

  • Задержка получения результатов

  • Возврат на более ранние стадии

  • Сложность параллельного ведения работ

  • Информационная перенасыщенность

  • Сложность управления проектом

  • Спиральная модель жизненного цикла

  • Преимущества спиральной модели

  • Конспект Лекций БД. Конспект лекций_БД. Конспект лекций по курсу Информационное обеспечение, базы данных


    Скачать 0.89 Mb.
    НазваниеКонспект лекций по курсу Информационное обеспечение, базы данных
    АнкорКонспект Лекций БД
    Дата16.11.2021
    Размер0.89 Mb.
    Формат файлаdocx
    Имя файлаКонспект лекций_БД.docx
    ТипКонспект лекций
    #273214
    страница3 из 11
    1   2   3   4   5   6   7   8   9   10   11

    Основные процессы жизненного цикла


    Среди основных процессе» жизненного цикла наибольшую важность имеют три: разработка, эксплуатация и сопровождение. Каждый процесс характеризуется определенными задачами и методами их решения, исходными данными, полученны­ми на предыдущем этапе, и результатами.

    Разработка

    Разработка информационной системы включает в себя все работы по созданию информационного программного обеспечения и его компонентов в соответствии с заданными требованиями. Разработка информационного программного обеспече­ния также включает:

    - оформление проектной и эксплуатационной документации;

    - подготовку материалов, необходимых для проведения тестирования разрабо­танных программных продуктов;

    - разработку материалов, необходимых для организации обучения персонала.

    Разработка является одним из важнейших процессов жизненного цикла инфор­мационной системы и, как правило, включает в себя стратегическое планирова­ние, анализ, проектирование и реализацию (программирование).

    Эксплуатация

    Эксплуатационные работы можно подразделить на подготовительные и основные. К подготовительным относятся:

    - конфигурирование базы данных и рабочих мест пользователей;

    - обеспечение пользователей эксплуатационной документацией;

    - обучение персонала.

    Основные эксплуатационные работы включают:

    - непосредственно эксплуатацию;

    - локализацию проблем и устранение причин их возникновения;

    - модификацию программного обеспечения;

    - подготовку предложений по совершенствованию системы;

    - развитие и модернизацию системы.

    Сопровождение

    Службы технической поддержки играют весьма заметную роль в жизни любой корпоративной информационной системы. Наличие квалифицированного тех­нического обслуживания на этапе эксплуатации информационной системы яв­ляется необходимым условием для решения поставленных перед ней задач, при­чем ошибки обслуживающего персонала могут приводить к явным или скрытым финансовым потерям, сопоставимым со стоимостью самой информационной си­стемы.

    Основными предварительными действиями при подготовке к организации технического обслуживания информационного системы являются следующие:

    - выделение наиболее ответственных узлов системы. Это позволит выделить наиболее критичные составляющие информационной системы и оптимизировать распределение ресурсов для тех­нического обслуживания;

    - определение задач технического обслуживания и их разделение на внутренние (решаемые силами обслуживающего подразделения) и внешние (решаемые специализированными сервисными организациями). Таким образом, произво­дится четкое определение круга исполняемых функций и разделение ответ­ственности;

    - проведение анализа имеющихся внутренних и внешних ресурсов, необходимых для организации технического обслуживания в рамках описанных задач и раз­деления компетенции. Основные критерии для анализа: наличие гарантии на оборудование, состояние ремонтного фонда, квалификация персонала;

    - подготовка плана организации технического обслуживания, в котором необхо­димо определить этапы исполняемых действий, сроки их исполнения, затраты на этапах, ответственность исполнителей.

    Обеспечение качественного технического обслуживания информационной систе­мы требует привлечения специалистов высокой квалификации, которые в состоя­нии решать не только каждодневные задачи администрирования, но и быстро вос­станавливать работоспособность системы при сбоях.

    Вспомогательные процессы

    Среди вспомогательных процессов одно из главных мест занимает управление конфигурацией. Это один из вспомогательных процессов, поддерживающих ос­новные процессы жизненного цикла информационной системы, прежде всего про­цессы разработки и сопровождения. При разработке проектов сложных информа­ционных систем, состоящих из многих компонентов, каждый из которых может разрабатываться независимо и, следовательно, иметь несколько вариантов реали­зации и/или несколько версий одной реализации, возникает проблема учета их связей и функций, создания единой структуры и обеспечения развития всей сис­темы. Управление конфигурацией позволяет организовывать, систематически учи­тывать и контролировать внесение изменений в различные компоненты информа­ционной системы на всех стадиях ее жизненного цикла.

    Организационные процессы

    Управление проектом связано с вопросами планирования и организации работ, создания коллективов разработчиков и контроля за сроками и качеством выпол­няемых работ. Техническое и организационное обеспечение проекта включает:

    - выбор методов и инструментальных средств для реализации проекта;

    - определение методов описания промежуточных состояний разработки;

    - разработку методов и средств испытаний созданного программного обеспече­ния;

    - обучение персонала.

    Обеспечение качества проекта связано с проблемами верификации, проверки и тестирования компонентов информационной системы. Верификация это процесс определения соответствия текущего состояния разра­ботки, достигнутого на данном этапе, требованиям этого этапа. Проверка это процесс определения соответствия параметров разработки исход­ным требованиям. Проверка отчасти совпадает с тестированием, которое прово­дится для определения различий между действительными и ожидавшимися ре­зультатами и оценки соответствия характеристик информационной системы ис­ходным требованиям.

    Структура жизненного цикла информационной системы

    Полный жизненный цикл информационной системы включает в себя, как прави­ло, стратегическое планирование, анализ, проектирование, реализацию, внедрение в эксплуатацию. В общем случае жизненный цикл можно, в свою очередь, разбить на ряд стадий. Это деление на стадии достаточно произвольно. В общем виде жизненный цикл информационной системы подразделяется на четыре стадии:

    - начало;

    - уточнение;

    - конструирование;

    - переход (передача в эксплуатацию).

    Границы каждой стадии определены некоторыми моментами времени, в которые необходимо принимать определенные критические решения и в которые, следова­тельно, должны быть достигнуты определенные ключевые цели.

    Начальная стадия

    На начальной стадии устанавливается область применения системы и определя­ются граничные условия. Для этого необходимо идентифицировать все внешние объекты, с которыми должна взаимодействовать разрабатываемая система, и оп­ределить характер этого взаимодействия на высоком уровне. На начальной стадии идентифицируются все функциональные возможности системы и производится описание наиболее существенных из них.

    Деловое применение включает:

    - критерии успеха разработки;

    - оценку риска;

    - оценку ресурсов, необходимых для выполнения разработки;

    - календарный план с указанием сроков завершения основных этапов.

    Стадия уточнения

    На этой стадии проводится анализ прикладной области, разрабатывается архитек­турная основа информационной системы.

    При принятии любых решений, касающихся архитектуры системы, необходимо принимать во внимание всю разрабатываемую систему в целом. Это означает, что необходимо описать большинство функциональных возможностей системы и учесть взаимосвязи между отдельными ее составляющими.

    В конце стадии уточнения проводится анализ архитектурных решений и способов устранения главных элементов риска, содержащихся в проекте.

    Стадия конструирования

    На стадии конструирования разрабатывается законченное изделие, готовое к пе­редаче пользователю.

    По окончании этой стадии определяется работоспособность разработанного про­граммного обеспечения.

    Стадия перехода

    На стадии перехода производится передача разработанного программного обеспе­чения пользователям. При эксплуатации разработанной системы в реальных ус­ловиях часто возникают различного рода проблемы, которые требуют дополни­тельных работ по внесению корректив в разработанный продукт. Это, как правило, связано с обнаружением ошибок и недоработок.

    В конце стадии перехода необходимо определить, достигнуты цели разработки или нет.

    Модели жизненного цикла информационной системы

    Моделью жизненного цикла информационной системы будем называть некото­рую структуру, определяющую последовательность осуществления процессов, действий и задач, выполняемых на протяжении жизненного цикла информаци­онной системы, а также взаимосвязи между этими процессами, действиями и за­дачами.

    В стандарте ISO/IEC 12207 не конкретизируются в деталях методы реализации и выполнения действий и задач, входящих в процессы жизненного цикла информационной системы, а лишь описываются структуры этих процессов. Это вполне понятно, так как регламенты стандарта являются общими для любых моделей жизненного цикла, методологий и технологий разработки. Модель же жизненного цикла зависит от специфики информационной системы и условий, в которых она создается и функционирует. Поэтому не имеет смысла предлагать какие-либо кон­кретные модели жизненного цикла и методы разработки информационных систем для общего случая, без привязки к определенной предметной области.

    К настоящему времени наибольшее распространение получили следующие две основные модели жизненного цикла:

    - каскадная модель, иногда также называемая моделью «водопад» (waterfall);

    - спиральная модель.

    Каскадная модель жизненного цикла информационной системы

    Каскадная модель демонстрирует классический подход к разработке различных систем в любых прикладных областях. Для разработки информационных систем данная модель широко использовалась в 70-х и первой половине 80-х годов.

    Каскадная модель предусматривает последовательную организацию работ. При этом основной особенностью является разбиение всей разработки на этапы, при­чем переход с одного этапа на следующий происходит только после того, как будут полностью завершены все работы на предыдущем этапе. Каждый этап завершает­ся выпуском полного комплекта документации, достаточной для того, чтобы раз­работка могла быть продолжена другой командой разработчиков.

    Основные этапы разработки по каскадной модели

    Можно выделить ряд устойчивых основных этапов разработки, практически не зависящих от предметной области:

    - анализ требований заказчика;

    - проектирование;

    - разработка;

    - тестирование и опытная эксплуатация;

    - сдача готового продукта.

    На первом этапе проводится исследование проблемы, которая должна быть реше­на, четко формулируются все требования заказчика. Результатом, получаемым на данном этапе, является техническое задание (задание на разработку), согласован­ное со всеми заинтересованными сторонами.

    На втором этапе разрабатываются проектные решения, удовлетворяющие всем требованиями, сформулированным в техническом задании. Результатом данного этапа является комплект проектной документации, содержащей все необходимые данные для реализации проекта.

    Третий этап — реализация проекта. Здесь осуществляется разработка программ­ного обеспечения (кодирование) в соответствии с проектными решениями, полу­ченными на предыдущем этапе. Методы, используемые для реализации, не имеют принципиального значения. Результатом выполнения данного этапа является го­товый программный продукт.

    На четвертом этапе проводится проверка полученного программного обеспечения на предмет соответствия требованиям, заявленным в техническом задании. Опыт­ная эксплуатация позволяет выявить различного рода скрытые недостатки, про­являющиеся в реальных условиях работы информационной системы.

    Последний этап — сдача готового проекта. Главная задача этого этапа — убедить заказчика, что все его требования реализованы в полной мере.

    Основные достоинства каскадной модели

    Каскадная модель имеет ряд положительных сторон, благодаря которым она хо­рошо зарекомендовала себя при выполнении различного рода инженерных разра­боток и получила широкое распространение. Рассмотрим основные достоинства модели «водопад»:

    - на каждом этапе формируется законченный набор проектной документации, отвечающий критериям полноты и согласованности. На заключительных этапах также разрабатывается пользовательская документация, охватывающая все предусмотренные стандартами виды обеспечения информационной системы: организационное, методическое, информационное, программное, аппаратное;

    - выполняемые в логичной последовательности этапы работ позволяют плани­ровать сроки завершения и соответствующие затраты.

    Каскадный подход хорошо зарекомендовал себя и при построении информационных систем, для которых в самом начале разработки можно достаточно точно и полно сформули­ровать все требования, с тем чтобы предоставить разработчикам свободу выбора реализации, наилучшей с технической точки зрения. К таким информационным системам, в частности, относятся сложные расчетные системы, системы реального времени.

    Тем не менее, несмотря на все свои достоинства, каскадная модель имеет ряд недо­статков, ограничивающих ее применение при разработке информационных сис­тем.

    Недостатки каскадной модели

    Перечень недостатков каскадной модели при ее использовании для разработки информационных систем достаточно обширен. Вначале просто перечислим их, а за­тем рассмотрим основные из них более подробно:

    - существенная задержка получения результатов;

    - ошибки и недоработки на любом из этапов выясняются, как правило, на после­дующих этапах работ, что приводит к необходимости возврата на предыдущие стадии;

    - сложность распараллеливания работ по проекту;

    - чрезмерная информационная перенасыщенность каждого из этапов;

    - сложность управления проектом;

    - высокий уровень риска и ненадежность инвестиций.

    Задержка получения результатов обычно считается главным недостатком каскад­ной схемы. Данный недостаток проявляется в основном в том, что вследствие после­довательного подхода к разработке согласование результатов с заинтересованными сторонами производится только после завершения очередного этапа работ. Поэтому может оказаться, что разрабатываемая информационная система не соответству­ет требованиям пользователей. Причем такие несоответствия могут возникать на любом этапе разработки — искажения могут непреднамеренно вноситься и проектировщиками-аналитиками, и программистами, так как они не обязательно хорошо разбираются в тех предметных областях, для которых производится разработка ин­формационной системы.

    Кроме того, используемые при разработке информационной системы модели автоматизируемого объекта, отвечающие критериям внутренней согласованно­сти и полноты, могут в силу различных причин устареть за время разработки (например, из-за внесения изменений в законодательство, колебания курса ва­лют и т. п.). Это относится и к функциональной модели, и к информационной модели, и к проектам интерфейса пользователя, и к пользовательской докумен­тации.

    Возврат на более ранние стадии. Данный недостаток каскадной модели в общем-то является одним из проявлений предыдущего. Поэтапная и последовательная работа над проектом может быть следствием того, что ошибки, допущенные на более ранних этапах, как правило, обнаруживаются только на последующих стадиях ра­боты над проектом. Поэтому, после того как ошибки проявятся, проект возвраща­ется на предыдущий этап, перерабатывается и снова передается на последующую стадию. Это может служить причиной срыва графика работ и усложнения взаимо­отношений между группами разработчиков, выполняющих отдельные этапы ра­боты.

    Самым же неприятным является то, что недоработки предыдущего уровня могут обнаруживаться не сразу на последующем уровне, а позднее (например, на стадии опытной эксплуатации могут проявиться ошибки в описании предметной облас­ти). Это означает, что часть проекта должна быть возвращена на начальный уро­вень работы. Вообще, работа может быть возвращена с любого этапа на любой пре­дыдущий этап.

    Одной из причин данной ситуации является то, что в качестве экспертов, уча­ствующих в описании предметной области, часто выступают будущие пользо­ватели системы, которые нередко не могут четко сформулировать то, что они хотели бы получить. Кроме того, заказчики и исполнители часто неправильно понимают друг друга вследствие того, что исполнители обычно не являются специалистами в предметной области решаемой задачи, а заказчики далеки от программирования.

    Сложность параллельного ведения работ. Отмеченные выше проблемы возникают вследствие того, что работа над проектом строится в виде цепочки последователь­ных шагов. Причем даже в том случае, когда разработку некоторых частей проекта (подсистем) можно вести параллельно, при использовании каскадной схемы рас­параллеливание работ весьма затруднительно. Сложности параллельного ведения работ связаны с необходимостью постоянного согласования различных частей проекта. Чем сильнее взаимозависимость отдельных частей проекта, тем чаще и тщательнее должна выполняться синхронизация, тем сильнее зависимы друг от друга группы разработчиков. Поэтому преимущества параллельного ведения ра­бот просто теряются.

    Отсутствие параллелизма негативно сказывается и на организации работы всего коллектива разработчиков. Работа одних групп сдерживается другими. Пока производится анализ предметной области, проектировщики, разработчики и те, кто занимается тестированием и администрированием, почти не имеют работы. Кроме того, при последовательной разработке крайне сложно внести изменения в проект после завершения этапа и передаче проекта на следующую стадию. Так, например, если после передачи проекта на следующий этап группа разработчиков нашла более эффективное решение, оно не может быть использовано. Это связано с тем, что более раннее решение уже, возможно, реализовано и связано с другими частями проекта.

    Информационная перенасыщенность. Проблема информационной перенасыщенности возникает вследствие сильной зависимости между различными группами разработчиков. Данная проблема заключается в том, что при внесении изменений в одну из частей проекта необходимо оповещать всех разработчиков которые использовали или могли использовать эту часть в своей работе. Когда система состоит из большого количества взаимосвязанных подсистем, синхронизация внутренней документации становится важной самостоятельной задачей.

    Сложность управления проектом при использовании каскадной схемы в основном обусловлена строгой последовательностью стадий разработки и наличием слож­ных взаимосвязей между различными частями проекта.

    Последовательность разработки проекта приводит к тому, что одни группы разра­ботчиков должны ожидать результатов работы других команд. Поэтому требуется административное вмешательство для того, чтобы согласовать сроки работы и со­став передаваемой документации.

    В случае же обнаружения ошибок в выполненной работе необходим возврат к пре­дыдущим этапам выполнения проекта. Это приводит к дополнительным сложнос­тям в управлении проектом. Разработчики, допустившие просчет или ошибку, вынуждены прервать текущую работу (над новым проектом) и заняться исправле­нием ошибок. Следствием этого обычно является срыв сроков выполнения как исправляемого, так и нового проектов. Требовать же от команды разработчиков ожидания окончания следующей стадии разработки нерационально, так как при­водит к существенным потерям рабочего времени.

    Упростить взаимодействие между группами разработчиков и уменьшить инфор­мационную перенасыщенность документации можно, уменьшая количество свя­зей между отдельными частями проекта. Однако это обычно весьма непросто. Да­леко не каждую информационную систему можно разделить на несколько слабо связанных подсистем.

    Высокий уровень риска. Чем сложнее проект, тем больше продолжительность каж­дого из этапов разработки и тем сложнее взаимосвязи между отдельными частями проекта, количество которых также увеличивается. Причем результаты разработ­ки можно реально увидеть и оценить лишь на этапе тестирования, то есть после завершения анализа, проектирования и разработки — этапов, выполнение кото­рых требует значительного времени и средств. Как уже было отмечено выше, за­поздалая оценка создает значительные проблемы при выявлении ошибок анализа и проектирования — требуется возврат проекта на предыдущие стадии и повторе­ние процесса разработки.

    Однако возврат на предыдущие стадии может быть связан не только с ошибками, но и с изменениями, произошедшими за время выполнения разработки в предмет­ной области или в требованиях заказчика. Причем возврат проекта вследствие этих причин на доработку не гарантирует, что предметная область снова не изменится к тому моменту, когда будет готова следующая версия проекта. Фактически это означает, что существует вероятность того, что процесс разработки «зациклится» и никогда не дойдет до сдачи в эксплуатацию. Расходы на проект будут постоянно расти, а сроки сдачи готового продукта — постоянно откладываться.

    Спиральная модель жизненного цикла

    Спиральная модель, в отличие от каскадной, предполагает итерационный процесс разработки информационной системы. При этом возрастает значение начальных этапов жизненного цикла, таких как анализ и проектирование. На этих этапах про­веряется и обосновывается реализуемость технических решений путем создания прототипов.

    Итерации

    Каждая итерация представляет собой законченный цикл разработки, приводящий к выпуску внутренней или внешней версии изделия (или подмножества конечно­го продукта), которое совершенствуется от итерации к итерации, чтобы стать за­конченной системой (рис).



    Рис. Спиральная модель жизненного цикла информационной системы

    Таким образом, каждый виток спирали соответствует созданию фрагмента или версии программного изделия, на нем уточняются цели и характеристики проек­та, определяется его качество, планируются работы следующего витка спирали. На каждой итерации углубляются и последовательно конкретизируются детали проекта, в результате чего выбирается обоснованный вариант, который доводится до окончательной реализации.

    Использование спиральной модели позволяет осуществлять переход на следую­щий этап выполнения проекта, не дожидаясь полного завершения работы на теку­щем — недоделанную работу можно будет выполнить на следующей итерации. Главная задача каждой итерации — как можно быстрее создать работоспособный продукт, который можно показать пользователям системы. Таким образом, суще­ственно упрощается процесс внесения уточнений и дополнений в проект.

    Преимущества спиральной модели

    Спиральный подход к разработке программного обеспечения позволяет преодо­леть большинство недостатков каскадной модели и, кроме того, обеспечивает ряд дополнительных возможностей, делая процесс разработки более гибким.

    Рассмотрим преимущества итерационного подхода более подробно:

    - итерационная разработка существенно упрощает внесение изменений в проект при изменении требований заказчика;

    - при использовании спиральной модели отдельные элементы информационной системы интегрируются в единое целое постепенно. При итерационном подхо­де интеграция производится фактически непрерывно. Поскольку интеграция начинается с меньшего количества элементов, то возникает гораздо меньше проблем при ее проведении (по некоторым оценкам, при использовании кас­кадной модели разработки интеграция занимает до 40 % всех затрат в конце проекта);

    - уменьшение уровня рисков. Данное преимущество является следствием пре­дыдущего, так как риски обнаруживаются именно во время интеграции. Поэто­му уровень рисков максимален в начале разработки проекта. По мере продви­жения разработки ожидаемый риск уменьшается. Данное утверждение спра­ведливо при любой модели разработки, однако при использовании спиральной модели уменьшение уровня рисков происходит с наибольшей скоростью. Это связано с тем, что при итерационном подходе интеграция выполняется уже на первой итерации и при выполнении начальных итераций выявляются многие аспекты проекта, такие как пригодность используемых инструментальных средств и программного обеспечения, квалификация разработчиков и т. п. На рис. приведены в сравнении графики зависимости уровня рисков от времени разра­ботки при использовании каскадного и итерационного подходов;

    - итерационная разработка обеспечивает большую гибкость в управлении про­ектом, давая возможность внесения тактических изменений в разрабатываемое изделие. Например, можно сократить сроки разработки за счет уменьшения функциональности системы или использовать в качестве составных частей си­стемы продукцию сторонних фирм вместо собственных разработок. Это может быть актуальным в условиях конкурентной борьбы, когда необходимо проти­востоять продвижению изделия, предлагаемого конкурентами;



    Время

    Рис. . Зависимость рисков от времени разработки

    - итерационный подход упрощает повторное использование компонентов (по­зволяет использовать компонентный подход к программированию — более по­дробно об этом мы будем говорить в следующей главе). Это обусловлено тем, что гораздо проще выявить (идентифицировать) общие части проекта, когда они уже частично разработаны, чем пытаться выделить их в самом начале про­екта. Анализ проекта после проведения нескольких начальных итераций по­зволяет выявить общие, многократно используемые компоненты, которые на последующих итерациях будут совершенствоваться;

    - спиральная модель позволяет получить более надежную и устойчивую систе­му. Это связано с тем, что по мере развития системы ошибки и слабые места обнаруживаются и исправляются на каждой итерации. Одновременно могут корректироваться критические параметры эффективности, что при использо­вании каскадной модели выполняется только перед внедрением системы;

    - итерационный подход позволяет совершенствовать процесс разработки — ана­лиз. проводимый в конце каждой итерации, позволяет проводить оценку того, что должно быть изменено в организации разработки, и улучшить ее на следу­ющей итерации.

    Проблемы, возникающие при использовании спиральной модели:

    Основная проблема спирального цикла — определение момента перехода на следующий этап. Для ее решения необходимо ввести временные ограничения на каждый из этапов жизненного цикла. Иначе процесс разработки может превратиться бесконечное совершенствование уже сделанного. При итерационном подходе полезно следовать принципу «лучшее —враг хорошего». Поэтому завершение итерации должно производиться строго в соответствии с планом, даже если не вся не вся запланированная работа закончена.

    Планирование работ обычно проводится на основе статистических данных, полученных в предыдущих проектах, и личного опыта разработчиков.


    Уровень ответственности системных аналитиков


    Анализ требований

    Выпуск программного продукта



    Установление соответствия











    Внешняя спецификация

    Комплексное тестирование







    1   2   3   4   5   6   7   8   9   10   11


    написать администратору сайта