The patent badge is an abbreviated version of the USPTO patent document. The patent badge does contain a link to the full patent document.
The patent badge is an abbreviated version of the USPTO patent document. The patent badge covers the following: Patent number, Date patent was issued, Date patent was filed, Title of the patent, Applicant, Inventor, Assignee, Attorney firm, Primary examiner, Assistant examiner, CPCs, and Abstract. The patent badge does contain a link to the full patent document (in Adobe Acrobat format, aka pdf). To download or print any patent click here.
Patent No.:
Date of Patent:
Aug. 04, 2020
Filed:
Jun. 22, 2018
Microsoft Technology Licensing, Llc, Redmond, WA (US);
Georgi M. Chalakov, Duvall, WA (US);
Shane Kumar Mainali, Duvall, WA (US);
Thomas Leo Marquardt, Newcastle, WA (US);
Zichen Sun, Sammamish, WA (US);
Maneesh Sah, Sammamish, WA (US);
Esfandiar Manii, Kirkland, WA (US);
Saurabh Pant, Bellevue, WA (US);
Dana Yulian Kaban, Seattle, WA (US);
Saher B. Ahwal, Redmond, WA (US);
Jun Chen, Redmond, WA (US);
Da Zhou, Seattle, WA (US);
Amit Pratap Singh, Redmond, WA (US);
Junhua Gu, Bothell, WA (US);
Shaoyu Zhang, Shanghai, CN;
Wei Chen, Shanghai, CN;
Jingchao Zhang, Shanghai, CN;
Quan Zhang, Kenmore, WA (US);
Arild Einar Skjoldsvold, Kenmore, WA (US);
Microsoft Technology Licensing, LLC, Redmond, WA (US);
Abstract
A service enables a command that refers to a file system object using a hierarchical namespace identifier to be executed against the file system object in a flat namespace. The service selectively distributes the command to one of a plurality of name resolution nodes based on a directory name included in the hierarchical namespace identifier. The identified node resolves the directory name to a flat namespace identifier that is used to execute the command against the flat namespace. After communicating with at least one storage node to resolve a directory name, each name resolution node stores a mapping of the directory name to the corresponding flat namespace identifier in a cache, so that subsequent resolutions of that directory name may be performed more efficiently. Cache entries may be invalidated when an operation occurs that impacts the relevant mapping and/or based on system considerations such as cache expiry.