В-третьих, на любом серьезном предприятии постоянно ведется обработка больших объемов данных с помощью многочисленных многофункциональных программ – приложений. Эти приложения при системном подходе к делу опираются на общие правила формализованного хранения данных (обычно в многочисленных взаимосвязанных таблицах баз данных) и общие методы поиска данных и манипулирования ими. Эти методы реализуются в виде программных процедур в рамках так называемых систем управления базами данных (СУБД). Относящиеся к СУБД процедуры используются всеми основными приложениями с помощью специально созданного для этих целей языка структурированных запросов SQL (Structured Query Language). Такие СУБД называют SQL-серверами. SQL-сервер – это не обслуживающий компьютер, а обслуживающий программный комплекс, не только предоставляющий другим программам данные, но и выполняющий их типовую обработку по SQL-запросам. СУБД в основном размещаются на файл-сервере. Тем самым общим ресурсом предприятия становятся не только основные данные, но и типовые программы обработки этих данных.
Итак, достоинством компьютерных сетей является коллективное использование информационных ресурсов, технических и программных средств многими пользователями. Рассмотрим теперь основные виды сетей и важнейшие понятия сетевых технологий.
Простейшую сеть можно получить, связав группу компьютеров, на каждом из которых установлена ОС Windows (95, 98, NT, ME, 2000 или XP). В каждый из этих компьютеров надо вставить сетевую карту (плату) и связать кабелем наружные разъемы сетевых карт. Такая сеть называется локальной одноранговой. Она может быть использована в масштабе отдела или малого предприятия. В качестве кабеля применяется витая пара, тонкий или толстый коаксиальный или волоконнооптический кабель. Данные по сети передаются по битам со скоростью 10 Мбит/сек или 100 Мбит/сек. Устройства (в основном это компьютеры), подключенные к передающей среде сети, называют узлами, а усредненную геометрическую схему соединения узлов называют топологией локальной вычислительной сети (ЛВС). Основные топологии ЛВС – кольцевая, шинная и звездообразная – схематически представлены на рис. 5.2. Пользователь компьютера, являющегося узлом ЛВС, при загрузке ОС вводит пароль и получает доступ к файлам, хранимым на других компьютерах, и к периферийным устройствам, подключенным к другим узлам.
| |||||||||||
| |||||||||||
|
| ||||||||||
| |||||||||||
|
| |||||||||||||||
| |||||||||||||||
|
| ||||||||||||||
| |||||||||||||||
| |||||||||||||||
|
| ||||||||||||||
| |||||||||||||||
(а) (б) (в)
Рис. 5.2. Основные топологии ЛВС: а - кольцевая, б - шинная, в - звездообразная
Взаимосвязь узлов сети определяется соглашениями – протоколами. Например, электрические характеристики сигналов, параметры разъемов и т.п. определяются протоколом физического уровня, а правила обмена данными между приложениями - протоколами логического уровня. Стандарты протоколов разрабатываются международными институтами и комитетами и принимаются Международной Организацией по Стандартизации (ISO – International Standard Organization).
На крупных предприятиях обычно используется не одноранговая сеть, а ЛВС с выделенным файл-сервером. В отличие от сервера, компьютеры в узлах такой сети называют еще рабочими станциями. Рабочие станции одного отдела или, например, размещенные на одном этаже здания, обычно соединяются со специальным коммутирующим устройством, называемым концентратором (HUB), а концентраторы соединяются с файл-сервером. В такой сети устанавливается сетевая ОС, например, Microsoft Windows NT Server, или какая-либо модификация ОС Unix, или ОС Novell NetWare. Сетевая ОС устанавливается на сервере, а на каждой рабочей станции, кроме Windows (95, 98, NT, ME, 2000, XP) или другой несетевой ОС, размещается клиентская часть сетевой ОС. Если на файл-сервере устанавливается еще СУБД (например, MS SQL Server или Oracle), то эта СУБД работает под управлением сетевой ОС, причем на каждой рабочей станции размещается еще клиентская часть СУБД. Технологию работы в сети, где каждый пользователь-клиент с помощью СУБД имеет доступ к базам данных предприятия на сервере, называют технологией клиент/сервер.
Кроме локальных сетей, всемирное распространение получили глобальные сети, особенно Internet – разветвленная сеть, включающая в себя серверы, разбросанные по всему миру. Серверы имеют свои адреса и управляются специализированными программами. Они позволяют пересылать почту и файлы, производить поиск в базах данных и т.п. Для подключения к Internet требуется модем и канал связи, соединяющий ЛВС предприятия или личный компьютер пользователя с сервером провайдера – предприятия, предоставляющего информационные услуги Internet.
Модем необходим потому, что передаваемые сигналы, соответствующие битам информации, накладываются (мо дуляция) на синусоидальный сигнал несущей частоты. Благодаря этому по одному каналу могут передаваться данные многих абонентов на разных несущих частотах. Модем компьютера, принимающего информацию, обеспечивает дем одуляцию сигнала, т.е. выделение из суммарного сигнала цепочек получаемых битов информации. Чаще всего используются модемы со скоростью передачи 56 Кбит/сек. Модемы, связывающие ЛВС со специальной выделенной линией связи, обеспечивают еще большую скорость передачи.
В качестве канала связи для соединения с провайдером может использоваться либо выделенная линия, либо обычный телефонный канал. Сценарий соединения выглядит так. Пользователь запускает программу-проводник, обеспечивающую навигацию в сети Internet, например, Microsoft Internet Explorer (Explorer – проводник) или Opera. В рабочем окне этой программы предусмотрена строка (поле) для указания сетевого адреса. Если пользователь ввел этот адрес, а его компьютер еще не соединен с узлом провайдера, то на экране появится диалоговое окно. В этом окне указывается телефон провайдера (в случае применения обычного телефонного канала связи), имя клиента и пароль. После этого происходит соединение, и можно пользоваться всеми видами сервиса Internet. Для полноты картины остается рассмотреть адресацию в Internet и виды предоставляемых информационных услуг.
В Internet каждому компьютеру присваивается уникальный сетевой адрес – IP-адрес (IP – Internetwork Protocol), имеющий длину 32 бита и состоящий из 4 частей по 8 битов. Каждая часть может принимать значения от 0 до 255 и отделяется от других частей точкой, например, 133.107.4.19. В четырех байтах IP-адреса записывается адрес сети и адрес компьютера в этой сети. В зависимости от масштаба сети под адрес компьютера в ней отводятся 3, 2 или 1 байт (сети классов A,B,C). Чем длиннее адрес компьютера (масштабнее сеть), тем меньше байтов отводится на адрес сети. Класс сети определяется по значению первого числа IP-адреса: класс A – от 0 до 127, класс B – от 128 до 191, класс C – от 192 до 223. В приведенном нами примере сеть относится к классу B, ее адрес - 133.107, адрес компьютера – 4.19.
Для удобства запоминания каждому IP-адресу ставится в соответствие буквенно-цифровой адрес, называемый доменным. Пользователи Internet имеют дело именно с доменными адресами, которые преобразуются в IP-адреса специальными серверами имен. Доменный адрес состоит из двух частей, разделенных символом @:
<идентификатор пользователя>@<название домена>
Идентификатор пользователя и название домена могут состоять из сегментов, разделенных точками. В адресе допускается использование латинских букв, цифр и некоторых других символов. Например, www.bfh.esib.ru – адрес сервера Байкальского фондового дома (по русски – БФД, Восточная Сибирь, Россия). Если надо указать адрес электронной почты конкретного сотрудника, то к доменному имени сервера слева добавляется не www, а идентификатор человека, например: ivan.petrov@bfh.esib.ru или ipetrov@bfh.esib.ru. В этом примере идентификатор пользователя в первом случае состоит из двух сегментов (это бывает редко), во втором - из одного, а название домена – из трех сегментов – поддоменов, отображающих название организации, географического региона, страны. Поддомен верхнего уровня, обозначающий страну, обычно состоит из двух букв: ru – Россия, su – территория бывшего Советского Союза, uk – Великобритания и т.п. В США традиционно используется другая система: поддомен верхнего уровня состоит из трех букв, обозначающих тип организации-владельца. Например: com – коммерческие организации, gov – правительственные, edu – образовательные. Поддомен второго уровня в России обычно обозначает город или регион. Например: msk – Москва, irk – Иркутск, esib – Восточная Сибирь.
Итак, набрав адрес требуемого сервера в поле адреса программы-проводника, можно воспользоваться информационными услугами этого сервера. Большая часть серверов – это WWW-серверы всемирной информационной сети (World-Wide-Web – всемирная паутина). Такие серверы предоставляют информационные страницы (Web-страницы) с гипертекстом и графическим оформлением. Гипертекст отличается от обычного наличием ссылок на другие документы и возможностью немедленного переключения на них. Ссылка оформляется как выделенное шрифтом и цветом слово или понятие из нескольких слов, или же как выделенный рисунок. Ссылке соответствует адрес в сети. Поэтому документ, хранимый на каком-либо сервере в России (пусть это будет, например, информация для инвесторов на сервере Байкальского фондового дома) может ссылаться на документ, хранимый в США (например, на сервере Нью-Йоркской фондовой биржи). Таким образом, создатели Web-страниц имеют возможность ссылаться не только на множество страниц на своем же сервере, но и на множество страниц WWW, рассеянных по всему миру. Для переключения на другую Web-страницу надо просто щелкнуть мышью по выделенному тексту.
При создании страниц WWW используется специальный язык HTML (Hypertext Markup Language – язык разметки гипертекста). Неявно используя этот язык, HTML-документ можно подготовить с помощью приложений, входящих в состав MS Office (Word, Excel, PowerPoint – см. пункт меню Файл/Сохранить в формате HTML), но лучше воспользоваться специальным приложением FrontPage или Dreamweaver. HTML-документ может содержать, кроме текста и графики, звук и видео. Поскольку создание собственного сервера WWW является сложным и дорогостоящим, многие пользователи Internet размещают свои Web-страницы на уже существующих серверах.
Для того, чтобы определить на каких серверах хранится представляющая интерес информация, обращаются к услугам поисковых серверов. Их информационные системы состоят из двух частей. Одна из этих частей (с ней работает пользователь) осуществляет поиск в своем справочнике (индексе) Web-страниц. Другая часть – это сложная программа, которая постоянно связывается с WWW-серверами во всем мире, анализирует содержимое их Web-страниц, пополняя индекс. Эта часть системы называется crawler –«ползун». К числу популярных поисковых серверов, относится AltaVista, поддерживающая индексирование и поиск документов на русском языке и выполняющая два варианта поиска: простой и сложный (расширенный). Простой поиск эффективен только применительно к редким терминам. Сложный поиск поддерживает такие критерии отбора, как логические операции над ключевыми словами, поиск целых фраз, поиск документов только на определенных серверах или доменах и др. При обращении к ресурсам Internet обычно указывают их URL-адрес. URL – это унифицированный указатель ресурсов (Uniform Resource Locator). Так, для сервера AltaVista URL имеет вид http://www.altavista.com. Здесь http:// указывает на протокол, используемый при адресации, а www.altavista.com задает доменное имя (сетевой адрес) сервера. В России получили признание поисковые серверы Rambler (www.rambler.ru) и Яndex (www.yandex.ru). На последнем широкие возможности предоставляет страница расширенного поиска (www.yandex.ru/advanced.html).
Чрезвычайно важна для многих пользователей почтовая служба Internet. Почтовые услуги предоставляют как специализированные почтовые серверы, так и большинство провайдеров. В настоящее время бесплатные почтовые ящики практически неограниченных размеров предоставляют информационные порталы Mail.ru, Rambler.ru, Lenta.ru и др. При регистрации новый пользователь назначает себе имя и пароль. Для него резервируются сетевой адрес и каталоги на сервере: Входящие – каталог для принятых писем, Отправленные – каталог для хранения отправленных писем, Написать письмо – для подготовки и отправки писем и др. Письмо можно подготовить заранее текстовым редактором и скопировать его в буфер обмена, затем c помощью программы Internet Explorer открыть Web-страницу почтового сервера, указать свое имя и пароль, выбрать страницу Написать письмо, скопировать из буфера обмена письмо, указать в поле адреса сетевой адрес получателя и нажать кнопку Отправить. В качестве приложения к письму можно прикрепить один или несколько файлов (кнопка Прикрепить). Для просмотра поступивших писем надо выбрать страницу Входящие. В комплексе приложений Microsoft Office работу с почтой упрощает программа OutLook. Часто используют и программу The Bat.
Электронная почта предназначена, прежде всего, для обмена текстовой информацией, хотя к письму всегда можно прикрепить различные файлы, в том числе и графические документы при некоторых ограничениях (обычно это первые мегабайты) на их размеры. Многие пользователи заинтересованы в получении из Internet программного обеспечения, музыки и других файлов большого размера. Информацию в виде файлов, предназначенных для открытого доступа, предоставляют FTP-серверы. Чтобы обеспечить перемещение файлов между различными операционными системами, встречающимися в узлах Internet, используется протокол FTP (File Transfer Protocol). Для копирования файлов с FTP-серверов удобно использовать операционную оболочку FAR, которую поясним в следующем разделе. Здесь лишь заметим, что при использовании FAR работа с каталогами и файлами на FTP-сервере ничем не отличается от работы с каталогами и файлами на жестком диске своего компьютера. Для “выкачивания” c серверов файлов большого размера удобно использовать специальные программы типа NetVampire и ReGet, которые обеспечивают продолжение копирования файла в случае сбоя или разрыва связи с точки разрыва, а не начинают процесс сначала.
Кроме рассмотренных информационных услуг, глобальная сеть Internet предоставляет и некоторые другие возможности: телеконференции, рассылка новостей, общение в оперативном режиме с помощью сервера ICQ, электронные магазины и др.
Некоторые технологии Internet (HTML-документы и др.) оказались настолько удобными, что стали применяться в локальных сетях вместе с соответствующими протоколами. Такие информационные технологии в локальных сетях получили название Intranet-технологий. Особенно большой эффект в масштабе крупной организации дает интеграция технологии клиент/сервер с Intranet-технологией. Первая из них обеспечивает формализованное хранение и обработку больших объемов данных, а вторая – доступность и обзорность информации высоких уровней обобщения, т.е. информации, используемой для принятия решений. Сочетание этих двух технологий обычно предусматривает автоматическое программное обновление HTML-страниц при изменении на SQL-сервере отражаемой ими информации.
Контрольные вопросы к разделу 5: классы технических средств информационных технологий; основные блоки персонального компьютера, его структурная схема; основные периферийные устройства, подключаемые к ПК; компьютерные сети, преимущества работы в сети; локальные вычислительные сети – одноранговые и с выделенным сервером; основные топологии ЛВС; сетевые протоколы; понятие о сетевой ОС, о SQL-сервере и о технологии клиент/сервер; глобальные сети; адресация в Internet; информационные услуги Internet, WWW-серверы, HTML-страницы, поисковые серверы, электронная почта, FTP-серверы; понятие о технологии Intranet.
6. Классификация и обзор программного обеспечения
Программное обеспечение (ПО - software) информационных технологий по назначению подразделяют на системное ПО, инструментальные средства программирования и прикладное ПО.
6.1. Системное программное обеспечение
Системное ПО (System Software) – это программы и программные комплексы, обеспечивающие работу компьютеров и вычислительных сетей. К системному ПО относят операционные системы и операционные оболочки, программы тестирования оборудования, обслуживания дисков, обслуживания сетей, антивирусные программы и архиваторы. С некоторой условностью к системному ПО можно отнести и сетевые СУБД (системы управления базами данных), поскольку они создают условия для работы прикладных программ на рабочих станциях пользователей, предоставляя им данные, хранимые на сервере.
Операционные системы (ОС) делятся на одно- и многозадачные, непереносимые и переносимые на другие типы компьютеров, несетевые и сетевые.
Однозадачной ОС является MS DOS, с которой современный специалист уже не имеет дела, но ее знание полезно, т.к. многие решения, использованные в этой ОС, применяются и в последующих операционных системах. В этом пособии мы ограничимся только краткими сведениями о DOS. Другие ОС, которые мы будем упоминать, являются многозадачными, т.е. поддерживают одновременное функционирование нескольких приложений. Так ОС Windows 98/NT/2000/XP, Unix позволяют запустить какое-нибудь приложение, например, выполняющее долговременные вычисления или копирующее данные из сети Internet, и заняться на ПК другой работой с помощью других приложений.
Переносимость ОС и большинства других программных продуктов всегда довольно относительна. Например, ОС Unix (для ПК получает все большее распространение версия Linux) была написана на языке программирования Си. Поскольку компиляторы Си разработаны для всех современных ЭВМ, то тексты основных программных модулей этой ОС могут быть преобразованы в объектные модули (см. раздел 4) для конкретной ЭВМ. Но, кроме основных модулей, всегда есть множество дополнительных, учитывающих особенности данного типа ЭВМ. Например, мощные вычислительные комплексы обычно многопроцессорные, и ОС должна это учитывать. К тому же сами системы программирования и входящие в них компиляторы также работают под управлением ОС. Поэтому адаптация ОС к другому типу ЭВМ – это очень сложная работа, выполняемая крупными компьютерными фирмами. Для пользователя важна не переносимость ОС, а возможность перенесения приложений и последующего их использования на другой ЭВМ, но в привычной операционной среде. Если приложение разработано для ОС Unix, а не для Windows, применяемой только на ПК, то его легче перенести на другие типы ЭВМ, где также применяется Unix, и, следовательно, системы программирования используют процедуры этой же ОС. Самое же главное условие переносимости приложения – это наличие на ЭВМ другого типа той системы программирования, с помощью которой данное приложение создано. Если же приложение использует СУБД, то надо, чтобы на ЭВМ другого типа имелась бы эта же или аналогичная СУБД. Для большинства пользователей, работающих на ПК, проблема переносимости программ не актуальна, так как эти пользователи и не собираются переходить на недоступные им по ценам суперкомпьютеры и наращивают свои вычислительные мощности путем развития сетевых коммуникаций.
К числу сетевых ОС относятся все версии Unix, Microsoft Windows NT Server, Novell NetWare и некоторые другие. Эти ОС поддерживают работу пользователей в локальной сети с выделенным сервером (см. раздел 4). Операционные системы Windows 98/NT/2000/XP поддерживают работу в одноранговой ЛВС и хорошо взаимодействуют с сетевой ОС Windows NT, установленной на сервере. ОС Linux в большинстве организаций используют на серверах Internet. Такой сервер связывается через модем с глобальной сетью и предоставляет возможность работы с Internet всем пользователям локальной сети.
Упомянув основные ОС, применяемые в настоящее время, далее ограничимся лишь кратким рассмотрением операционных систем корпорации Microsoft – MS DOS и Windows. На примере этих систем можно видеть, как постепенно изменялся состав ОС. Сначала считалось, что операционная система должна лишь организовывать и обеспечивать работу всех других программ на ЭВМ определенного типа. Многочисленные программы, полезные для повышения эффективности компьютера (наиболее экономное использование оперативной памяти, проверка, дефрагментация, сжатие дисков и др.), разрабатывались и поставлялись на рынок различными фирмами – независимыми производителями ПО. Но как только независимый производитель создавал программный продукт, который стремились приобрести почти все пользователи, корпорация Microsoft включала функции этого продукта в свою ОС. В результате Microsoft не только имеет почти полную монополию на ОС для ПК, но и постоянно расширяет трактовку принадлежности к ОС. Глава Microsoft Билл Гейтс неоднократно заявлял, что объемы и стандарты в программном обеспечении ПК ведут к естественной монополии. В настоящее время большинство ПК в мире поставляется не только с установленной Windows, но и с MS Office. Приобретая компьютер с Windows XP и MS Office, «средний пользователь» обнаруживает, что у него есть почти все, что ему требуется для работы. Нажмите кнопку Пуск и просмотрите состав стандартных, а среди них и служебных программ, включенных в Windows. Среди них текстовые редакторы Блокнот и WordPad, проводник по сети Internet, средства работы с мультимедиа, калькулятор, программа просмотра рисунков, графический редактор Paint и служебные программы проверки, дефрагментации и сжатия диска. Если к этому набору добавить еще комплекс приложений MS Office, то мы получим почти все, что требуется для ведения документации, выполнения расчетов и создания баз данных на небольшом предприятии. Поэтому для многих пользователей MS Office фактически является продолжением ОС – платформой для ведения большей части их работ на ПК. Но вернемся к рассмотрению ОС.
Операционная система MS DOS до появления ОС Windows-95 использовалась практически на всех ПК. Даже широкое распространение в 1993-95 г.г. операционных оболочек Windows 3.1 и Windows 3.11 не уменьшило роли MS DOS. Эти операционные оболочки (вторая из них поддерживала работу в одноранговой ЛВС) лишь дополняли MS DOS, улучшая интерфейс пользователя и конкурируя не столько с самой ОС, сколько с другой общепризнанной операционной оболочкой Norton Commander. Операционные оболочки возникли в связи со стремлением облегчить работу пользователя, так как MS DOS управлялась с помощью команд, которые он вводил в командной строке. Например, команда Copy C:\doc99\*.doc C:\vl\*.doc означает, что ОС должна скопировать все файлы, имеющие имена с расширением doc, из каталога C:\doc99 в каталог C:\vl. Если пользователь забывал, как записать команду копирования файлов, он набирал в командной строке Copy /? и получал на экране справку о функциях и операндах данной команды. Количество команд, которые необходимы для работы, довольно велико. Это команды смены текущего (активного) каталога (CD), создания нового каталога (MD), вывода на экран списка каталогов и файлов в указанном или текущем каталоге (DIR), форматирования диска (FORMAT), копирования (DISKCOPY) и сравнения (DISKCOMP) дискет, перемещения (MOVE), копирования (COPY) и удаления (DEL) файлов и др. Чтобы выполнить программу, надо было задать в командной строке полный путь к EXE-файлу, в котором эта программа содержится. Можно было и просто ввести в командной строке имя программы с операндами (через пробелы), но тогда предварительно в команде PATH надо было перечислить пути к тем каталогам, в которых могут находиться используемые программы – как прикладные, так и системные. Для того чтобы программы могли использовать более 640 Кбайт основной памяти и чтобы они могли обращаться к периферийным устройствам, надо было предварительно загрузить в оперативную память резидентные программы (постоянно находящиеся в ОП) – драйверы устройств. Таким образом, пользователь должен был довольно много помнить. Для облегчения его работы применялись, во-первых, командные файлы и, во-вторых, операционные оболочки.
Командный файл (пакетный файл - Batch File) содержит пакет последовательно выполняемых команд DOS. Это могут быть команды смены текущего каталога, команда PATH, команды загрузки с диска в ОП драйверов, исполнения тех или иных программ. Командный файл имеет имя с расширением BAT. При его вызове могут указываться параметры, например, параметры выполняемых по командам программ - имена входных и выходных файлов и др. Из пакетного файла можно вызывать другие командные файлы (CALL имя файла). В пакетный файл можно включать комментарии (REM текст), метки (: END) и даже команды условного перехода (IF ERRORLEVEL 1 GOTO END). Таким образом, пакетный файл позволяет реализовать алгоритм обработки данных, разветвляющийся в зависимости от успешности или результатов завершения работы программ. Операционные оболочки рассмотрим позже, а сейчас остановимся на процессе загрузки MS DOS и на ее файловой системе, так как именно эти вопросы важны для понимания работы операционных систем.
Процесс запуска ПК и подготовки ОС к работе включает следующие шаги: