Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Глава 4. Інформаційні технології.doc
Скачиваний:
0
Добавлен:
01.05.2025
Размер:
1 Mб
Скачать

4.6.5. Багаторівневі архітектури ”клієнт-сервер”

Багаторівневі архітектури ”клієнт-сервер” більш раціонально розподіляють модулі обробки даних, які в цьому випадку виконуються на одному або декількох окремих серверах. Ці програмні модулі виконують функції сервера для інтерфейсів з користувачами і клієнта – для серверів баз даних. Крім того, різні сервери додатків можуть взаємодіяти між собою для більш точного розподілу системи на функціональні блоки, що виконують певні ролі. Наприклад, можна виокремити сервер управління персоналом, який буде виконувати усі необхідні для управління персоналом функції. Зв'язавши з ним окрему базу даних, можна приховати від користувачів усі деталі реалізації цього сервера, дозволивши їм звертатися тільки до його загальнодоступних функцій. Крім того, таку систему дуже просто адаптувати до Web, оскільки простіше розробляти html-форми для доступу користувачів до певних функцій бази даних, чим до усіх даних.

У трьохрівневій архітектурі ”тонкий” клієнт не перевантажений функціями обробки даних, а виконує свою основну роль системи подання інформації, що надходить з сервера додатків. Такий інтерфейс можна реалізувати за допомогою стандартних засобів Web-технології – браузера, CGI і Java. Це зменшує об'єм даних, що передаються між клієнтом і сервером додатків, що дозволяє підключати клієнтські комп'ютери навіть повільними лініями (телефонними каналами). Крім того, клієнтська частина може бути настільки простою, що у більшості випадків її реалізують за допомогою універсального браузера. Однак якщо змінювати її все ж таки доведеться, то цю процедуру можна здійснити швидко і безболісно.

Трьохрівнева архітектура ”клієнт-сервер” дозволяє більш точно призначати повноваження користувачів, оскільки вони одержують права доступу не до самої бази даних, а до певних функцій сервера додатків. Це підвищує захищеність системи (порівняно зі звичайною архітектурою) не тільки від навмисного нападу, але й від помилкових дій персоналу.

Як приклад, розглянемо систему, різні частини якої працюють на декількох віддалених один від одного серверах. Припустимо, що від розробника надійшла нова версія системи, для встановлення якої у двохрівневій архітектурі необхідно одночасно замінити усі системні модулі. Якщо ж цього не зробити, то взаємодія старих клієнтів з новими серверами може привести до непередбачених наслідків, оскільки розробники зазвичай не розраховують на таке використання системи. В трьохрівневій архітектурі ситуація спрощується. Справа в тому, що помінявши сервер додатків і сервер збереження даних (це легко зробити одночасно, оскільки обидва вони зазвичай знаходяться поруч), ми відразу змінюємо набір доступних сервісів. Таким чином, імовірність помилки через невідповідності версій серверної і клієнтської частин різко скорочується. Якщо у новій версії якийсь сервіс зник, то елементи інтерфейсу, що обслуговують його в старій системі, просто не будуть працювати. Якщо ж змінився алгоритм роботи сервісу, то він буде коректно працювати навіть зі старим інтерфейсом.

Багаторівневі ”клієнт-серверні” системи достатньо легко можна перевести на Web-технологію – для цього достатньо замінити клієнтську частину універсальним або спеціалізованим браузером, а сервер додатків доповнити Web-сервером і невеликими програмами виклику процедур сервера. Для розробки цих програм можна використовувати як Common Gateway Interface (CGI), так і більш сучасну технологію Java.

Треба відзначити й той факт, що у трьохрівневій системі каналом зв'язку між сервером додатків і базою даних передається достатньо багато інформації. Однак це не сповільнює обчислень, оскільки для зв'язку зазначених елементів можна використовувати більш швидкісні лінії. Це вимагає мінімальних витрат, оскільки обидва сервера зазвичай знаходяться в одному приміщенні. Таким чином, збільшується сумарна продуктивність системи – над однією задачею тепер працюють два різних сервера, а зв'язок між ними можна здійснювати по більш швидкісним лініям з мінімальними витратами коштів. Правда, виникає проблема узгодженості спільних обчислень, яку покликані вирішувати менеджери транзакцій – нові елементи багаторівневих систем.