Wiki source code of 01.08. Klienta-servera modelis

Last modified by Valdis Vītoliņš on 2018/01/15 21:44

Show last authors
1 = 01.08. Klienta-servera modelis =
2
3 Vairums tīkla lietotņu ir uzrakstītas ar pieņēmumu, ka viena komunikācijas puse ir klients un otra - serveris. Lietotnes mērķis ir likt serverim sniegt kādu noteiktu servisu klientiem. Serverus var iedalīt divās kategorijās - //vienpavediena// jeb iteratīvie un //daudzpavedienu// jeb laiksakritīgie. Iteratīvs serveris veic iterācijas šādos soļos:
4
5 I1. Gaidīt, kamēr ierodas klienta pieprasījums. I2. Apstrādāt klienta pieprasījumu. I3. Nosūtīt atbildi atpakaļ klientam, kurš sūtīja pieprasījumu. I4. Iet atpakaļ uz I1 soli.
6
7 Vienpavediena servera galvenais ierobežojums ir tas, ka I2 solim ir vajadzīgs laiks. Šajā laikā citus klientus nevar apkalpot. Daudzpavedienu serveris toties veic sekojošus soļus:
8
9 Cl. Gaidīt, kamēr ierodas klienta pieprasījums. C2. Sākt jaunu servisa pavedienu, lai apstrādātu šī klienta pieprasījumu. (Tehniskās realizācijas līmenī tas var nozīmēt ne vien pavedienu, bet arī jaunu procesu jeb uzdevumu, atkarībā no tā, ko atbalsta konkrētā operētājsistēma.) Šis jaunizveidotais servisa pavediens apstrādā visu klienta pieprasījumu. Kad tas ir pabeigts, jaunais servisa pavediens beidz darbu. C3. Iet atpakaļ uz soli C1.
10
11 Daudzprocesoru servera priekšrocība ir tā, ka šāds serveris savairo servisa pavedienus, kas apstrādā klientu pieprasījumus. Katram klientam būtībā pieder savs neatkarīgs pavediens (kurš no klienta redzesviedokļa nav atšķirīgs no neatkarīga servera). Pieņemot, ka operētājsistēma pieļauj multiprogrammēšanu, vairākus klientus var apkalpot vienlaicīgi.
12
13 Iemesls, kādēļ mēs kategorizējam serverus, nevis klientus ir tāds, ka klients parasti nevar pateikt, vai tas sazinās ar iteratīvu (vienpavediena) serveri vai daudzpavedienu serveri.
14
15 Bieži ir spēkā likumsakarība - TCP serveri ir daudzpavedienu, bet UDP serveri ir vienpavediena, bet ir daži izņēmumi. UDP protokola iespaidu uz tā serveriem aplūkosim [[11.12.nodaļā>>11_12]], un TCP iespaidu uz tā serveriem - [[18.11. nodaļā>>18_11]].