1 / 38

Chapter 4: Concurrent Programming

Chapter 4: Concurrent Programming. Distributed Physically separate autonomous processors that interact and collaborate Parallel Processing occurring on more than one processor within the same time frame Concurrent

abie
Télécharger la présentation

Chapter 4: Concurrent Programming

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Chapter 4: Concurrent Programming • Distributed • Physically separate autonomous processors that interact and collaborate • Parallel • Processing occurring on more than one processor within the same time frame • Concurrent • Processing occurring on more than one processor that is synchronized in real-time Distributed Systems

  2. Processes run termination ready block creation Process: A program in execution. • Earlier processes are sequential processes as there is only one control flow in each process. • A process includes its program code, data, resources, and virtual execution environment(CPU, memory). Distributed Systems

  3. Process Creation /* UNIX and C:process_creation.c */ #include <stdlib.h> main(){ int pid; if ((pid = fork()) != 0){ /* father process */ printf(“Father\n”); wait(0); } else if ((pid = fork()) != 0){ /* son process */ printf(“Son\n”); wait(0); } else { /* grandson process */ printf(“Grandson\n”); } exit(0); } Distributed Systems

  4. Memory Space of a Process Stack Heap Program and constant Stack Heap Program and constant Stack Heap Program and constant father son grandson Every process has its own independent memory space Distributed Systems

  5. Process Context Switch Process Context switch: allocate CPU from one process to another. A Process context includes two portions: CPU context and Storage context. • CPU context: program counter, registers, stack/heap pointers and other control registers. Easy to switch. • Storage context: program code, data, address space, memory mapping, (disk) swapping, etc. Hard and time consuming to switch. Distributed Systems

  6. Threads Thread: a (part of a) program in execution. • Maintains only the minimum information to allow a CPU to be shared by several threads. • A thread includes nothing more than the CPU context, and shares program code, data, resources, and virtual execution environment(CPU, memory) with other threads within a process. Distributed Systems

  7. Threads and Processes MPST: Unix SPST: Dos SPMT: JVM MPMT: Win-nt Solaris Distributed Systems

  8. Design problems Two major design problems: • How to schedule threads? (user level vs. system level, preemptive vs. non-preemptive) • How to handle blocking system calls: if a user level thread issues a blocking system call, such as sleep, I/O, etc, it may blocks all threads within the same process. Distributed Systems

  9. User/System Level Threads Heavyweight process Heavyweight process User level thread User level thread LWP LWP LWP LWP System level thread Distributed Systems

  10. Thread implementations /* POSIX */ main(){ … pthread_create(f,arg); … } void *f(void *arg){ … pthread_exit(status); } /* Win32 */ main(){ … CreateThread(f,arg); _beginthread(f,arg); _xbeginthread(f,arg); } DWORM f(DWORD arg){ … ExitThread(status); _endthread(status); _xendthread(status); } /* Java */ main(){ MyThread t; t = new MyThread(); t.start(); } class MyThread extends Thread{ public void run(){ … return; } } Distributed Systems

  11. POSIX Thread /* POSIX thread: thread_creation.c */ /* compile:gcc –o thread_creation thread_creation.c –lpthread */ #include <pthread.h> #include <stdlib.h> #include <stdio.h> void *mythread(void); /* thread prototype */ /* ME-lock initialization */ pthread_mutex_t mylock = PTHREAD_MUTEX_IITIALIZER; int x = 0; /* shared variable */ int main(){ pthread_t tids[10]; /* identifier array */ int i; for (i = 0; i < 10; i++){ /* create 10 threads */ pthread_create(&tids[i], NULL, mythread, NULL); } for (i = 0; i < 10; i++){ /* waiting for thread termination */ pthread_join(tids[i], NULL); printf(“Thread id %ld returned\n”, tids[i]); } exit(0); } /* thread function*/ void *mythread(void){ /* add 1 to shared variable */ while (x < 4000){ pthread_mutex_lock(&mylock); /* lock */ x++; /* critical region */ printf(“Thread id %ld: x is now %d\n”, pthread_self(), x); pthread_mutex_unlock(&mylock); /* unlock */ } pthread_exit(NULL); /* thread terminates */ } /* Each thread increases x by 1 in each loop, until x is greater than or equal to 4000 . If we do not use lock/unlock, what happen? */ Distributed Systems

  12. Mutual Exclusion and Synchronization Thread T Thread S Possible execution sequences: (1) t1,t2,t3,s1,s2,s3 (2) t1,t2,s1,t3,s2,s3 (3) t1,t2,s1,s2,t3.s3 (4) t1,t2,s1,s2,s3,t3 (5) t1,s1,t2,t3,s2,s3 (6) t1,s1,t2,s2,t3,s3 (7) t1,s1,t2,s2,s3,t3 (8) t1,s1,s2,t2,t3,s3 (9) t1,s1,s2,t2,t3,s3… T: { x++; } t1: LOD R1, x t2: ADD R1, 1 t3: STO R1, x S: { x++; } s1: LOD R1, x s2: ADD R1, 1 s3: STO R1, x A CR(Critical Region) is an atomic sequence of program segment whose execution must not be interrupted, i.e., must be executed mutual exclusively. Distributed Systems

  13. Mutual Exclusion Mechanisms Requirements: • Should guarantee no more than one entity enters CR • Should prevent interferences from entities outside of CR • Should prevent starvation Commonly used ME mechanisms are: semaphore and P/V operations, lock/unlock primitives, conditional variables, shared variables, monitors, etc. Distributed Systems

  14. Synchronisation Using Shared Memory Semaphore • A semaphore s is a nonnegative integer variable, initially with value 1, • A semaphore can only be changed or tested by one of the following two indivisible access routines: • P(s): [while (s=0) wait; s := s-1] • V(s): [s := s+1] • Semaphores are used for mutual exclusion Distributed Systems

  15. V(s) P(s) Stack k cells d1 d2 d3 d4 ... dn top Mutual Exclusion Using P/V Operations Semaphore s; Example Push and Pop operations on a stack by concurrent processes. Push(x): Repeat If top<k then { top++; stack[top]:=x;} end Pop(y): Repeat If top>0 then { y:=stack[top]; top--; } end Distributed Systems

  16. Mutual Exclusion Example(1): a naïve solution /* POSIX : producer_consumer.c */ #include <pthread.h> void *producer_function(void); /* prototype */ void *consumer_function(void); /* Initialize a ME lock */ pthread_mutex_t mylock = PTHREAD_MUTEX_IITIALIZER; /* shared variables among threads */ int flag = 0; char buffer; struct timespec dealy; main(){ pthread_t consumer; delay.tv_sec = 2; /* set 2 sec delay */ delay.tv_nsec = 0; /* create consumer */ pthread_create(&consumer, NULL, consumer_function, NULL); producer_function(); /* main becomes producer */ } void *producer_function(void){ while (1){ pthread_mutex_lock(&mylock); if (flag == 0){ buffer = produce(); /* produce an item */ flag = 1; } pthread_mutex_unlock(&mylock); pthread_delay_np(&delay); /* sleep 2 sec */ } } void *consumer_function(void){ while (1){ pthread_mutex_lock(&mylock); if (flag == 1){ consume(buffer); /* consume an item */ flag = 0; } pthread_mutex_unlock(&mylock); pthread_delay_np(&delay); /* sleep 2 sec */ } } Distributed Systems

  17. Mutual Exclusion Example(2): a better solution /* POSIX : producer_consumer1.c */ #include <pthread.h> /* thread prototypes */ void *producer_function(void); void *consumer_function(void); /* initialize a lock and two conditional variables */ pthread_mutex_t mylock = PTHREAD_MUTEX_IITIALIZER; pthread_cond_t w_consumer = PTHREAD_COND_IITIALIZER; pthread_cond_t w_producer = PTHREAD_COND_IITIALIZER; /* threads shared variables */ int flag = 0; char buffer; struct timespec dealy; main(){ pthread_t consumer; delay.tv_sec = 2; /* set 2 sec time delay*/ delay.tv_nsec = 0; /* create consumer thread */ pthread_create(&consumer, NULL, consumer_function, NULL); producer_function();/* main becomes producer thread */ } void *producer_function(void){ char x; while (1){ x = produce(); pthread_mutex_lock(&mylock); while (flag == 1) /* wait for consumer’s signal */ pthread_cond_wait(&w_consumer, &mylock); buffer = x; flag = 1; pthread_mutex_unlock(&mylock); pthread_cond_signal(&w_producer); pthread_delay_np(&delay);/* sleep 2 sec */ } } void *consumer_function(void){ char x; while (1){ pthread_mutex_lock(&mylock); while (flag == 0) /* wait for producer’s signal */ pthread_cond_wait(&w_producer, &mylock); x = buffer; flag = 0; pthread_mutex_unlock(&mylock); pthread_cond_signal(&w_consumer); consume(x); pthread_delay_np(&delay); /* sleep 2 sec */ } } Distributed Systems

  18. Client/Server Concurrent systems Two design issues related with Client software : • How to interact with users: Graphic User Interface • How to interact with remote servers: RPC/message GUI Design: • Understand user’s habits and knowledge about computer • Easy to learn and easy to use • Provide user-friendly hint, help, warning and error report • Be consistency with commonly used conventions, such as menu, icons, color, and terminologies. Distributed Systems

  19. Client GUI Example: Distributed Systems

  20. Design of Concurrent Server D I S P A T C H Thread A Thread A Thread B Thread B Thread C Thread C Thread D Thread D (a) Center distributor (b) Concurrent threads S C H D U L E Q U E U E Thread Thread A Thread Thread B Thread C Thread C (d) Round-robin schedule (c) Center scheduler Distributed Systems

  21. Centralized request dispatcher Consists of a centralized dispatcher and a set of long lived workers. Different workers handle different kinds of requests. Distributed Systems

  22. How a Client contacts a Server: • Client-to-server binding using a daemon as in DCE • Client-to-server binding using a superserver as in UNIX Distributed Systems

  23. Software Agent Paradigm • A software agent is a program in execution, on behalf of its owner to carry out the assigned task. • An agent is autonomous, may react in different environments, may communicate with other agents, may temporally continuously running, may be driven by goals, and may move from host to host. Distributed Systems

  24. What is Mobile Agent? • A self-contained process that can autonomously migrate from host to host in order to perform its task on Internet. • The motto of Mobile Agents is: move the computations to the data rather than the data to the computations Distributed Systems

  25. Client implement transfer information Intelligent Agent buy / sell stocks send agent … Client implement buy / sell stocks Mobile Intelligent Agent dispatch receive agent … Carry the result Why do we need mobile agents? Client Stock market IBM: $20 Microsoft: $21 HP: $22 Customer buy / sell stocks transfer information Stock server Distributed Systems

  26. Examples of Potential Applications • User-level applications • Search and information filtering agents • Personal assistants • Middleware systems • Global file systems • Distributed collaboration and workflow systems • System level tasks • Network status monitoring and control • Intrusion detection • Software distribution, installation, upgrades Distributed Systems

  27. Advantages of Mobile Agents • Simulate human’s concurrent activities. • Various abstractions: task agent, interface agent, information agent, etc. • Occupy less network traffics. • Achieve more flexibility. • Reduce network delay. • Suitable to disconnecting/reconnecting networks. Distributed Systems

  28. Software Agents in Distributed Systems Some important properties by which different types of agents can be distinguished. Distributed Systems

  29. A Comparison of different distributed models D C D RPC Data migration C C (2) Client/server model (1) Remote file access model D D D Data distribution and coordination Program migration C C C C (3) Distributed database model (4) Mobile agent model Distributed Systems

  30. Models for Program Migration program migration: move a program from one host to another and resume its execution. Distributed Systems

  31. What should we move? A running program (any language) consists of: • Code: source code, byte code, or binary code • Data: initial data, intermediate data • Resource: hardware/software, such as printer, communication link/port, file, library, URL, disk, etc. • Execution state: snapshot of execution environment, such as program counter, registers, stack pointers. content in stack, etc. Distributed Systems

  32. Migration model Migration components Continuation point after migration Primeval migration Code, Initial data Start from entry point Weak migration Code, intermediate data Resume execution from beginning, but program follows flags to find move point Strong migration Code, intermediate data, and execution state Continue execution at the instruction immediately following the move point Types of Program Migration Strong migration: move_to(A); Continuation point Weak migration: if (not moved){ moved = true; move_to(A); } else{ Continuation point } Distributed Systems

  33. Process Migration • Process migration allows a partially executed process to be relocated to another node. • Execution state of the process is migrated. • Stack, memory, program counter, state of open files. • Mainly used for load balancing. • In the mid 1980s several mechanisms were investigated and supported in a local area network environments. Distributed Systems

  34. Object Migration • Object migration allows objects to be moved across address spaces at different nodes. • Requires mobility of object’s code and data. • Emeraldsupported object mobility under program control. (Univ. of Washington)(1986) • Chorus distributed system (1988) supported object mobility with autonomous control by the object. • Most of these system supported migration in a homogeneous system. Distributed Systems

  35. Code Migration Remote Programming and Code Mobility: procedure code + data Code transported to the server Server Client results (data) • Remote Evaluationmodel by Stamos and Gifford • (MIT)(1990). • JavaSun Microsystems(1995) allows code • migration across heterogeneous platforms. Distributed Systems

  36. Agent Migration Client Server 1 agent(code+data) Mobile Agent Server 2 Server 3 Distributed Systems

  37. Mobile Agent Programming Systems • Tacoma - Tcl based system developed at Cornell and Tromso University (1994-95) • Agent Tcl - Tcl based system developed at Dartmouth College. (1994-95) D’Agents • Aglets - Java based system from IBM. (1996) • Concordia - Java based system from Mitsubishi Research. (1997) • Voyager - Java based system from ObjectSpace • Odyssey - Java based system from General Magic Distributed Systems

  38. Migration and Local Resources Resource-to machine binding Process-to-resource binding • Actions to be taken with respect to the references to local resources when migrating code to another machine. • GR: establish a global systemwide reference • MV: move the resource • CP: copy the value of the resource • RB: rebind process to locally available resource Distributed Systems

More Related