Разработка АСР

Автор работы: Пользователь скрыл имя, 28 Декабря 2011 в 11:16, дипломная работа

Описание работы

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

Содержание работы

Введение 4
1 Анализ технического задания 5
1.1 Техническое задание 5
1.2 Общие выводы из технического задания 5
2 Подходы к проектированию баз данных 6
2.1 Основные понятия теории реляционных баз данных 6
2.2 Сервер базы данных 10
2.2.1 Технология и модели "клиент-сервер" 10
2.2.2 Механизмы реализации активного ядра 18
2.2.3 Хранимые процедуры 19
2.2.4 Правила (триггеры) 20
2.2.5 Механизм событий 21
2.3 Обработка распределенных данных 21
2.4 Взаимодействие с PC-ориентированными СУБД 28
2.5 Обработка транзакций 31
2.6 Средства защиты данных в СУБД 35
2.7 Применение CASE-средств для информационного моделирования в системах обработки данных. 39
3 Реализация базы данных 40
3.1 Анализ существующей системы 41
3.2 Новая схема обмена информацией 42
3.3 Выбор операционной системы 42
3.4 Выбор сервера баз данных 43
3.5 Выбор средств разработки 44
3.6 Проектирование структуры базы данных 44
4 Реализация клиентского приложения 45
4.1 Назначение и состав клиентского приложения 45
4.2 Безопасность доступа к данным 45
4.2.1 Идентификация 45
4.2.2 Авторизация 46
4.2.3 Управление доступом на основе ролей 47
4.3 Алгоритм работы приложения 48
5 Разработка таблиц 48
5.1 Структура таблицы “nodes_prolog” 49
5.2 Структура таблицы “nodes_elektro” 50
5.3 Структура таблицы “ elektro_pokaz” 50
5.4 Структура таблицы “t943_name” 51
5.5 Структура таблицы “t942_name” 52
5.6 Структура таблицы “t943_name_totals” 52
5.7 Структура таблицы “t942_name_totals” 53
6 Руководство оператора 54
6.1 Запуск приложения 54
6.2 Начало работы 55
7 Экономическая часть 60
7.1 Особенности программного продукта как товара 60
7.2 Расчет затрат на изготовление подсистемы 60
7.3 Расчет экономической эффективности 69
8 Безопасность жизнедеятельности. Природопользование и охрана окружающей среды. 71
8.1 Краткое содержание дипломного проекта 71
8.2 Безопасность проекта 72
8.2.1 Вредные и опасные производственные факторы при работе с ПЭВМ 72
8.2.2 Электро- и пожаробезопасность на рабочем месте оператора ПЭВМ 73
8.2.2.1 Электробезопасность на рабочем месте 74
8.2.2.2 Пожарная безопасность на рабочем месте 76
8.2.3 Обеспечение микроклимата на рабочем месте. Освещенность, шум, вибрация 78
8.2.4 Расчет освещенности на рабочем месте оператора 79
8.2.4.1 Вводная часть 79
8.2.4.2 Описание помещения, в котором располагается рабочее место 79
8.2.4.3 Расчет освещенности на рабочем месте 80
8.2.4.4 Особенности освещения рабочих мест с видеотерминальными устройствами 82
8.2.4.5 Заключение 82
8.3 Эргономичность проекта 83
8.4 Природопользование проекта. Работа с видеодисплейными терминалами ПЭВМ. 85
8.5 Выводы по разделу 87
9 Выводы по выполненной работе 88
10 Список использованных источников 89

Файлы: 7 файлов

Диплом.docx

— 620.40 Кб (Скачать файл)
  • Прозрачность  расположения;
  • Прозрачность сети;
  • Автоматическое преобразование форматов данных;
  • Автоматическая трансляция кодов;
  • Межоперабельность;
  • Прозрачность расположения.
 

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

      Любой пользователь или любая прикладная программа оперирует с одной  или несколькими базами данных. В  том случае, когда прикладная программа  и сервер БД выполняются на одном  и том же узле, проблемы расположения не возникает. Для получения доступа  к базе данных, пользователю или  программе достаточно указать имя  базы.

      Однако  в том случае, когда прикладная программа запускается на локальном  узле, а база данных находится на удаленном, возникает проблема идентификации  удаленного узла. Для того, чтобы получить доступ к базе данных на удаленном узле, необходимо указать имя удаленного узла и имя базы данных. Если использовать жестко фиксированное имя узла в паре "имя_узла, имя_БД", то прикладная программа становится зависимой от расположения БД. Например, обращение к БД "host::stock", где первый компонент есть имя узла, будет зависимым от расположения.

      Одно  из возможных решений этой проблемы состоит в использовании виртуальных  имен узлов. Управление ими обеспечивается специальным программным компонентом  СУБД - сервером имен (Name Server), который адресует запросы клиентов к серверам.

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

      Клиент  и сервер взаимодействуют по сети с конкретной топологией; для поддержки  взаимодействия всегда используется определенный протокол. Следовательно, оно должно быть организовано таким образом, чтобы  обеспечивать независимость как от используемого сетевого аппаратного обеспечения, так и от протоколов сетевого обмена. Чтобы обеспечить прозрачный доступ пользователей и программ к удаленным данным в сети, объединяющей разнородные компьютеры, коммуникационный сервер должен поддерживать как можно более широкий диапазон сетевых протоколов (TCP/IP, DECnet, SNA, SPX/IPX, NetBIOS, AppleTalk, и др.).

      Как только несколько компьютеров различных  моделей под управлением различных  операционных систем соединяются в  сеть, сразу возникает вопрос о  согласовании форматов представления  данных. Действительно, в сети могут  быть компьютеры, отличающиеся разрядностью (16-ти, 32-х и 64-х разрядные процессоры), порядком следования байт в слове, представлением чисел с плавающей точкой и  т.д. Задача коммуникационного сервера  состоит в том, чтобы на уровне обмена данными обеспечить согласование форматов между удаленным и локальным  узлами с тем, чтобы данные, извлеченные  сервером из базы на удаленном узле и переданные по сети, были правильно  истолкованы прикладной программой на локальном узле.

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

      В реальной жизни сервер базы данных должен обслуживать одновременно множество  запросов от клиентов - следовательно, в один момент времени таких пар  «клиент-сервер» может быть несколько. Таким образом, все проблемы взаимодействия должны решаться коммуникационным сервером для всех этих взаимодействующих  пар.

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

      Именно  поэтому для современных распределенных СУБД важно иметь многопотоковый коммуникационный сервер, который берет на себя задачи сетевой поддержки множества клиентов, одновременно обращающихся к серверу. На каждом узле сети он поддерживает множество пар соединений "клиент-сервер" и позволяет существовать одновременно множеству независимых сеансов работы с базами данных.

      С точки зрения клиента доступ к  распределенной базе данных должен выглядеть  точно так же, как доступ к централизованной БД. При организации прозрачного  доступа к распределенной базе данных возникают следующие задачи:  

  • Управление  именами в распределенной среде;
  • Оптимизация распределенных запросов;
  • Управление распределенными транзакциями.
 

      Первая  решается путем использования глобального  словаря данных. Он хранит информацию о распределенной базе: расположение данных, возможности других СУБД (если используется шлюз), сведения о скорости передачи по сети с различной топологией и т.д.

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

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

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

      Решение всех трех задач, возложено на специальный  компонент СУБД - сервер распределенных баз данных (Distributed Database Server).

      Если  база данных расположена на одном  узле, а сервер БД и прикладная программа  выполняются там же, то не требуется  ни коммуникационный сервер, ни сервер распределенной БД. Когда же прикладная программа выполняется на локальном  узле, БД находится на удаленном  узле и там же выполняется сервер БД, то на удаленном узле необходим  коммуникационный сервер, а на локальном - сервисная коммуникационная программа.

      Если  локальные БД расположены на нескольких узлах, то для доступа к распределенной БД необходим и сервер распределенной БД, и коммуникационный сервер.

      Важнейшее требование к современным СУБД - межоперабельность (или интероперабельность). Это качество можно трактовать как открытость системы, позволяющую встраивать ее как компонент в сложную разнородную распределенную среду. Межоперабельность достигается как за счет использования интерфейсов, соответствующих международным, национальным и промышленным стандартам, так и за счет специальных решений.

      Для СУБД это качество означает следующее:  

  • способность приложений, созданных средствами разработки данной СУБД, оперировать над базами данных в "чужом" формате так, как  будто это собственные базы данных;
  • свойство СУБД, позволяющее ей служить в качестве поставщика данных для любых приложений, созданных средствами разработки третьих фирм, поддерживающих некоторый стандарт обращения к базам данных.
 

      Первое  достигается использованием шлюзов, второе - использованием интерфейсов ODBC (Open Database Connectivity) и BDE (Borland Database Engine).

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

      Существует  альтернатива технологии распределенных БД - тиражирование данных. Принципиальное отличие технологии тиражирования  данных от технологии распределенных баз данных (которую часто для  краткости называют технологией STAR) заключается в отказе от распределенных данных. Ее суть состоит в том, что  любая БД (как для СУБД, так  и для работающих с ней пользователей) всегда является локальной; данные всегда размещаются локально на том узле сети, где они обрабатываются; все  транзакции в системе завершаются  локально.

      Тиражирование данных - это асинхронный перенос  изменений объектов исходной базы данных (source database) в БД, принадлежащие различным узлам распределенной системы. Функции тиражирования данных выполняет специальный модуль СУБД - сервер тиражирования данных, называемый репликатором (replicator). Его задача - поддержка идентичности данных в принимающих базах данных (target database) данным в исходной БД. Сигналом для запуска репликатора служит срабатывание триггера, перехватывающего любые изменения тиражируемого объекта БД. Возможно и программное управление репликатором посредством сигнализаторов о событиях в базе данных.

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

      Детали  тиражирования данных полностью  скрыты от прикладной программы; ее функционирование никак не зависит от работы репликатора, который целиком находится в  ведении администратора БД. Следовательно, для переноса программы в распределенную среду с тиражируемыми данными  не требуется ее модифицировать.

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

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

      Преимущества  технологии тиражирования данных:  

  1. Данные  всегда расположены там, где они  обрабатываются - следовательно, скорость доступа к ним существенно  увеличивается.
  2. Передача только операций, изменяющих данные (а не всех операций доступа к удаленным данным, как в технологии STAR), и к тому же в асинхронном режиме позволяет значительно уменьшить трафик.
  3. Со стороны исходной БД для принимающих БД репликатор выступает как процесс, инициированный одним пользователем, в то время как в физически распределенной среде с каждым локальным сервером работают все пользователи распределенной системы, конкурирующие за ресурсы друг с другом.
  4. Никакой продолжительный сбой связи не в состоянии нарушить передачу изменений. Дело в том, что тиражирование предполагает буферизацию потока изменений (транзакций); после восстановления связи передача возобновляется с той транзакции, на которой тиражирование было прервано.

Приложение _А.docx

— 14.16 Кб (Просмотреть файл, Скачать файл)

Хранимые процедуры.docx

— 22.02 Кб (Просмотреть файл, Скачать файл)

~$Диплом.docx

— 162 байт (Скачать файл)

Информация о работе Разработка АСР