Transcript Document

Processes
Distributed Systems
Acknowledgement:
These slides are adapted from slides provided in
Thißen & Spaniol's course Distributed Systems and Middleware, RWTH Aachen
Outline
Threads (3.1)
Servers (3.4)
Code migration (3.5)
Processes
2
Processes and Threads
A distributed application is a collection of cooperating processes.
A process is a program which is currently executed with its own
address space and an own control flow; the execution is strict
sequentially
A process can create several threads
which work together and do not disturb
the work of the other threads.
Processes
3
Threads and Distributed Systems
Multithreaded Web client
Hiding network latencies:
Web browser scans an incoming HTML page, and finds that more files
need to be fetched.
Each file is fetched by a separate thread, each doing a (blocking)
HTTP request.
As files come in, the browser displays them.
Multiple request-response calls to other machines (RPC)
A client does several calls at the same time, each one by a different
thread.
It then waits until all results have been returned.
Note: if calls are to different servers, we may have a linear speed-up.
Processes
4
Threads and Distributed Systems
Improve performance
Starting a thread is much cheaper than starting a new process.
Having a single-threaded server prohibits simple scale-up to a
multiprocessor system.
As with clients: hide network latency by reacting to next request
while previous one is being replied.
Better structure
Most servers have high I/O demands. Using simple, well-understood
blocking calls simplifies the overall structure.
Multithreaded programs tend to be smaller and easier to understand
due to simplified flow of control.
Processes
5
Threaded Servers
Common model for implementation: Dispatcher/Worker model
Processes
6
Servers: General organization
Basic model
A server is a process that waits for incoming service requests at a
specific transport address. In practice, there is a one-to-one mapping
between a port and a service.
 Example: ftp uses port 21; telnet uses port 23
Type of servers
Superservers: Servers that listen to several ports, i.e., provide
several independent services. In practice, when a service request
comes in, they start a subprocess to handle the request (UNIX inetd)
Iterative vs. concurrent servers: Iterative servers can handle only
one client at a time, in contrast to concurrent servers
Processes
7
Servers and state
Stateless servers:
Never keep accurate information about the status of a client after having
handled a request:
 Don’t record whether a file has been opened (simply close it again
after access)
 Don’t promise to invalidate a client’s cache
 Don’t keep track of your clients
Consequences
 Clients and servers are completely independent
 State inconsistencies due to client or server crashes are reduced
 Possible loss of performance because, e.g., a server cannot
anticipate client behavior (think of prefetching file blocks)
Processes
8
Servers and state
Question
Does connection-oriented communication fit into a
stateless design?
Processes
9
Servers and state
Stateful servers
Keeps track of the status of its clients:
Record that a file has been opened, so that prefetching
can be done
Knows which data a client has cached, and allows clients
to keep local copies of shared data
Observation
The performance of stateful servers can be extremely
high, provided clients are allowed to keep local copies. As
it turns out, reliability is not a major problem.
Processes
10
Server clusters: three tiers
Crucial element
The first tier is generally responsible for passing requests
to an appropriate server.
Example: PlanetLab
Processes
11
Request Handling
Observation
Having the first tier handle all communication from/to the
cluster may lead to a bottleneck.
Solution: Various, but one popular one is TCP-handoff
Processes
12
Code migration
Why move code?
 Optimise computation (load balancing)
 Optmise communication
Weak vs Strong Mobility:
 Weak transfer only code
 Strong transfer code and execution segment
Sender vs Receiver Intitated migration:
 Sender Send program to compute server
 Receiver Download applets
What are the challenges of code mobility?
Processes
13