210 likes | 369 Views
GridFS Targeting Data Sharing in Grid Environments. Marcelo Nery dos Santos / Renato Cerqueira PUC-Rio, Brazil Presented by: Francisco Silva. Motivation. User-level file system infra-structure Providing access to remote file systems Having a simple configuration
E N D
GridFSTargeting Data Sharing in Grid Environments Marcelo Nery dos Santos / Renato Cerqueira PUC-Rio, Brazil Presented by: Francisco Silva
Motivation • User-level file system infra-structure • Providing access to remote file systems • Having a simple configuration • No need for super-user privileges • Lessening problems faced by CSBase, a framework for developing grid environments • Reducing NFS dependency • Facilitating deployment • Enabling useful file transfer metrics
Related Work • Distributed File Systems (e.g. NFS/AFS) • Configuration overhead for system administrators • Local access to large files is not available • Avaki Data Grid • Proprietary solution, no file transfer metrics • Globus • GridFTP / Reliable File Transfer Service • Useful, but hard installation for novices • Oversized solution for simpler cases
GridFS - Characteristics • Scalability, allowing a large number of files to be shared; • Performance; • Interoperability through the use of CORBA for remote access; • Federative approach.
GridFS - Characteristics • Historical data about data transfers, that can be used by scheduling algorithms in order to choose na executing host for a task based on the estimated time and effort for data transfer; • Metadata support that can store (field, value) tuples; • Object Oriented Interface.
GridFS - Features • Remote File System Access • List / Create / Delete files and directories • Read / Write operations over files • Retrieve file system free space • General Operations • Metadata get / set operations • Copy files directly between servers • Add / Remove mount points • In order to allow a GridFS federation
CORBA IDL – RemoteFile interface RemoteFile { RemoteFile createDirectory(in Path name) RemoteFile createFile(in Path name) RemoteFile getChild(in Path name) FileSequence getChildren() boolean remove() ReadChannel getReadChannel() WriteChannel getWriteChannel() RandomAccessChannel getRandomAccessChannel() boolean copyTo (in RemoteFile dst, in string method) boolean addMount (in Path name, in RemoteFile target) RemoteFile removeMountPoint (in Path name) FileServer getFileServer() //continues... }
GridFS – Data Accessibility • Remote Access • Through CORBA remote invocations • Allows read/write access • By mounting a GridFS on the local file systems using FUSE • Allows use of legacy applications • File Transfer Operations • Several implementation methods • Java NIO / CORBA / FTP • New methods/protocols can be easily added • Performance evaluation
Implementation Aspects • CORBA • Interoperability • Scalability • POA Policies (RootPOA) (DefaultServant) • Java • Portability • Performance issues • Use of NIO allows performance similar to FTP (Transfer Rate) (CPU) (Load)
GridFS - Limitations • Remove operations only over leaves • Files or empty directories • No lock mechanism • Several writers to the same file (unix-like) • Single user • No users, groups or permissions • Caching • No caching policies implemented
Limits Tested • Simultaneous file transfer operations • NIO (96 - 192, independently of the method used) • FTP (50, PureFTPd server limit) • CORBA (80 - 480, 80 threads dealing with 480 ops) • Performance • NIO and FTP: limited by IDE disk speed (Gigabit network) • CORBA: limited by disk speed and Round Trip Time • FUSE: 1,5MB/s (naive implementation) • Remote Access Channels • 1000 (operating system file descriptors limit)
CSBase • Infra-structure for remote algorithm execution • GridFS used to implement CSFS Daemon • Files are copied to execution host or accessed remotely by NFS • CSBase server controls file transfer operations from Data Repository to Execution Hosts • CSFS Daemons allow local file system accessibility
CSBase: Algorithm Execution • User requests an algorithm execution • CSBase server creates an object to handle the request • This object verifies if the selected execution host has access to binaries and data files (uses CSFS to copy files, if necessary) • CSBase server starts a command on that host using the Node Daemon • Whenever the command is finished, the modified files are synchronized back to repository • A clean-up procedure is invoked • Client is notified of command completion
Main Contributions • A file server that: • Is scalable, portable, interoperable • Has reasonable performance • Combines the benefits of different approaches • Remote File Access • File Staging • Offers special functionalities for Grid Computing (estimated transfer cost and file copy to local system)
Future Work • Notification Mechanism • Allowing caching policies implementation and online remote-tree visualization for GUIs • Users and security issues • In order to guarantee data integrity and confidentiality • Index and search capabilities • Over the stored metadata