Middies: Passive middleware abstractions for pervasive computing environments Daniel Cutting, Adam Hudson, Aaron Quigley University of Sydney Daniel Cutting, Adam Hudson, Aaron Quigley University of Sydney
Pervasive computing Middies Data distribution Pervasive computing Middies Data distribution
Pervasive computing Small mobile devices + large fixed servers Wireline and wireless communication Application collaboration chat, file store, video+audio matchmaking, games museum+gallery tours Small mobile devices + large fixed servers Wireline and wireless communication Application collaboration chat, file store, video+audio matchmaking, games museum+gallery tours
Art gallery scenario Edward Bob Cynthia Gillian Sunflowers, Van Gogh Bob was here. Bob was here.
Middleware Publish- subscribe: good for events Tuple spaces: good for data persistence Abstract sockets: good for streaming data Publish- subscribe: good for events Tuple spaces: good for data persistence Abstract sockets: good for streaming data
Pervasive computing Middies Data distribution Pervasive computing Middies Data distribution
Middies Generalised middleware abstractions Features of tuple spaces and pub-sub Store persistent data, publish events and handle streaming data Generalised middleware abstractions Features of tuple spaces and pub-sub Store persistent data, publish events and handle streaming data
Spaces Logically centralised shared structures like a tuple space Physically distributed over several devices Logically centralised shared structures like a tuple space Physically distributed over several devices
Blocks Data chunks like tuples, events, objects Stored by spaces permanently (like tuples) or forwarded to interested devices (like events) Data chunks like tuples, events, objects Stored by spaces permanently (like tuples) or forwarded to interested devices (like events)
Matchers Compare two blocks Application-defined Can implement tuple matchers, publish-subscribe subscription languages, etc. Compare two blocks Application-defined Can implement tuple matchers, publish-subscribe subscription languages, etc.
Reactors Callbacks fired by spaces under certain conditions Can implement events + abstract sockets Useful for pub-sub and streaming data Callbacks fired by spaces under certain conditions Can implement events + abstract sockets Useful for pub-sub and streaming data
Pervasive computing Middies Data distribution Pervasive computing Middies Data distribution
How do we distribute blocks around the network? Server? Single device stores all blocks Redundant? Each device stores replicas of all blocks Or…? How do we distribute blocks around the network? Server? Single device stores all blocks Redundant? Each device stores replicas of all blocks Or…?
Context-aided distribution Edward Bob Cynthia Gillian Unimportant (0.2) Long-lived (0.7) Large size (0.9) Group photo at Sunflowers Group photo at Sunflowers Group photo at Sunflowers Nearest situation vector is photo photo digest
Pervasive computing Middies Data distribution Pervasive computing Middies Data distribution
Chat, file store, video+audio Needs events (chat message added) data persistence (file store) data streaming (video+audio) Tedious and error-prone development file store would need special protocols for requesting/transmitting files from devices + way of handling unexpected disconnections Needs events (chat message added) data persistence (file store) data streaming (video+audio) Tedious and error-prone development file store would need special protocols for requesting/transmitting files from devices + way of handling unexpected disconnections