Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
MOUNTING DYNAMIC ENDPOINTS
Document Type and Number:
WIPO Patent Application WO/2018/022928
Kind Code:
A1
Abstract:
A client application is provided with a view of a subset of objects within an object store. A REST protocol, REST interface, or API may be used to access the objects. A coupling server may include a filter and a generator. The generator may automatically generate object metadata for newly created files that matches a filter. A client application may mount a drive on a computer based on metadata objects, such as providing a filter on object metadata to view files a user wants to access; or editing, reading, and updating object metadata as a file.

Inventors:
OLSEN GLEN (NZ)
TURPIN RUSSELL (US)
RING JONATHAN (US)
Application Number:
PCT/US2017/044236
Publication Date:
February 01, 2018
Filing Date:
July 27, 2017
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
CARINGO INC (US)
International Classes:
G06F17/30
Foreign References:
US20120303600A12012-11-29
JP2014032610A2014-02-20
US20040034550A12004-02-19
US20130226888A12013-08-29
US20100049817A12010-02-25
Attorney, Agent or Firm:
VAN GIESON, Edward et al. (US)
Download PDF:
Claims:
CLAIMS

We Claim:

1. A method of accessing from a client application a subset of file data from

object storage, said method comprising:

a. receiving, at a coupling server on a computer via a file system protocol, a file access request from a client application;

b. providing access to a subset of objects within an object store corresponding to the file access request, wherein objects in an object store have associated object metadata matching a filter that is predefined or included in a mount command from the client application;

wherein the client application can access a selected subset of objects within the object store.

2. A method as recited in claim 1, wherein object metadata is automatically generated for a new file such that in response to receiving a new file name an object name and object metadata is generated for the new file name.

3. A method as recited in claim 1, wherein the file access request is an OPEN for a selected file and the client application specifies a requested file to open.

4. A method as recited in claim 4, wherein an object specification is generated for the requested file, object data is retrieved and a filter determines if the object is visible such that the file is open if the object is found and is visible.

5. A method as recited in claim 1, wherein the file access request is a file

CREATE and the client application specifies a file name to write, and an object and object metadata is generated for a created file.

6. A method as recited in claim 1 , wherein the file access request is a READ for a selected file and the client application specifies an open file handle and byte information for the file, the coupling server validates the open file handle and in response determines a conversion required to read object data from the object store for the selected file.

7. A method as recited in claim 1, wherein the file access request is a WRITE for a selected file and the client application specifies an open file handle and byte information for the file, the coupling server validates the open file handle and in response determines any necessary offset and writes data to the object associated with the selected file.

8. A method as recited in claim 1, wherein the file access request is a DELETE for a selected file and the client application specifies a file specification, an object specification is crated for the selected file, a list of corresponding objects is determined and the corresponding objects are deleted from the object store.

9. A method as recited in claim 1 , wherein the file access request is a LIST

request for a file specification by the client application, wherein an object specification is generated for the file specification, a search is performed for objects matching the object specification, and a file listing is returned to the client application.

10. A method as recited in claim 1, wherein the file access request is a

METADATA EXPOSURE request for a file requested by the client application, wherein an object specification is generated for the requested file, and the file and associated metadata is returned to the client application.

11. A method as recited in claim 1 wherein objects in the object store are accessed via a REST interface.

12. A method as recited in claim 1, wherein objects in the object store are accessed via an API.

13. A method as recited a claim 1, wherein the client application is provided a view of a subset of objects with the object store filtered according to the logical predicate of the filter.

14. The method as recited in claim 1, wherein a generator ensures that new files created by the client application have metadata that matches the filter.

15. A method of interfacing file access requests from a client application onto object storage, said method comprising:

a. receiving, at a coupling server on a computer via a file system protocol, an access request from a client application that includes a file name to generate a new file;

b. generating for the new file, at the coupling server, object specification

information including an object name and object metadata to access an object from an object store; and c. utilizing the object specification for at least one subsequent access by the client computer to access the object from the object store for at least one of opening the file, reading the file, writing the file, deleting the file, and exposing metadata for the file.

16. A method as recited in claim 15, wherein a filter is predetermined or

included in a mount command from the client application and the filter determines if the object is visible.

17. A method as recited in claim 15, further comprising generating offsets to convert file specification information to access an object for a specified file.

18. A method as recited in claim 15 wherein objects in the object store are

accessed via a REST interface.

19. A method as recited in claim 15, wherein objects in the object store are accessed via an API.

20. A method as recited in claim 15, wherein the client application can access a selected subset of objects within the object store.

Description:
MOUNTING DYNAMIC ENDPOINTS

CROSS-REFERENCE TO RELATED APPLICATIONS

[0001] This application claims priority of U.S. provisional patent application No. 62/368,048 (Attorney Docket No. CRGOPOIOP), filed July 28, 2016, entitled "Mounting Dynamic Endpoints," and U.S. patent application No. 15/661,920

(Attorney Docket No. CRGOPOIO), filed July 27, 2017, entitled "Mounting Dynamic Endpoints," which is hereby incorporated by reference. This application is related to U.S. provisional patent application No. 62/368,050 (Attorney Docket No.

CRGOP011P), filed July 28, 2016 and also U.S. Patent Application No. 15/618,851 (Attorney Docket No. CRGOPOl 1) filed July 27, 2017, entitled "Multi-Part Upload," each of which is hereby incorporated by reference.

FIELD OF THE INVENTION

[0002] Embodiments of the present invention relate generally to file systems, object storage and metadata. More specifically, embodiments of the present invention relate to the ability to access object metadata via a file system.

BACKGROUND OF THE INVENTION

[0003] Some existing systems provide access to data storage through a

Representational State Transfer (REST) interface via a coupling that presents a file system interface for managing, storing, updating and retrieving objects, data and metadata. There are a variety of systems that provide such an interface, these include the Content File System (CFS) from Caringo, File Connectors from Scality and Coronado Access Points from Bridgestor.

[0004] The file system side of these couplings uses traditional file system protocols such as NFS (Network File System), Server Message Block (SMB)/Common Internet File System (CIFS) and File Transfer Protocol (FTP), through file system drivers, or through other mechanisms that provide a file system to a client computer.

[0005] These existing systems lack flexibility in that they do not include functionality to list a subset of objects on the basis of the object's metadata, nor do they include functionality to expose via a file system objects that are not created through it, i.e., objects that have been created directly through the object store or via other gateways to the object store. Users and applications only want to be presented with the subset of data (e.g., the digital objects) that they are interested in, and that subset should not always be the entire contents of a single bucket, container or exported directory, folder or share. Users and applications also want access to the desired set of objects through multiple means, e.g., file system and REST and other gateways. Existing file system interfaces also fail to provide access to object metadata that is stored with the object in the object store. Typically, file metadata is different from object metadata and it was not possible to access the object metadata via the traditional file system interface.

BRIEF DESCRIPTION OF THE DRAWINGS

[0006] The invention, together with further advantages thereof, may best be understood by reference to the following description taken in conjunction with the accompanying drawings in which:

[0007] FIG. 1 is a block diagram of a system in accordance with an embodiment.

[0008] FIG. 2 is an example of a list of open files to open file object mapping in accordance with an embodiment.

[0009] FIG. 3 is a block diagram of a system including a filter and generator in accordance with an embodiment.

[0010] FIG. 4 is a diagram illustrating a flow of an Open command operation in which a client application opens a file of one of the objects in the object store in accordance with an embodiment.

[0011] FIG. 5 illustrates a Create command operation in which the client application creates a new file in the Fin accordance with an embodiment.

[0012] FIG. 6 illustrates a Read command operation in accordance with an embodiment.

[0013] FIG. 7 illustrates a Write command operation in accordance with an embodiment.

[0014] FIG. 8 illustrates an embodiment of a delete command in accordance with an embodiment.

[0015] FIG. 9 illustrates an embodiment of a list command in accordance with an embodiment.

[0016] FIG. 10 illustrates metadata exposure in which the object store provides the metadata for an object as a pseudo-file in accordance with an embodiment. [0017] FIGS. 11A and 11B illustrate a computer system suitable for implementing embodiments of the present invention.

DETAILED DESCRIPTION OF THE INVENTION

[0018] Many data storage systems use a REST interface, i.e., one that is compliant with HTTP (RFCs 2616, 7230, 7231, 7232, 7233, 7234, 7235, 7236 and 7237). These interfaces provide the ability to store, retrieve and manage both data objects and metadata in the form of HTTP headers and their values. Examples of such interfaces include Amazon's S3 services, Openstack Swift and Caringo SCSP. File system interfaces, on the other hand, typically map onto a set of files identified by name, by name prefix, or by some pre-specified region of storage, e.g., all objects and files belonging to a particular customer.

[0019] "Object storage" is used here in reference to stored data accessible through a REST interface, for both original data and metadata that may be defined when the data is stored, or later modified. The term is agnostic to the ultimate persisted format, i.e., object storage includes storage systems that ultimately persist data as files, as blocks, or as objects. It also is agnostic with regard to the computer server architecture, which may be clustered or not, and if clustered, may be symmetric or layered or organized as a ring, or some combination. An "object store" refers to one or a set of computer servers providing object storage.

[0020] Though the metadata of a digital object typically is captured as a set of HTTP headers, it may be captured via other aspects of a REST protocol that provide name- value pairs, such as query parameters. The values may be treated as text strings or interpreted as Booleans, numbers, dates, GPS locations, or other metrizable values.

[0021] As mentioned above, one difficulty with the prior art is that one cannot access the object metadata stored with the object in an object store via a traditional file system interface on a client machine. For example, a doctor in a clinic may have access to a file system that stores x-ray images from hundreds of patients, taken on different dates, and of different limbs. When patient X walks in, it is difficult and time-consuming for the doctor to find just those images of that particular patient that the doctor needs using the traditional file system hierarchy. Each x-ray image may be stored as a digital object in an object store, and may have metadata attached to it, but that metadata is not accessible to the doctor on his or her computer using a traditional file system interface.

[0022] Advantageously, and as will be described in greater detail below, one aspect of the present invention provides a user or client application the ability to access an object's metadata using a traditional file system interface without any changes to that interface, and or to the underlying file system technology or architecture. Thus, the user may read, modify or store an object's metadata via standard file system commands; any type of tag may be added to a file which will then be attached to the object in object storage as object metadata. For example, a patient's insurance identifier may be attached as a tag to each x-ray image of that patient allowing for easy later retrieval. In one simple example, the following file command returns the metadata corresponding to the insurance identifier for a particular file: Read filename :InsID. In another simple example, this file command saves a value for the metadata: Save filename: metadata. A tag attached to a file's metadata may be any conceivable type, value, range, etc.

[0023] Even more advantageously, the ability to access an object's metadata using a file system interface provides a second aspect of the present invention that allows a user or client application to mount a drive on a computer based on metadata of objects, thus providing a filter based on object metadata. A user or client application has ability to mount a drive that will provide a view of only the files they wish to see. For example, a doctor may mount a D: drive with a filter that specifies the particular insurance identifier of patient X; therefore, only those x-ray images having that particular metadata tag will appear in drive D: on the doctor's computer. In addition, as more files are created and stored in the object store having the particular tag specified by the filter, these files will now automatically appear in the view of drive D: on the computer.

[0024] Embodiments of the invention are processes that: 1) further refine the subset of objects mapped through the use of REST interface-accessible object and object metadata, 2) automatically attach metadata to all new objects created through the coupling, and 3) provide create, read and edit access to the REST interface-accessible metadata through traditional file system protocols. [0025] Figure 1 is a block diagram of a system 100 for implementing embodiments of the present invention. Shown is a client computer 105 on which executes a client application which may be any suitable software such as linux mount, linux command shells such as bash or commands like vi, Microsoft windows drive mapping, Microsoft windows explorer, Mac OS X finder, or applications such as NFS servers, SMB or CIFS servers such as Samba, FTP Servers, media streamers, document management systems and archiving applications which are arranged to communicate via a standard file protocol (e.g., NFS, SMB, CIFS, FTP, etc) 110 with the coupling server computer 115, to make various file requests, and to issue commands as will be described in greater detail below.

[0026] The presentation to the client application or user is simulated file system operations, having a traditional hierarchical namespace and providing to the application or user the standard operations to open or delete a file that already exists, to create a new file that does not yet exist, to list a subset of files, and to read data from or write data to an opened file. The embodiments of the present invention below describe implementations of file system operations initiated by the client application in the context of an object store 130.

[0027] The coupling server 115 is software that executes upon any computer and is capable of communicating with the client application of client computer 105 and with the object store 130, capable of storing logical predicates, and maintaining a list of open files by name or unique identifier with an associated object name or identifier of a digital object in the object store, and the object's metadata. An object store REST protocol or API 120 is used to communicate with a REST interface 125 to access the object storage 130.

[0028] An example of a list of open files is illustrated in Figure 2, which shows a coupling server to open file object mapping in accordance with an embodiment. In this example, there is a mapping between an open filelD, a file name, and an object. For example, a doctor may mount a D: drive with a filter that specifies a mapping of open filelD, a file name, and an object. In this example, the first three entries are mappings for x-ray data and the fourth entry is for a scan.

[0029] Object Store 130 is any suitable object storage system with built in or third party extension object and object metadata indexing existing upon suitable computer hhaarrddwwaarree ssuucchh aass hhaarrdd ddrriivveess,, ssoolliidd--ssttaattee ddiisskkss,, flflaasshh ssttoorraaggee aanndd mmaayy iinncclluuddee oobbjjeecctt ssttoorraaggee ssyysstteemmss ssuucchh aass CCaarriinnggoo SSwwaarrmm,, AAmmaazzoonn SS33,, DDDDNN,, HHDDSS,, ooppeennssttaacckk SSwwiifftt aanndd IIBBMM CClloouudd OObbjjeecctt ssttoorraaggee aanndd SSccaalliittyy..

[[00003300]] FFiigguurree 33 sshhoowwss aann iimmpplleemmeennttaattiioonn hhaavviinngg aa RREESSTT iinntteerrffaaccee 332255,, aa ccoouupplliinngg 55 sseerrvveerr 331155 tthhaatt iimmpplleemmeennttss tthhee pprroocceesssseess tthhaatt aarree eemmbbooddiimmeennttss ooff tthhee pprreesseenntt

iinnvveennttiioonn aanndd aa cclliieenntt oonn aa cclliieenntt ccoommppuutteerr 330055,, wwhheetthheerr aa ppeerrssoonn uussiinngg tthhee ccoouupplliinngg sseerrvveerr 331155 tthhrroouugghh aa uusseerr iinntteerrffaaccee oonn aa cclliieenntt ccoommppuutteerr 330055 aanndd,, oorr ootthheerr ccoommppuutteerrss uussiinngg tthhee ccoouupplliinngg sseerrvveerr vviiaa aa nneettwwoorrkk iinntteerrffaaccee.. TThhee ccoouupplliinngg sseerrvveerr 331155 mmaayy bbee aa ssiinnggllee ccoommppuutteerr oorr mmuullttiippllee ccoommppuutteerrss wwoorrkkiinngg ccooooppeerraattiivveellyy.. TThhee ccoouupplliinngg sseerrvveerr 1100 331155 mmaayy iinncclluuddee aa ffiilltteerr 331177 aanndd aa ggeenneerraattoorr 331199.. AAnn ooppttiioonnaall oobbjjeecctt iinnddeexx 333322 mmaayy bbee iinncclluuddeedd iinn tthhee oobbjjeecctt ssttoorree 333300 oorr mmaaddee aavvaaiillaabbllee bbyy aa tthhiirrdd ppaarrttyy eexxtteennssiioonn ttoo ssuuppppoorrtt aa sseeaarrcchh ffuunnccttiioonn..

[[00003311]] IInn oonnee eemmbbooddiimmeenntt aann oobbjjeecctt''ss mmeettaaddaattaa mmaayy bbee eexxppoosseedd aass aa ppsseeuuddoo--ffiillee.. IInn oonnee eemmbbooddiimmeenntt tthhee ssyysstteemm ssuuppppoorrttss tthhee aabbiilliittyy ttoo mmoouunntt oorr mmaapp aa ddrriivvee oonn aa

1155 ccoommppuutteerr wwiitthh aa vviieeww ooff aa ssuubbsseett ooff oobbjjeeccttss wwiitthhiinn tthhee oobbjjeecctt ssttoorree 333300,, tthhee oobbjjeeccttss bbeeiinngg ssccooppeedd bbyy aa llooggiiccaall pprreeddiiccaattee ((tthhee ffiilltteerr 331177)) wwhhiicchh ooppeerraatteess oonn tthhee oobbjjeecctt mmeettaaddaattaa.. AA llooggiiccaall ffuunnccttiioonn,, tthhee ggeenneerraattoorr 331199,, eennssuurreess tthhaatt nneeww ffiilleess ccrreeaatteedd bbyy tthhee cclliieenntt aapppplliiccaattiioonn hhaavvee mmeettaaddaattaa tthhaatt mmaattcchheess tthhee ffiilltteerr 331177 aattttaacchheedd,, ffoorr eexxaammppllee iiff tthhee ffiillee vviieeww iiss bbeeiinngg ffiilltteerreedd oonn oobbjjeecctt wwiitthh tthhee aattttaacchheedd mmeettaaddaattaa ""XX--mmeettaa--

2200 ffiilleemmoouunntt:: ffoooo"" tthheenn tthhee ggeenneerraattoorr wwiillll aauuttoommaattiiccaallllyy aattttaacchh tthhaatt ffiilltteerrss mmeettaaddaattaa ooff ""XX--mmeettaa--ffiilleemmoouunntt:: ffoooo"" ttoo nneeww ffiilleess ccrreeaatteedd bbyy tthhee cclliieenntt aapppplliiccaattiioonn,, bbyy ddooiinngg ssoo nneewwllyy ccrreeaatteedd ffiilleess wwiillll mmaattcchh,, aappppeeaarr aanndd bbee aacccceessssiibbllee..

[[00003322]] IInn tthhee bbeellooww eexxaammppllee,, aallll oobbjjeeccttss wwiitthh tthhee ffoolllloowwiinngg hheeaaddeerrss mmaayy bbee ffiilltteerreedd oonn aanndd pprreesseenntteedd aass aa mmoouunntt ppooiinntt::

X-meta-filemount: foo

[0033] In this example if any new files are created by the client application through this filtered mountpoint, then the generator 319 will automaticity attach the two headers and values above to the new files, by doing so the client application does not need to be aware of the active filter or details of the metadata to attach to new files itself. [0034] The generator 319 may in some embodiments provide more complex text functions and other logical functions. The filter 317 in one embodiment is a general logical predicate. In addition, in the below descriptions, the filter 317 may simply be the constant predicate "True," in which case, all objects in the object store 330 are within its scope.

[0035] Returning to Figure 3, in one embodiment the system captures from the client computer 305 a logical predicate on metadata, that is the filter 307 is intended to qualify the set of objects that are surfaced through a particular coupling of object data to the file system. This predicate may include the file system name as a variable in the predicate. The logical predicate filter may be predefined or included in the mount command from the client. For example, the client may request to mount "allimages" which has a predefined filter set matching objects with metadata tagged as images, or they may specify the filter as part of the mount request itself, such as request to mount where object metadata matches content-type=images

[0036] The filter 317 then requests from the object index 332 a list of objects, including in the request the filter to restrict the object subset to, when such object search 3.e functionality is included in the object store 330 or third party extension, otherwise the filter 317 will itself refine the list to only those matching the requested filter from those returned by the object store 332, the list of matching objects obtained is then retuned by the coupling server 315 and from the coupling server 315 to the client computer 305 using the appropriate operation for the standard file protocol (NFS, SMB, Cifs, FTP etc) in use.

[0037] These components including the filter 317 and generator 319 are then used in the embodiments described below, thus creating a filtered object view file system mount point. In one embodiment, mounting is via standard file system methods such as the Unix/Linux mount command, Mac OS X finder connect to server, Microsoft Windows 'net use' or Windows Explorer 'add network location' . Advantageously, in one embodiment a file system mount point is defined against a set of objects qualified by having metadata that fits a particular predicate, the filter 317. The objects may have been created through the file system interface, as described below, or may be pre-existing in the object store 330. Flow Diagrams

[0038] Figure 4 shows an embodiment of an Open command (Open) in which the client application opens as a file one of the objects in the object store. In one embodiment, the Open is preformed using standard file system applications, for example a file could be opened through Microsoft Word, Mac OS X preview, a pdf viewer, a specialized PAX application, a document management system, a file editor such as Unix/Linux vi or an application issuing a ISO C standard open or other language equivalent. Figure 4 illustrates a set of steps: A client from client computer 305 specifies the file concerned as a request 405. The generator 319 receives a request 410 to convert the file name to an object name and generates an object specification 415. The object is located and its metadata is retrieved 420 from the object store. If the object is found, the filter 317 is applied 425 to the metadata to determine if the object is visible. If the filter 317 evaluates to "True," the object is presented 430 as having been opened through the file system interface and the coupling server stores the object- file pair as opened. If, however, the object is not located or the filter 317 evaluates to False, the file is presented as absent. In one embodiment the filter is reapplied on an open for security purposes to ensure that the user or application is allowed to open the file requested; if not a user could possibly request a file Open for a file that may exist in the object store but does not match the allowed filter. On a successful Open the coupling server returns a new file handle to the client; the client then uses this file handle to read or write data to the newly opened file.

[0039] The use of the generator 319 and filter 317 allows the scope of the "Open" command to be qualified by the metadata of the objects stored, a result that existing file system interfaces cannot achieve. Note that this command allows file system access to objects that have been created by means other than through the file system interface (which is described below in more detail).

[0040] Figure 5 shows an embodiment of a Create command (Create) in which the client application creates a new file thus creating a new object in the object store as opposed to opening an existing file. In one embodiment the Create is performed using standard file system applications, for example a file could be created through

Microsoft Word, Mac photos, a pdf editor, a specialized PAX application, a document management system etc, a file editor such as Unix/Linux vi or a application issuing a ISO C standard open() or other language equivalent. As illustrated in Figure 5, in one embodiment the client specifies 505 the file concerned, which may include a file name to write. The file system interface provides 510 the file name and associated properties to the coupling server 315. The coupling server 315 applies the generator 319 to the file system name to generate an object name 515. If the object name exists it locates the object in the object store and retrieves it 520. If an existing object is found, it deletes 525 the object from the object store along with its metadata and creates a new object. The new object so described is created in the object store ready for writing. The coupling server stores the object-file pair as opened, and returns 530 a new file handle and success to the client. In one embodiment the use of Create and the generator 319 guarantees that the new object will be qualified by the filter 317 for subsequent use. On a successful Create the coupling server returns a new file handle to the client, the client then uses this file handle to read from or write data to the newly opened file.

[0041] Figure 6 shows an embodiment of a Read command (Read) in which the client application of the client 305 reads a file that has been opened or created by one of the embodiments above. The object itself may also have been created previously using any support object store method. . In one embodiment, the Read is preformed using standard file system applications, for example a file could be opened through Microsoft Word, Mac OS X preview, a pdf viewer, a specialized PAX application, a document management system, a file editor such as Unix/Linux vi or a application issuing a ISO C standard read or other language equivalent, the file system application will have obtained a file handle prior to issuing the Read using either the Open or Create method as described above. In one embodiment a Read follows the follows a sequence of steps that includes the client specifying the opened file handle (provided by Open or Create), and a number of bytes to read at a specific offset. The coupling server 315 validates the handle and converts the offset. This may include determining whether the specified file is open (e.g., does it have a matching file handle) for reading or writing, if not, returning an error, otherwise converting the file offset to an offset in the object, and reading 615 those specified number of bytes from the object in the object store, and returning them 620 to the client. [0042] Figure 7 shows an embodiment of a write command (Write) in which the client application writes to a file that has been opened or created via the embodiments previous. In one embodiment, the Write is preformed using standard file system applications, for example a file could be opened or created and then written to through Microsoft Word, Mac OS X preview, a pdf editor, a specialized PAX application, a document management system, a file editor such as Unix/Linux vi or a application issuing a ISO C standard fprintf(), fputc etc or other language equivalent, the file system application will have obtained a file handle prior to issuing the Write using either the Open or Create method as described above. One embodiment includes the following steps. A client 305: the client specifies 705 the opened file handle, and a string of bytes to write at a specific offset. The coupling server 315 validate the handle and converts and offset 710, which can include determining that the specified file is open for writing, if not, returning an error and otherwise converting the file offset to an offset in the object. Writing data to an object 715 may be performing writing those bytes to the object in the object store. If the file handle is invalid or data cannot be written, an error is returned 720.

[0043] In the previous two embodiments, the object to be read from the object store (or to be written to the object store) may be a multi-part object that is uploaded or downloaded in pieces, as described in related patent application No. 62/368,050 (attorney docket CRGOPOl 1).

[0044] Figure 8 shows an embodiment (Delete) in which the client application deletes an object or set of objects from the object store. The Delete is preformed by the client by using standard file system applications such as Windows Explorer Delete, the Unix/Linux rm command or a application issuing a ISO C standard removeO or other language equivalent. In one embodiment, the client 305 specifies 805 a file or set of files by a regular expression on file names. The filter 317 may used to convert the file specification 810 into a specification of objects 815. The object specification is provided 820 to a search engine (based on the object store search index 332) to determine a set of objects 825 that qualify against the object stores search index 332. The qualified object objects are then deleted 830 from the object store, and their metadata removed from the Object Stores search index. [0045] This approach allows the file system interface to delete not only objects that have been created by opening a new file with the file system interface (using the Create embodiment above), but also objects that have been created otherwise such as through the objects stores provided object API (i.e. Caringo SCSP, Amazon S3) or other third party application that has integrated into the object stores object API (i.e. third party applications such as cyberduck, s3browser, Caringo FileFly, Commvault). The use of the generator guarantees that the possible scope of the Delete command is restricted to a desired set of objects based on their object metadata.

[0046] Figure 9 shows an embodiment of a list command (List) in which the client application requests a listing of a subset of files. In one embodiment the List is performed by the client by using standard file system applications such as Windows Explorer, the Unix/Linux Is command or a application issuing a ISO C standard readdir() or other language equivalent. One embodiment includes the client 305 requests a list of files based on a file specification 905 from the coupling server which match a customized client specified file specification that may include a regular expression or set of expressions, and possibly metadata criteria in addition to the stored filter. The coupling server 315 uses those qualifiers and the persisted client filter 317 to convert that into a predicate on object metadata. For example the file specification is provided 910 to the filter 317 which creates an object specification 915. The coupling server uses this to issue a query 920 to the object store search index using any method provided to the coupling server by the search index and/or object store to query the search index for object identifiers based on the metadata and perform a search that determines a list of objects 925. For each object with matching metadata returned from the search index the coupling server generates a file name and properties, and e) the coupling server returns 930 this list to the client.

[0047] In one embodiment the use of the generator guarantees that listings are scoped to the set of objects whose metadata qualifies them. Note that this embodiment exposes in the file system interface not only objects that have been created through the file system interface by the Create embodiment, but also those objects which have been created directly in the object store such as through the objects stores provided object API (i.e. Caringo SCSP, Amazon S3) or other third party application that has integrated into the object stores object API (i.e. third party applications such as cyberduck, s3browser, Caringo FileFly, Commvault.

[0048] Figure 10 shows an eighth embodiment (metadata exposure) in which the object store provides the metadata for an object as a pseudo-file. In contrast, objects metadata is conventionally not available to clients using standard file system methods, modifying traditional file system commands, methods and APIs would require all existing and new file based applications to be updated to reflect, this is not feasible. Instead this embodiment provides a method for standard file clients and applications to access and update an objects metadata without the requirement to change or add to standard file system APIs and methods, this in addition provides existing file system clients and applications access to an Objects metadata without requiring major changes to those clients and applications, in many cases no application code changes are now needed at all, only minor re-education of the application and clients users.

[0049] The name for the object is derived from the file name by a fixed file name mapping, such as a predefined prefix or a predefined suffix for the file name or other label of the file name. For example if the Object name is "exampleobject" then when the predefined suffix of ":metadata" is added, resulting in "exampleobject:metadata" the label is ":metadata" The metadata may then be retrieved and edited as a file.

[0050] In one embodiment, the client specifies in a file requestl005 the file concerned, using the metadata label.) The generator is provided this information 1010 and is used to convert the file name to an object specification 1015 (object name), which may include (removing the label). The object is then located and the object and its metadata is retrieved 1020 from the object store 330. If the object is found, the filter is applied to the metadata, and e) if the filter evaluates to True, the file's metadata is presented as a file opened through the file system interface and the coupling server stores the object-file pair as opened. If, however, f) the object is not located or the filter evaluates to False, then the file is presented as absent.

[0051] As an example, consider a file "somefile", and assume that ":metadata" is used as the metadata label. The client application provides the command open

"somefile :metadata" This command opens a pseudo-file that presents as its contents the metadata associated with the object representing " somefile", the client can then read, modify and add new metadata to the object as thought it was written standard data to the file. For example:

[0052] If a object called "exampleobjec t" contains:

the data "This is the file data"

and the metadata "x-meta-data: this is the meta data"

And the metadata label in use is .-metadata

[0053] Opening and then reading the file in Unix/Linux using the command "cat exampleobject" will display the data "This is the file data"

[0054] Whereas Opening and then reading the file in Unix/Linux using the command "cat exampleobject:metadata" will display the attached metadata "x-meta-data: this is the meta data"

[0055] In addition, an Unix/Linux example of Opening and then writing to the file as "echo 'new data' > exampleobject" will change the object data to be 'new data' , whereas Opening and then writing in Unux/Linux like "echo 'x-meta-data: new metadata ' > exampleobjecf. metadata" will change the metadata attached to the Object named "exampleobject"

Computer System Embodiment

[0056] FIGS. 11A and 11B illustrate a computer system 1100 suitable for implementing embodiments of the present invention. FIG. 11 A shows one possible physical form of the computer system. Of course, the computer system may have many physical forms including an integrated circuit, a printed circuit board, a small handheld device (such as a mobile telephone or PDA), a personal computer or a super computer. Computer system 1100 includes a monitor 1102, a display 1104, a housing 1106, a disk drive 1108, a keyboard 1110 and a mouse 1112. Disk 1114 is a computer-readable medium used to transfer data to and from computer system 1100.

[0057] FIG. 1 IB is an example of a block diagram for computer system 1100.

Attached to system bus 1120 are a wide variety of subsystems. Processor(s) 1122 (also referred to as central processing units, or CPUs) are coupled to storage devices including memory 1124. Memory 1124 includes random access memory (RAM) and read-only memory (ROM). As is well known in the art, ROM acts to transfer data and instructions uni-directionally to the CPU and RAM is used typically to transfer data and instructions in a bi-directional manner. Both of these types of memories may include any suitable of the computer-readable media described below. A fixed disk 1126 is also coupled bi-directionally to CPU 1122; it provides additional data storage capacity and may also include any of the computer-readable media described below. Fixed disk 1126 may be used to store programs, data and the like and is typically a secondary mass storage medium (such as a hard disk, a solid-state drive, a hybrid drive, flash memory, etc.) that can be slower than primary storage but persists data. It will be appreciated that the information retained within fixed disk 1126, may, in appropriate cases, be incorporated in standard fashion as virtual memory in memory 1124. Removable disk 1114 may take the form of any of the computer-readable media described below.

[0058] CPU 1122 is also coupled to a variety of input/output devices such as display 1104, keyboard 1110, mouse 1112 and speakers 1130. In general, an input/output device may be any of: video displays, track balls, mice, keyboards, microphones, touch- sensitive displays, transducer card readers, magnetic or paper tape readers, tablets, styluses, voice or handwriting recognizers, biometrics readers, or other computers. CPU 1122 optionally may be coupled to another computer or

telecommunications network using network interface 1140. With such a network interface, it is contemplated that the CPU might receive information from the network, or might output information to the network in the course of performing the above-described method steps. Furthermore, method embodiments of the present invention may execute solely upon CPU 1122 or may execute over a network such as the Internet in conjunction with a remote CPU that shares a portion of the processing.

[0059] In addition, embodiments of the present invention further relate to computer storage products with a computer-readable medium that have computer code thereon for performing various computer-implemented operations. The media and computer code may be those specially designed and constructed for the purposes of the present invention, or they may be of the kind well known and available to those having skill in the computer software arts. Examples of computer-readable media include, but are not limited to: magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROMs and holographic devices; magneto-optical media such as floptical disks; and hardware devices that are specially configured to store and execute program code, such as application- specific integrated circuits (ASICs), programmable logic devices (PLDs) and ROM and RAM devices. Examples of computer code include machine code, such as produced by a compiler, and files containing higher-level code that are executed by a computer using an interpreter.

[0060] Although the foregoing invention has been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications may be practiced within the scope of the appended claims. Therefore, the described embodiments should be taken as illustrative and not restrictive, and the invention should not be limited to the details given herein but should be defined by the following claims and their full scope of equivalents.