P2L5. Thread Performance Considerations Flashcards
What are the pros/cons of a multi-process (MP) implementation?
Pros:
- Simple programming
Cons:
- High memory usage
Costly to context switch
- Hard/costly to maintain shared state
data:image/s3,"s3://crabby-images/ca2ab/ca2ab0e6569d4904c02ed0bc9895bf11927b6e42" alt=""
What are the pros/cons of a multi-threaded (MT) approach?
Pros:
- Shared address space
- Shared space
- Cheap context switch
Cons:
- Not simple implementation
- Requires sychnonization
- Need underlying support for threads on OS (not an issue today)
How does the Event Driven Model work? (TODO: Ask a better question?)
data:image/s3,"s3://crabby-images/612ee/612ee117221c58ac1773705f4bae3ddcee8b8dfe" alt=""
How does the Event-Driven Model achieve concurrency?
MP and MT: 1 request per execution context (process/thread)
Event-driven: Many requests interleaved in an execution context.
data:image/s3,"s3://crabby-images/463ae/463aef2f916ee6d1ed500f8ba0edecb8c101736b" alt=""
What are the pros/cons of Event-Driven Model?
Pros:
- Single address space
- Single flow of control
- Smaller memory requirement
- No context switching
- No sychronization
Cons:
- Loss of cache locality
- A blocking request/handler will block the entire process
What does the Event-Driven Model use helpers for?
When async calls are not available, helpers can be used instead.
Helpers are:
- designated for blocking I/O operations only
- pipe/socket based communication w/ event dispatcher => select()/poll() still ok!
- helper blocks, but main event loop (and process) will not
At the time the Flash paper was written not all OSes were multi-threaded, so they used processes for helpers.
What are the pros/cons of helper processes in the Event-Drive Model (AMPED/AMTED)?
data:image/s3,"s3://crabby-images/e9a03/e9a038b6b435a766725eae094819e90b64be4425" alt=""
Compare/contrast performance of Flash, SPED, MT, MP when the data is cached and when it’s not cached.
data:image/s3,"s3://crabby-images/aa623/aa62303ab6fa53ec6b74cf3934bb7cd617d5cbcc" alt=""