Klient-serwer

Z Wikipedii, wolnej encyklopedii
Ilustracja przedstawiająca budowę tego typu sieci - urządzenia (klienci) łączą się z serwerem i otrzymują od niego dane

Klient-serwer (ang. client/server, client-server model) – architektura systemu komputerowego, w szczególności oprogramowania, umożliwiająca podział zadań (ról). Polega na ustaleniu, że serwer zapewnia usługi klientom, zgłaszającym do serwera żądania obsługi (ang. service request)[1].

Zastosowanie[edytuj | edytuj kod]

Podstawowe, najczęściej spotykane serwery działające w oparciu o architekturę klient-serwer to: serwer poczty elektronicznej, serwer WWW, serwer plików, serwer aplikacji. Z usług jednego serwera może zazwyczaj korzystać wiele klientów. Jeden klient, w ogólności, może korzystać jednocześnie z usług wielu serwerów. Według schematu klient-serwer działa też większość, obecnie spotykanych, systemów zarządzania bazą danych.

Podział zadań[edytuj | edytuj kod]

W pewnym uproszczeniu, bez wdawania się w techniczne szczegóły realizacji, sposób komunikacji według architektury klient-serwer można scharakteryzować przez określenie zadań (wyznaczenie ról) obu stronom oraz zdefiniowanie ich trybów pracy[2].

Strona klienta

Jest to strona żądająca dostępu do danej usługi lub zasobu.

Tryb pracy klienta:
  • aktywny,
  • wysyła żądanie do serwera,
  • oczekuje na odpowiedź od serwera.
Strona serwera

Jest to strona świadcząca usługę lub udostępniająca zasoby.

Tryb pracy serwera:
  • pasywny,
  • czeka na żądania od klientów,
  • w momencie otrzymania żądania, przetwarza je, a następnie wysyła odpowiedź.

Typy architektury[edytuj | edytuj kod]

Ze względu na podział wykonywanych zadań wyróżnia się następujące typy architektury klient-serwer:

Komunikacja[edytuj | edytuj kod]

Połączenie pomiędzy klientem a serwerem opisane jest przy pomocy określonych protokołów komunikacyjnych. Najczęściej spotykanym jest TCP/IP. W większości przypadków komunikacja opiera się na schemacie, w którym klient nawiązuje połączenie z serwerem. Następnie wysyła żądanie w określonym formacie do serwera i oczekuje na jego odpowiedź. Serwer cały czas oczekuje na klientów i w momencie otrzymania żądania przetwarza je i wysyła odpowiedź. W modelu OSI komunikacja pomiędzy stronami przebiega w warstwie aplikacji.

P2P[edytuj | edytuj kod]

P2P jest to rodzaj innej architektury, w której każdy host może pełnić jednocześnie rolę klienta i rolę serwera.

Zalety[edytuj | edytuj kod]

  • Wszystkie informacje przechowywane są na serwerze, wobec tego możliwe jest lepsze zabezpieczenie danych. Serwer może decydować kto ma prawo do odczytywania i zmiany danych.
  • Istnieje wiele rozwiniętych technologii wspomagających działanie, bezpieczeństwo i użyteczność tego typu rozwiązania.

Wady[edytuj | edytuj kod]

  • Duża liczba klientów próbujących otrzymać dane z jednego serwera powoduje różnego typu problemy związane z przepustowością łącza oraz technicznymi możliwościami przetworzenia żądań klientów.
  • W czasie, gdy serwer nie działa, dostęp do danych jest całkowicie niemożliwy.
  • Do uruchomienia jednostki będącej serwerem z możliwością obsługi dużej liczby klientów potrzebne jest specjalne oprogramowanie oraz sprzęt komputerowy, które nie występują w większości komputerów domowych.

Przykład[edytuj | edytuj kod]

Najbliższym przykładem jest organizacja dostępu do zasobów Internetu, gdzie:

Przeglądając strony internetowe komputer użytkownika jest klientem, a komputery które obsługują bazy danych i inne aplikacje potrzebne do obsługi połączenia to serwer. W momencie gdy przeglądarka żąda jakiejś strony, serwer wyszukuje odpowiednie informacje w bazie danych, przetwarza je do postaci strony internetowej, a następnie wysyła do klienta.

Zobacz też[edytuj | edytuj kod]

Przypisy[edytuj | edytuj kod]

  1. Klient-serwer. www.i-slownik.pl. [dostęp 2011-04-15].
  2. Model klient-serwer. Model komunikacji w sieci.. www.korzen.org. [dostęp 2011-04-15].