2 A Quan ly qua trnh Khai niem

  • Slides: 46
Download presentation
2. A Quaûn lyù quaù trình Khaùi nieäm cô baûn < Ñònh thôøi CPU

2. A Quaûn lyù quaù trình Khaùi nieäm cô baûn < Ñònh thôøi CPU < Caùc taùc vuï cô baûn: taïo/keát thuùc quaù trình < Söï coäng taùc giöõa caùc quaù trình < Giao tieáp giöõa caùc quaù trình < 1

Khaùi nieäm cô baûn < Heä thoáng maùy tính thöïc thi nhieàu chöông trình

Khaùi nieäm cô baûn < Heä thoáng maùy tính thöïc thi nhieàu chöông trình khaùc nhau ● Batch system: job ● Time-shared system: user program, task < Quaù trình (process) ● moät chöông trình ñang thöïc thi Moät quaù trình ñöôïc ñònh nghóa bôûi ● Traïng thaùi CPU (trò cuûa caùc thanh ghi) ● Khoâng gian ñòa chæ (noäi dung boä nhôù) ● Moâi tröôøng (environment, xaùc ñònh thoâng qua caùc baûng cuûa heä ñieàu haønh) 2

Khaùi nieäm cô baûn (tt) < Traïng thaùi CPU ● ● ● < Khoâng

Khaùi nieäm cô baûn (tt) < Traïng thaùi CPU ● ● ● < Khoâng gian ñòa chæ ● ● < Processor Status Word (PSW) Instruction Register (IR) Program Counter (PC) Stack Pointer (SP) Caùc general purpose register Text (code) Data Heap Stack Moâi tröôøng ● Vd: terminal ñang duøng, caùc open file, caùc keânh giao tieáp vôùi caùc quaù trình khaùc ● Ñöôïc lieät keâ trong caùc baûng cuûa heä ñieàu haønh 3

Process control block < Heä ñieàu haønh löu thoâng tin veà quaù trình trong

Process control block < Heä ñieàu haønh löu thoâng tin veà quaù trình trong process control block (PCB) D. Feitelson 4

Caùc böôùc naïp chöông trình vaøo boä nhôù 5

Caùc böôùc naïp chöông trình vaøo boä nhôù 5

Töø chöông trình ñeán quaù trình < Chöông trình thöïc thi coù ñònh daïng

Töø chöông trình ñeán quaù trình < Chöông trình thöïc thi coù ñònh daïng load module maø trình naïp (loader) “hieåu” ñöôïc ● Vd ñònh daïng elf trong Linux < Layout luaän lyù cuûa process image Executable binary file (load module) Process image trong main memory program code data start address heap stack 6

Khôûi taïo quaù trình < Caùc böôùc heä ñieàu haønh khôûi taïo quaù trình

Khôûi taïo quaù trình < Caùc böôùc heä ñieàu haønh khôûi taïo quaù trình ● ● Caáp phaùt moät ñònh danh duy nhaát (process number hay process identifier, pid) cho quaù trình Caáp phaùt khoâng gian nhôù ñeå naïp quaù trình Khôûi taïo khoái döõ lieäu Process Control Block (PCB) cho quaù trình Thieát laäp caùc moái lieân heä caàn thieát (vd: saép PCB vaøo haøng ñôïi ñònh thôøi, …) 7

Caùc traïng thaùi cuûa quaù trình (1/2) < Caùc traïng thaùi cô baûn cuûa

Caùc traïng thaùi cuûa quaù trình (1/2) < Caùc traïng thaùi cô baûn cuûa moät quaù trình: ● ● ● new: quaù trình vöøa ñöôïc taïo ready: quaù trình ñaõ coù ñuû taøi nguyeân, chæ coøn caàn CPU running: caùc leänh cuûa quaù trình ñang ñöôïc thöïc thi waiting: hay laø blocked, quaù trình ñôïi I/O hoaøn taát, hay ñôïi tín hieäu terminated: quaù trình ñaõ keát thuùc 8

Caùc traïng thaùi cuûa quaù trình (2/2) < Chuyeån ñoåi giöõa caùc traïng thaùi

Caùc traïng thaùi cuûa quaù trình (2/2) < Chuyeån ñoåi giöõa caùc traïng thaùi cuûa quaù trình new admit dispatch ready exit terminated running interrupt I/O or event wait I/O or event completion waiting 9

Ví duï veà traïng thaùi quaù trình < /* test. c */ int main(int

Ví duï veà traïng thaùi quaù trình < /* test. c */ int main(int argc, char** argv) { printf(“Hello worldn"); exit(0); } Bieân dòch chöông trình trong Linux gcc test. c –o test Thöïc thi chöông trình test. /test Chuoãi traïng thaùi cuûa quaù trình test nhö sau (tröôøng hôïp toát nhaát): ● ● ● ● new ready running waiting (do chôø I/O khi goïi printf) ready running terminated Trong heä thoáng seõ coù moät quaù trình test ñöôïc taïo ra, thöïc thi vaø keát thuùc. 10

Process Control Block < Ñaõ thaáy laø moãi quaù trình trong heä thoáng ñeàu

Process Control Block < Ñaõ thaáy laø moãi quaù trình trong heä thoáng ñeàu ñöôïc caáp phaùt moät Process Control Block (PCB) < PCB laø moät trong caùc caáu truùc döõ lieäu heä ñieàu haønh quan troïng nhaát cuûa Ví duï layout cuûa moät PCB: (tröôøng pointer duøng ñeå lieân keát caùc PCB thaønh moät linked list) Moâi tröôøng 11

Caùc tröôøng tieâu bieåu cuûa PCB Tanenbaum 12

Caùc tröôøng tieâu bieåu cuûa PCB Tanenbaum 12

Chuyeån ngöõ caûnh (1/2) < Laøm theá naøo ñeå chia seû CPU giöõa caùc

Chuyeån ngöõ caûnh (1/2) < Laøm theá naøo ñeå chia seû CPU giöõa caùc quaù trình? < Ngöõ caûnh (context) cuûa moät quaù trình laø tình traïng hoaït ñoäng cuûa quaù trình ● Trò cuûa caùc thanh ghi, trò cuûa program counter, boä nhôù, … < Ngöõ caûnh cuûa quaù trình ñöôïc löu trong PCB cuûa noù < Chuyeån ngöõ caûnh (context switch) laø coâng vieäc ngöng quaù trình ñang thöïc thi vaø chaïy moät quaù trình khaùc. Khi ñoù caàn: ● löu ngöõ caûnh cuûa quaù trình vaøo PCB cuûa noù ● naïp ngöõ caûnh töø PCB cuûa quaù trình môùi ñeå quaù trình môùi thöïc thi 13

Chuyeån ngöõ caûnh (2/2) 14

Chuyeån ngöõ caûnh (2/2) 14

Yeâu caàu ñoái vôùi heä ñieàu haønh veà quaûn lyù quaù trình < Hoã

Yeâu caàu ñoái vôùi heä ñieàu haønh veà quaûn lyù quaù trình < Hoã trôï söï thöïc thi luaân phieân giöõa nhieàu quaù trình ● Khi naøo choïn vaø choïn quaù trình naøo ñeå thöïc thi coù theå tuøy thuoäc vaøo tieâu chí nhö 4 Hieäu suaát söû duïng CPU 4 Thôøi gian ñaùp öùng 4… < Phaân phoái taøi nguyeân heä thoáng hôïp lyù ● Vaán ñeà deadlock, trì hoaõn voâ haïn ñònh, … < < Cung caáp cô cheá hoã trôï user taïo/keát thuùc quaù trình Cung caáp cô cheá ñoàng boä vaø giao tieáp giöõa caùc quaù trình 15

Quaûn lyù quaù trình: caùc haøng ñôïi < Ví duï caùc PCB running 7

Quaûn lyù quaù trình: caùc haøng ñôïi < Ví duï caùc PCB running 7 process number ready 11 4 19 11 2 17 waiting 16

Ñònh thôøi quaù trình < Taïi sao phaûi ñònh thôøi? ● Multiprogramming 4 Coù

Ñònh thôøi quaù trình < Taïi sao phaûi ñònh thôøi? ● Multiprogramming 4 Coù nhieàu quaù trình thöïc thi luaân phieân nhau 4 Muïc tieâu (ví duï): cöïc ñaïi hieäu suaát söû duïng cuûa CPU ● Time-sharing 4 User töông taùc vôùi quaù trình 4 Muïc tieâu: toái thieåu thôøi gian ñaùp öùng < Moät soá khaùi nieäm cô baûn ● Caùc boä ñònh thôøi (scheduler) ● Caùc haøng ñôïi ñònh thôøi (scheduling queue) 17

Caùc haøng ñôïi ñònh thôøi < < Job queue Ready queue Caùc device queue

Caùc haøng ñôïi ñònh thôøi < < Job queue Ready queue Caùc device queue … 18

Caùc taùc vuï ñoái vôùi quaù trình (1/4) < Taïo quaù trình môùi ●

Caùc taùc vuï ñoái vôùi quaù trình (1/4) < Taïo quaù trình môùi ● Quaù trình coù theå taïo moät quaù trình môùi thoâng qua moät system call (vd: haøm fork trong UNIX) 4 Ví duï: (UNIX) Khi user ñaêng nhaäp heä thoáng, moät command interpreter (shell) seõ ñöôïc taïo ra cho user Quaù trình ñöôïc taïo laø quaù trình con cuûa quaù trình taïo (quaù trình cha). Quan heä cha-con ñònh nghóa moät caây quaù trình. 19

Caây quaù trình trong Linux/Unix < Ví duï pagedaemon gcc root swapper init bash

Caây quaù trình trong Linux/Unix < Ví duï pagedaemon gcc root swapper init bash ls mkdir bash grep 20

Caùc taùc vuï ñoái vôùi quaù trình (2/4) < Taïo quaù trình môùi (tt)

Caùc taùc vuï ñoái vôùi quaù trình (2/4) < Taïo quaù trình môùi (tt) ● Chia seû taøi nguyeân cuûa quaù trình cha: caùc khaû naêng 4 Quaù trình cha vaø con chia seû moïi taøi nguyeân 4 Quaù trình con chia seû moät phaàn taøi nguyeân cuûa cha 4 Cha vaø con khoâng chia seû taøi nguyeân ● Trình töï thöïc thi: hai khaû naêng 4 Quaù trình cha vaø con thöïc thi ñoàng thôøi (concurrently) 4 Quaù trình chaïy khi quaù trình con keát thuùc ● Trong Unix, quaù trình goïi fork seõ ñöôïc taïo moät quaù trình con 4 hoaøn toaøn gioáng noù vaøo thôøi ñieåm goïi --- cuøng traïng thaùi CPU, khoâng gian ñòa chæ, moâi tröôøng 4 chæ khaùc nhau ôû process ID vaø trò traû veà töø fork 21

Caùc taùc vuï ñoái vôùi quaù trình (3/4) < Taïo quaù trình môùi (tt)

Caùc taùc vuï ñoái vôùi quaù trình (3/4) < Taïo quaù trình môùi (tt) ● Khoâng gian ñòa chæ: tuøy heä ñieàu haønh 4 UNIX: Khoâng gian ñòa chæ cuûa quaù trình con ñöôïc nhaân baûn töø khoâng gian ñòa chæ cuûa cha vaøo thôøi ñieåm goïi 4 Windows: phöùc taïp hôn, Win 32 API Create. Process() caàn hôn 10 tham soá 22

Veà quan heä cha/con < Ví duï aùp duïng fork trong UNIX/Linux ● Quaù

Veà quan heä cha/con < Ví duï aùp duïng fork trong UNIX/Linux ● Quaù trình goïi fork() ñeå taïo moät quaù trình con ● Quaù trình con goïi exec() ñeå naïp vaø thöïc thi moät chöông trình trong khoâng gian nhôù cuûa noù ● Quaù trình cha laøm vieäc khaùc… hay goïi wait() ñeå ñôïi con xong ñoàng boä 23

Ví duï taïo process vôùi fork() #include <stdio. h> #include <unistd. h> int main

Ví duï taïo process vôùi fork() #include <stdio. h> #include <unistd. h> int main (int argc, char *argv[]){ int return_code; /* create a new process */ return_code = fork(); if (return_code > 0){ printf(“This is parent process”); wait(NULL); exit(0); } else if (return_code == 0){ printf(“This is child process”); execlp(“/bin/ls”, “ls”, NULL); exit(1); } else { printf(“Fork errorn”); exit(1); } } 24

Caùc taùc vuï ñoái vôùi quaù trình (4/4) < Taïo quaù trình môùi <

Caùc taùc vuï ñoái vôùi quaù trình (4/4) < Taïo quaù trình môùi < Keát thuùc quaù trình ● Quaù trình töï keát thuùc 4 Quaù trình keát thuùc khi thöïc thi leänh cuoái vaø goïi system routine exit ● Quaù trình keát thuùc do quaù trình khaùc (coù ñuû quyeàn, vd: quaù trình cha cuûa noù) 4 Goïi system routine abort vôùi tham soá laø pid (process identifier) cuûa quaù trình caàn ñöôïc keát thuùc ● Heä ñieàu haønh thu hoài taát caû caùc taøi nguyeân cuûa quaù trình keát thuùc (vuøng nhôù, I/O buffer, …) 25

Coäng taùc giöõa caùc quaù trình < Caùc quaù trình coù theå coäng taùc

Coäng taùc giöõa caùc quaù trình < Caùc quaù trình coù theå coäng taùc (cooperate) ñeå hoaøn thaønh coâng vieäc ● Vd Sensor Sampler Sensor data buffer Process data Shared memory Display 26

Coäng taùc giöõa caùc quaù trình < Thieát keá öùng duïng ● Phaân chia

Coäng taùc giöõa caùc quaù trình < Thieát keá öùng duïng ● Phaân chia moät öùng duïng lôùn thaønh caùc process coäng taùc nhau kieán truùc client-server < AÙp duïng coäng taùc giöõa caùc quaù trình ñeå ● Baøi toaùn producer-consumer ● Modul hoùa ● Taêng toác tính toaùn 4 Neáu heä thoáng coù nhieàu CPU, chia coâng vieäc tính toaùn thaønh nhieàu coâng vieäc tính toaùn nhoû chaïy song < Söï coäng taùc giöõa caùc quaù trình ñoøi hoûi heä ñieàu haønh cung caáp giaûi phaùp ñoàng boä hoaït ñoäng (chöông 3) vaø giao tieáp cho caùc quaù trình 27

Baøi toaùn producer-consumer < Baøi toaùn tieâu bieåu veà söï coäng taùc giöõa caùc

Baøi toaùn producer-consumer < Baøi toaùn tieâu bieåu veà söï coäng taùc giöõa caùc quaù trình: baøi toaùn producer- consumer ● Producer taïo ra caùc döõ lieäu vaø consumer tieâu thuï / söû duïng caùc döõ lieäu ñoù. Söï trao ñoåi döõ lieäu ñöôïc thöïc hieän qua buffer 4 unbounded buffer: kích thöôùc buffer voâ haïn (khoâng thöïc teá) 4 bounded buffer: kích thöôùc buffer coù haïn ● Producer vaø consumer phaûi hoaït ñoäng ñoàng boä vì 4 Consumer khoâng ñöôïc tieâu thuï khi producer chöa saûn xuaát 4 Producer khoâng ñöôïc taïo theâm döõ lieäu khi buffer ñaày 28

Interprocess communication (IPC) < IPC laø caùc kyõ thuaät cung caáp bôûi heä ñieàu

Interprocess communication (IPC) < IPC laø caùc kyõ thuaät cung caáp bôûi heä ñieàu haønh nhaèm giuùp caùc quaù trình giao tieáp vôùi nhau ● Caùc quaù trình coù theå treân cuøng maùy hoaëc khaùc maùy < Hai kyõ thuaät IPC ● Truyeàn thoâng ñieäp (message passing) ● Duøng boä nhôù chia seû (shared memory) 29

Moâ hình giao tieáp Dùng bộ nhớ chia sẻ Truyền thông điệp 3. 4

Moâ hình giao tieáp Dùng bộ nhớ chia sẻ Truyền thông điệp 3. 4 Fig 3. 12

Truyeàn thoâng ñieäp < Caùc vaán ñeà ● Naming 4 Giao tieáp tröïc tieáp

Truyeàn thoâng ñieäp < Caùc vaán ñeà ● Naming 4 Giao tieáp tröïc tieáp – send(P, msg): göûi thoâng ñieäp ñeán quaù trình P – receive(Q, msg): nhaän thoâng ñieäp ñeán töø quaù trình Q 4 Giao tieáp giaùn tieáp: thoâng qua mailbox hay port – send(A, msg): göûi thoâng ñieäp ñeán mailbox A – receive(B, msg): nhaän thoâng ñieäp töø mailbox B ● Synchronization: 4 blocking/nonblocking send 4 blocking/nonblocking receive 31

Example of shared memory for IPC < POSIX Shared Memory ● Process first creates

Example of shared memory for IPC < POSIX Shared Memory ● Process first creates shared memory segment_id = shmget(IPC_PRIVATE, size, S_IRUSR | S_IWUSR); ● Process wanting access to that shared memory must attach to it shared_memory = (char *) shmat(id, NULL, 0); ● Now the process could write to the shared memory sprintf(shared_memory, "Writing to shared memory"); ● When done a process can detach the shared memory from its address space shmdt(shared_memory); 32

Giao tieáp trong heä thoáng client-server < Socket < Remote Procedure Call (RPC) <

Giao tieáp trong heä thoáng client-server < Socket < Remote Procedure Call (RPC) < Remote Method Invocation (RMI) 33

Socket < Socket laø moät ñoái töôïng tröøu töôïng duøng ñeå töôïng tröng moät

Socket < Socket laø moät ñoái töôïng tröøu töôïng duøng ñeå töôïng tröng moät ñaàu cuoái cuûa moät keânh giao tieáp ● Goàm ñòa chæ IP vaø port number ● Vd socket 161. 25. 19. 8: 1625 duøng ñeå tham chieáu port 1625 treân maùy coù ñòa chæ IP 161. 25. 19. 8 34

Socket ● (tt) ‘well-known’ port xaùc ñònh caùc dòch vuï chuaån ● Cung caáp

Socket ● (tt) ‘well-known’ port xaùc ñònh caùc dòch vuï chuaån ● Cung caáp cô cheá giao tieáp möùc thaáp: göûi nhaän moät chuoãi byte döõ lieäu khoâng caáu truùc ● Hai loaïi giao tieáp qua socket: connectionless vaø connection-oriented 35

Göûi/nhaän qua socket Haøm thö vieän Dieãn giaûi socket() Taïo moät socket bind() Gaùn

Göûi/nhaän qua socket Haøm thö vieän Dieãn giaûi socket() Taïo moät socket bind() Gaùn moät ñòa chæ cuïc boä vaøo socket listen() Saün saøng ñeå chaáp nhaän keát noái accept() (server) Chôø keát noái ñeán töø client connect() (client) keát noái ñeán moät server send() sendto() Göûi döõ lieäu qua keânh giao tieáp ñaõ thieát laäp Göûi döõ lieäu ñeán moät ñòa chæ recv() recvfrom() Nhaän döõ lieäu qua keânh giao tieáp ñaõ thieát laäp Nhaän döõ lieäu ñeán töø moät ñòa chæ close() Ñoùng keát noái 36

Connectionless Transport Service < < Process A Process B socket() bind() sendto()/ recvfrom() close()

Connectionless Transport Service < < Process A Process B socket() bind() sendto()/ recvfrom() close() sendto(socket, buffer_length, flags, destination_address, addr_len) recvfrom(socket, buffer_length, flags, from_address, addr_len) 37

Connection-Oriented Transport Service Server (Google) socket() bind() listen() accept() recv() send() close() communication socket()

Connection-Oriented Transport Service Server (Google) socket() bind() listen() accept() recv() send() close() communication socket() connect() send() recv() close() Client (Firefox) < < send(socket, buffer_length, flags) recv(socket, buffer_length, flags) 38

Remote procedure call (RPC) < Môû roäng cô cheá goïi thuû tuïc (procedure call)

Remote procedure call (RPC) < Môû roäng cô cheá goïi thuû tuïc (procedure call) thoâng thöôøng ● Duøng RPC moät quaù trình coù theå goïi moät thuû tuïc naèm treân maùy tính ôû xa qua maïng < Caùc vaán ñeà khi hieän thöïc RPC ● ● ● Truyeàn tham soáû Bieåu dieãn döõ lieäu Keát noái töø client ñeán server (binding) Giao thöùc vaän chuyeån Xöû lyù loãi (exception handling) An toaøn (security) 39

Hieän thöïc RPC: caùc stub Client Server g D. Feitelson 40

Hieän thöïc RPC: caùc stub Client Server g D. Feitelson 40

Hieän thöïc RPC: löu ñoà thôøi gian chôø keát quaû traû veà (suspended) Client

Hieän thöïc RPC: löu ñoà thôøi gian chôø keát quaû traû veà (suspended) Client Goïi remote procedure Request Keát quaû traû veà Reply Server (blocked) Goïi thuû tuïc cuïc boä vaø traû veà keát quaû (blocked) Thời gian 41

Marshalling / Unmarshalling < Marshalling laø coâng vieäc ñoùng goùi döõ lieäu vaøo trong

Marshalling / Unmarshalling < Marshalling laø coâng vieäc ñoùng goùi döõ lieäu vaøo trong moät thoâng ñieäp döôùi moät ñònh daïng thích hôïp ñeå vaän chuyeån qua maïng ● Unmarshalling laø coâng vieäc ngöôïc laïi < Duøng marshalling / unmarshalling trong hieän thöïc RPC trong caùc coâng ñoaïn ● Göûi yeâu caàu ñeán server 4 Client stub ñoùng goùi caùc tham soá cuûa thuû tuïc vaøo trong goùi thoâng ñieäp vaø göûi noù ñeán server stub 4 Server stub môû goùi laáy caùc tham soá töø thoâng ñieäp vaø duøng chuùng ñeå goïi thuû tuïc cuûa server ● Server traû veà keát quaû 4 Server stub ñoùng goùi keát quaû tröôùc khi göûi ñeán client stub 4 Client stub môû goùi laáy keát quaû vaø chuyeån noù ñeán client 42

Marshalling / Unmarshalling Client return reply Server call request Client Stub message to result

Marshalling / Unmarshalling Client return reply Server call request Client Stub message to result receive return reply Server Stub parameters to message to parameters result to message Transport (OS 1) (OS 2) send receive send network 43

Hieän thöïc RPC: bieåu dieãn döõ lieäu < Döõ lieäu treân caùc heä thoáng

Hieän thöïc RPC: bieåu dieãn döõ lieäu < Döõ lieäu treân caùc heä thoáng khaùc nhau coù theå ñöôïc bieåu dieãn khaùc nhau ● Maõ hoùa kyù töï: ASCII, EBCDIC ● Ví duï bieåu dieãn 32 -bit integer trong boä nhôù 4 Motorola: big-endian most significant byte taïi high memory address () 4 Intel x 86: little-endian least significant byte taïi high memory address () < Giaûi phaùp: maõ hoùa döõ lieäu duøng daïng bieåu dieãn ñoäc laäp maùy XDR (External Data Representation) khi trao ñoåi döõ lieäu giöõa caùc heä thoáng maùy khaùc nhau 44

Remote method invocation (RMI) < Cho pheùp moät chöông trình Java coù theå goïi

Remote method invocation (RMI) < Cho pheùp moät chöông trình Java coù theå goïi moät phöông thöùc (method) cuûa moät ñoái töôïng ôû xa, nghóa laø moät ñoái töôïng ôû taïi moät maùy aûo Java khaùc 45

Marshalling tham soá trong RMI marshalling unmarshalling Phöông thöùc ñöôïc trieäu goïi coù daïng

Marshalling tham soá trong RMI marshalling unmarshalling Phöông thöùc ñöôïc trieäu goïi coù daïng sau: boolean some. Method(Object x, Object y) 46