User Tools

Site Tools


research:dgc

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
Next revisionBoth sides next revision
research:dgc [2006/07/01 13:36] elisagresearch:dgc [2006/07/01 15:27] elisag
Line 3: Line 3:
 ==== Motivation ==== ==== Motivation ====
  
-Mobile ad hoc networks represent a new kind of distributed system with distinguishing characteristics that pose new challenges in the field of distributed garbage collection (DGC). In particular, DGC must deal with a highly partial disconnected network topology where remote references may be inaccessible for unpredicted amount of time. DGC mechanisms typically determine the reachability of the remote objects by means of communication between the nodes involved. However, in a mobile setting where disconnections are the rule rather the exception, the system cannot determine how long it should wait for a connection to be restored. At best, the failure will be transitory and the created inaccessible reference will become accessible again by a repaired connection, but at worst the devices may never encounter again - e.gwhen a user never comes back to a certain place and an unbounded amount of inaccessible reference will be accumulated as they move about+Mobile ad hoc networks represent a new kind of distributed system with distinguishing characteristics that pose new challenges in the field of distributed garbage collection (DGC). In particular, DGC must deal with a highly partial disconnected network topology where remote references may be inaccessible for unpredicted amount of time. DGC mechanisms typically determine the reachability of the remote objects by means of communication between the nodes involved. However, in a mobile setting where disconnections are the rule rather the exception, the system cannot determine how long it should wait for a connection to be restored. Knowing when the communication will be restored depends on how the application reacts to disconnections. Some applications may wait for the connection to be restored to resume its computation while some others may continue their computation with a substitute service instead. Sometimes the geographic location of the devices or identify information may also influence the behaviour of mobile applicationsTherefore, DGC process depends not only on the object graph but also on the //context// in which the objects are themselves understanding context as the semantics of the application or the role of the reference in the network, but also implicit context such as the location of devices
  
-Knowing when the communication will be restored between two devices depends on how the application reacts to disconnections. Some applications may wait for the connection to be restored to resume its computation while some others may continue their computation with a substitute service in the proximity instead of waiting for the connection to be restored. Moreover, context information may also influence the behaviour of mobile applications. Imagine the case of a user that wants to print some of their PDA files in a printer available in the ambient. Considering that this interaction occurrs at the user's home, their PDA will establish a remote reference to the user printer service. The PDA application could keep this remote reference after the disconnection of the devices since there is a high change that the user will come back eventually and print another file. Considering the same kind of interaction when the user is attending a conference, the remote reference could be reclaimed after the termination of the conference once the user has left. These examples illustrates that DGC process depends not only on the object graph but also on the context in which the objects are themselves - understanding context as internal context such as the semantics of the application or the role of the reference in the network, but also external context such as the location of the devices or identity information.  +Our position is that reclaiming remote objects can no longer be a low level concern tackled in a transparent way via a DGC mechanism. On the contrary, we admit that automatic transparent DGC is irreconcilable with the characteristics intrinsic to mobile networks. Our research proposes a novel treatment of the memory management called //semi-automatic garbage collection// based on the collaboration between the developer and collector which will be guided by the developer to determine the reachability of the remote objects. 
- +
-As a result, we claim that reclaiming remote objects can no longer be a low level concern tackled in a transparent way with a DGC mechanism.  On the contrary, we admit that automatic transparent DGC is irreconcilable with the characteristics intrinsic to mobile networks since context information is necessary to ascertain whether remote references can be cleared. Our research proposes a novel treatment of the memory management called //semi-automatic garbage collection// based on the collaboration between the developer and collector which will be guided by the developer to determine the reachability of the remote objects. +
  
 ==== Design ====  ==== Design ==== 
  
-Semi-automatic garbage collection is a hybrid approach which relies on an underlying local GC and proposes a non-transparent DGC. The approach can be seen as an extension to the indirect reference counting (Piquer,1991) and network objects (Birrel et al.m 1993) since it also maintains the distributed inverse reference graph (IRG) where each remote object keeps a list of pointers to other devices which have references to it. However, the IRG is augmented with additional semantic information attached to the remote references to help the collector to determine the reachability of the remote objects they point to.  This means the developer will be able to steer the gc proccess and accomodate the requirement of the applications by means of annotating the remote references. +Semi-automatic garbage collection is a hybrid approach which relies on an underlying local GC and proposes a non-transparent DGC. The approach can be seen as an extension to the indirect reference counting (Piquer,1991) and network objects (Birrell et al.m 1993) since it also maintains the distributed inverse reference graph (IRG) where each remote object keeps a list of pointers to other devices which have references to it. However, the IRG is augmented with additional semantic information attached to the remote references to help the collector to determine the reachability of the remote objects they point to.  This means the developer will be able to steer the gc proccess and accomodate the requirement of the applications by means of annotating the remote references. 
  
 {{ remoterefint.jpg?430x250 }} {{ remoterefint.jpg?430x250 }}
research/dgc.txt · Last modified: 2015/02/04 19:10 by elisag