Movatterモバイル変換


[0]ホーム

URL:


USRE48894E1 - Disaggregated resources and access methods - Google Patents

Disaggregated resources and access methods
Download PDF

Info

Publication number
USRE48894E1
USRE48894E1US16/422,873US201916422873AUSRE48894EUS RE48894 E1USRE48894 E1US RE48894E1US 201916422873 AUS201916422873 AUS 201916422873AUS RE48894 EUSRE48894 EUS RE48894E
Authority
US
United States
Prior art keywords
resource
nodes
node
disaggregated
resource nodes
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US16/422,873
Inventor
Thomas Earl Ludwig
Mark Adams
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Intellectual Ventures I LLC
Original Assignee
Rateze Remote Mgmt LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Rateze Remote Mgmt LLCfiledCriticalRateze Remote Mgmt LLC
Priority to US16/422,873priorityCriticalpatent/USRE48894E1/en
Assigned to RATEZE REMOTE MGMT. L.L.C.reassignmentRATEZE REMOTE MGMT. L.L.C.ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: ZETERA CORPORATION
Application grantedgrantedCritical
Publication of USRE48894E1publicationCriticalpatent/USRE48894E1/en
Assigned to INTELLECTUAL VENTURES I LLCreassignmentINTELLECTUAL VENTURES I LLCASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: RATEZE REMOTE MGMT. L.L.C.
Activelegal-statusCriticalCurrent
Adjusted expirationlegal-statusCritical

Links

Images

Classifications

Definitions

Landscapes

Abstract

Disaggregated resources distributed among resource nodes provide access to resource consumers by offering resource node information to the resource consumers. Resource node information supplied by each individual resource node comprises incomplete information with respect to the complete disaggregated resource. Resource consumers collect resource node information to create maps of the disaggregated resource, ensure coherency, or manage the disaggregated resource.

Description

CROSS REFERENCE TO RELATED APPLICATION
The present application is a second reissue application of U.S. Pat. No. 8,819,092. The present application is a continuation reissue of U.S. patent application Ser. No. 15/247,779, filed Aug. 25, 2016, now pending, which is an application for reissue of U.S. patent application Ser. No. 11/205,895, filed Aug. 16, 2005, issued as U.S. Pat. No. 8,819,092.
FIELD OF THE INVENTION
The field of invention is disaggregated resources especially storage devices, memories, displays, CPUs, or other computing resources.
BACKGROUND OF THE INVENTION
As computers have increased in capabilities the demand for computing resources has also grown. In fact, the demand for computing resources has grown to the point that, in many cases, far outstrips the capabilities of a single computer to deliver resources to a user or application. For example, enterprises have been aware of this issue for many years and continue to buy racks of servers, storage arrays, or other computing resources at great cost to satisfy their needs for computing resources. In addition, many consumers employ external hard disk drives to store massive amounts of personal media data because their personal computers lack sufficient capacity. There are many reasons that drive the demand and proliferation of computing resources including legislation that affect enterprises, applications, ubiquitous digital cameras, media players, and countless other reasons. Industry has responded to the demand by producing products that provide computer resources to users and applications where the computing resource products are no longer centralized to a single computer. Furthermore, the industry is tending toward a distribution of computing resources where individual computer systems offer their capabilities or services to other users and applications where on example includes NAS file servers.
Yet another trend in the industry is to disaggregate resources into their constituent resource device elements, for example USB disk drives or SAN systems. However, these approaches do not address combining a number of resource elements together into a coherent virtual whole from the perspective of an arbitrary set of resource consumers, but rather these approaches still follow a centralized approach.
Even though the industry combines computing resources into a centralized set of capabilities or services as in SAN systems, it is still desirable to have the computing resources exist as individual resource nodes. Centralized resources imply further costs to due to the expense of the additional computer hardware and infrastructure; introduce yet another point of potential failure beyond the computing resources; create a bottleneck that all resource consumers must pass through, and so on. Disaggregated resources that comprise a collection of individual resource nodes that work independently but operate as a whole without a centralized controller or manager alleviate many of these problems. Individual resource nodes carry a smaller per unit price tag reducing incremental cost and offering stronger scalability, introduce no additional points of failure, do not require out-of-band communication increasing responsiveness, and operate in parallel increasing performance. Some known examples of distributed resources include clusters or applications like SETI@Home that offer CPU bandwidth as the computer resource. These examples are “distributed resources” where they rely on complete computer systems rather than individual computing resources and operate at an application level rather than at a resource device level.
Offering true disaggregated resources that comprise a number of resource nodes has a number of critical problems that must be overcome in order to deliver a solid disaggregated solution. First, networks are inherently unreliable and have latency; consequently resource nodes might loose connectivity with a resource consumer. Connectivity is important where the state or coherency of the resource from the perspective of a resource consumer is important. Second, multiple resource consumers can have different “views” of a disaggregated resource from each other; therefore, each resource consumer can have a different resource map used to access the disaggregated resource. Furthermore, most computer systems require access to a resource at a very fine level of granularity well below the resource device level. For example, when a CPU addresses memory, it attempts to reference a single byte or word. Such fine level granularity access is difficult in a disaggregated resource because a resource consumer does not necessarily have a sufficiently detailed and complete map of the disaggregated resource. Third, the organization of the resource nodes can be quite complex depending on a number of factors including type of resource involved, the roles or responsibilities of each resource node, resource node location, or other implementation specific information. Fourth, operating systems have to interpret the disaggregated resource as if it were locally connected in order to provide applications seamless, transparent integration with the computing environment.
A number of attempts have been made previously to provide a solid solution addressing the problems encountered when building a disaggregated resource. BitTorrent™, a peer-to-peer file transfer system, offers redundant file storage as a distributed resource where each resource node is complete computer system offering file storage. BitTorrent™ places redundant copies of data on multiple peers to alleviate some of the risk of an unreliable network; however, the peers are outside the control of the ultimate user so the user does not know if a peer is lost. Any owner of a BitTorrent™ system can take down their computer reducing the overall performance for a remote unknown user. Although each BitTorrent™ user has a different view of the network based on connectivity, a user can not, in a deterministic fashion, determine the extent and usability of the system. Unfortunately, BitTorrent™ is an application level protocol and does not provide a transparent solution of a storage resource that allows an operating system or application to read and write data at will. Cleary, BitTorrent™ offers some utility for high level file transfers; it is not suitable for consumer or enterprise system due to the lack of control, determinism, fine level access, or performance. BitTorrent™ and other peer-to-peer systems have not addressed the need for resource consumers to understand a complete map for a coherent disaggregated resource at an elemental level.
Hitachi's U.S. Pat. No. 4,890,227 offers a resource management system for operating systems of large scale computers. The memory, CPUs, I/O channels, and storage devices represent disaggregated resources. The management system relies on a set of policies that are continually updated and deleted to equitably and autonomously assign resources to process units (programs, threads, or tasks). The Hitachi patent does not address issues of resource coherency over an unreliable communication path or issues of multiple resource consumers (process units) having different views of the resources because a centralized management system handles all the resources for the process units. The Hitachi patent does not provide insight on how a resource consumer will manage and access resource nodes of a disaggregated resource that extend beyond the core computer. Even though the Hitachi patent addresses more elemental resources, the centralized resource management system does not allow resource consumers build their own view of the system or to function independently. Furthermore, the Hitachi patent offers no insight how to address fine level of structure of a resource.
Microsoft's U.S. Pat. No. 6,912,622 attempts to resolve some of problems associated with a distributed resource that are similar to the problems associated with a disaggregated resource where the distributed resource is a peer-to-peer system. The Microsoft patent uses an underlying statistical assumption regarding the probability of a first peer knowing a second peer's ID based on the “distance” between the first peer's ID and the second peer's ID. Through this structure, the Microsoft patent offers an efficient peer-to-peer name resolution system which allows a peer to keep track of and to find other peers by a useable organization scheme resulting in a map of the system. However, the structure only offers a way to access peers across a peer-to-peer network, but does not offer developers a way to access a fine level of detail within a peer as required by a truly disaggregated resource. Furthermore, the Microsoft patent does not address the need for a resource consumer to know the coherency of the disaggregated resource as resource nodes lose connectivity. In a peer-to-peer network, if a peer drops out, other peers don't necessary care. However, if the a resource node representing a CPU, memory, or storage device drops out of connectivity, all resource consumers using the disaggregated resource will need to know. Finally, the Microsoft patent does not address more elemental resource nodes.
Adaptec's U.S. Pat. No. 6,922,688 offers a method of accessing data objects where portions of the object are found through obtaining referential maps comprising logical storage locations and physical maps comprising the physical storage locations associated with the logical storage locations. Although the patent teaches how to access data objects distributed across a plurality of physical locations, it does not enable disaggregated resources, how to access such resources, how to operate disaggregated resources as one functional whole resource, or how to maintain a disaggregated resource over an unreliable network. In addition, although one aspect of the present invention comprises a split map, that map is a split map of disaggregated resources not a split map of data objects. Moreover, as discussed below, the term resource, as used herein, excludes data objects.
None of the previously presented examples fully address the problems encountered for building and accessing disaggregated resources. A more complete solution handles unreliable communications, resource consumer and resource node independence, resource coherency, fine level access to the resource, and applies to many types of elemental resources rather than create a solution for a single type of resource. Such a solution would have the following characteristics:
    • A disaggregated resource would comprise independent, efficient resource nodes that do not necessarily communicate with each other and do not require out-of-band communications
    • The resource nodes provide information about their role in the disaggregated resource to resource consumers that request the information
    • Resource consumers discover and access the resources without accessing extraneous systems
    • Resource consumers construct their own view of the disaggregated resource based on information from the resource nodes
    • A map of the resource provides access to a fine level of granularity to the resource at or below the resource device level
Thus, there remains a considerable need apparatus for disaggregated resources and for methods of accessing disaggregated resources.
SUMMARY OF THE INVENTION
The present invention is directed toward disaggregated resources that are spread among a number of resource nodes. The resource nodes provide information about the nodes to resource consumers who then create maps of the resource in order to properly access the resource. The resource node information from a single resource node comprises insufficient information for a useable map of the disaggregated resource. Resource node information from multiple resource nodes allows for the creation of a more complete, useable map from perspective of a resource consumer. Another aspect of the invention provides for resource maps to be split among elements of the disaggregated resource and resource consumers in order to provide fine level access to the resource without the resource consumer storing an entire map of the resource.
Another aspect of the invention is directed toward methods for accessing the disaggregated resource through organizing resource nodes into the disaggregated resource, assigning resource node information, and assessing if the disaggregated resource has coherency. The resource nodes respond to discovery messages by providing their resource node information from which the resource consumers construct a map on how to access the resource. Resource consumers that wish to access the resource include resource consumers, resource managers, or other interested parities.
In a preferred embodiment resource node information includes resource name, resource node name, resource node type, or resource attributes. Resource consumers that interact with disaggregated resources use the resource name to identify a particular resource. Furthermore, each resource node that composes the disaggregated resource includes a resource node name to differentiate themselves in cases where the nodes offer redundant physical resources. Through the use of names, the resource consumers select which resources are of interest and which resource nodes compose the disaggregated resource.
A resource node type provides resource consumers with the necessary information on how to access a specific node within the disaggregated resource. Resource nodes function independently of each and focus only on their prescribed roles and responsibilities. Consequently, resource node attributes provide the resource consumers information on node state with respect to the disaggregated resource if resource state is critical relative to other nodes and provide resource node role information. Contemplated attributes include coherency attributes that indicate when a disaggregated resource has lost coherency. If a disaggregated resource loses coherency, then one or more resource nodes have lost contact with active resource consumers; consequently, the disaggregated resource might not operate correctly or might not offer correct services. Resource node information from an individual resource node comprises incomplete information for resource consumers to interact with the complete disaggregated resource.
In a preferred embodiment a resource consumer collects resource node information from resource nodes to create a map of the disaggregated resource. The resource map can be the same from one resource consumer to another or can be different from one resource consumer to another depending on what the resource consumers requires and how the disaggregated resource is configured. Furthermore, the resulting resource map has sufficient detail to allow a resource consumer to access the disaggregated resource. The resource map provides a translation of a resource element ID to a physical resource address, location, or capability. It is specifically contemplated that the resource map splits into a number of resource sub-maps where each sub-map provides a further translation. For example, a resource consumer accessing a disaggregated resource creates a top level resource sub-map that comprises a translation of a resource element ID to an address of a resource node. Each resource node also comprises a resource sub-map that translates a resource element ID to a physical resource ID. Consequently, it is contemplated that a resource map has a granularity below a resource unit level to a partition that represents some fraction of a physical resource. In addition, it is specially contemplated that a resource map has granularity below a partition level to an individual addressable physical resource element level, or even smaller.
Some embodiments may include a storage medium having instructions that, when executed, results in a resource node and/or a resource consumer operating as described herein with respect to other embodiments.
Contemplated disaggregated resources include, but not limited to, computer related resources including storage, displays, CPU, input devices, or memory. Non-computer related resources are also contemplated including electrical power, or networking bandwidth. Specifically contemplated examples include disaggregated storage or disaggregated video displays. Furthermore, a disaggregated resource could comprise a heterogeneous mix of physical resources. For example, a number of disk drives, displays, CPUs, or memory where each individual item is disaggregated, then forms together into a complete disaggregated computer system.
Glossary
The following descriptions refer to terms used within this document. The terms are provided to ensure clarity when discussing the various aspects of the invention matter without implied limitations.
“Access Fault” means an error condition raised by a resource node when a resource consumer has requested access to a resource beyond the capabilities of the resource node. When the consumer receives the access fault, the consumer reconsiders the request and then forms a more reasonable request, or takes other desired actions.
“Resource” means a fungible commodity required or desired by a resource consumer for the consumer's operation. Resources include displays, I/O channels, data storage, network bandwidth, processor bandwidth, or other items used by a resource consumer even those that pertain to other systems beyond computing, for example electrical power. “Physical Resource” means a physical instantiation of a resource at the device level. Examples of physical resources include video displays, hard disk drives, memory, processing units, media cards, network interfaces, power outlets, or other items used by resource consumers. Resources have granularity; therefore, “resource partition” means a logical representation of a portion of a physical resource. For example, a resource partition of a hard disk drive includes a logical partition on the disk that is addressable external to the disk. Another example of a resource partition includes a range of pixels in an (x,y) coordinate system on a video display representing a logical frame that is addressable external to the display. Further granularity is possible; therefore, “resource element” means a natural, logical unit of the resource that can be addressed. An example of a resource element for a storage system based on a hard disk drive includes a data block on the disk. Yet another example of a resource element includes a pixel of a video display.
On the other hand, the term “resource,” as used herein does not include a file or other data object because data objects are not fungible.
“Resource Consumer” means an entity that utilizes a commodity in order to deliver its desired functionality. Resource consumers have the ability to operate independently of other resource consumers. Further, resource consumers share physical resources though each resource consumer could have a completely different perspective of the resource. Example resource consumers include applications, computers, operating systems, file systems, users, management software, or other entities that have interest in the commodity.
“Resource Map” means a translation from a virtual addressing scheme to a physical addressing scheme of a physical resource. Resource maps comprise software or data that translates a resource element ID into a physical address. Resource maps can split into a number of resource sub-maps where each sub-map comprises a further translation to a final physical address. Resource maps offer varying degrees of granularity of mapping virtual resource elements to physical locations. For example, a network storage system can offer a resource map with a granularity at the disk level, at the partition level, at the data block level, or even below the data block level by employing extra operations. “Split Resource Map” means a resource map split into a plurality of resources sub-maps. The resource sub-maps reside in individual memories where necessary.
“Resource Node” means a logical construct executing on a processor comprising software or firmware that provides a representation of a resource partition. Resource nodes comprise resource node information including and resource maps. Resource nodes have the ability to function independently of other resource nodes. This implies resource nodes do not require out-of-band management to communicate with other resource nodes in order to deliver a coherent disaggregated resource. An example of a resource node is a combination of hardware, software, or firmware that functions as a logical partition of a disk. The logical disk partition accepts read or write requests based on a logical block address (LBA) of a data block, and then performs the requested operation on the disk. Yet another example includes a combination of hardware, software, or firmware that functions as a logical video frame. The logical video frame similarly accepts pixel display commands then instructs a monitor to modify the pixel within the bounds of the logical frame. Resource nodes comprise a resource map to aid in the translation of a resource element ID, including an LBA or logical (x,y) coordinate of a pixel, to a physical address, a disk sector, track, cylinder, or (x,y) coordinate on a monitor.
“Resource Node Attribute” means an attribute within a resource node used by resource consumers external to the resource node to determine if the disaggregated resource suffers from a potential problem or to determine the resource node's role. Resource node attributes include coherency attributes. If a coherency attribute or collection of coherency attributes indicates a disaggregated resource has lost coherency, a resource consumer can then determine the best alternative steps to deal with a potential problem.
The teachings herein may be advantageously employed by developers of disaggregated systems to develop, manage, deploy, or utilize the systems with reduce costs and overhead. Disaggregate resources access methods can be used to manage large arrays of storage devices, arrays of video displays, or other resources that lend themselves to disaggregation.
Various objects, features, aspects, and advantages of the present invention will become more apparent from the following detailed description of the preferred embodiments of the invention, along with the accompanying drawings in which like numerals represent like components.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a schematic of a disaggregated resource.
FIG. 2 is a schematic of a possible physical embodiment for a resource node.
FIG. 3A is a schematic of an example of a parallel group of resource nodes composing a disaggregated resource.
FIG. 3B is a schematic of an example of a serial group of resource nodes composing a disaggregated resource.
FIG. 3C is a schematic of an example of a combination group of serial and parallel groups of resource nodes composing a disaggregated resource.
FIG. 4A is a schematic of an example of group types for a disaggregated storage array.
FIG. 4B is a schematic of an example of group types for a disaggregated video display.
FIG. 5A is a schematic for an example of a physical arrangement of logical disk partitions composing a disaggregated storage array representing a logical volume Z.
FIG. 5B is a schematic for an example of the logical organization of logical disk partitions composing a disaggregate storage array representing the logical volume Z ofFIG. 5A.
FIG. 6 is a schematic for a resource map.
FIG. 7 is a schematic for a split resource map.
FIG. 8 illustrates resource maps with varying degrees of granularity.
FIG. 9 is a schematic for an example method of accessing a disaggregated resource.
DETAILED DESCRIPTION
In order to provide clarity for the detailed description of the inventive subject matter, two example embodiments are provided. Neither implementation should be interpreted as a limitation of the subject matter in any way. The first example embodiment focuses on a disaggregated storage array comprising resource nodes in the form of logical disk partitions and the second embodiment focuses a disaggregate video display comprising resource nodes in the form of logical video display frames.
Disaggregated Resources
FIG. 1 presents a schematic for a disaggregated resource comprising more than one resource nodes.Disaggregated resource100 comprisesresource nodes110A through110E. Although five resource nodes are shown, the number of resource nodes varies as necessary to fulfill the requirements of the disaggregated resource.Resource consumers140A through140N communicate with disaggregatedresource100 throughcommunication path150 by communicating withresource nodes110A through110E.
In a preferred embodiment,resource consumers140A through140N take the form of an electrical device running a driver on a processing unit. The driver allows an application or applications running on the electrical device to interact with the resource provided by disaggregatedresource100 andresource nodes110A through110E in a manner that is transparent to the applications. Consequently, disaggregatedresource100 appears as a local resource from the perspective of the applications. Examples of resource consumers include computers, operating systems, file systems, management software, or other entities that require access to disaggregatedresource100.
Resource consumers140A through140N interact with disaggregatedresource100 independently from each other. Therefore, each resource consumer has its own view of disaggregatedresource100.Resource consumers140A through140N can alter resource node information stored onresource nodes110A through110E. It is contemplated that altering resource node information provides for indicating changes in the disaggregated resource.
Communication path150 provides for a sustained communication betweenresource consumers140A through140N andresource nodes110A through110E. It is specifically contemplated thatcommunication path150 is unreliable and could result in one or more of theresource nodes110A through110E losing connectivity withresource consumers140A through140N. Contemplated communication paths include packet switched networks, computer busses, wireless transmission, or other communication mechanisms.
Resource Nodes
FIG. 2 presents a schematic for a possible embodiment of a resource node.Resource node200 comprises processingunit210 andmemory220.Processing unit210 communicates with other entities, including resource consumers, overcommunication path250. Inaddition processing unit220 communicates withphysical resources260A through260M over physicalresource communication path215.Processing unit210 communicates withmemory220 overbus225.Memory220 further comprisesresource node information230 andresource map240.
Memory220 comprises resource node instructions that run on processingunit210, and data for use by processingunit210 or resource consumers. Data structures includeresource node information230, orresource map240.Resource node information230 includes one or more information elements as indicated byresource information elements233A through233N and conveys information regardingresource node200 to resource consumers overcommunication path250. Contemplated examples of resource node information include resource name, resource node type, resource node name, resource node attribute, address, or other resource node information of interest to a resource consumer. Resource consumers use resource node information to determine the role of a specific resource node within a disaggregated resource, among other things.Resource map240 provides processing unit information on how to translate requests for resource access from resource consumers into an access ofphysical resource260A through260M. It is contemplated thatresource map240 provides information on translating resource consumer requests across one or more physical resources, at a partition level of a physical resource, or at levels smaller than a partition.Resource node200 usesresource map240 to aid in determining the responsibility ofresource node200 with regards tophysical resources260A through260M.
Contemplated embodiments ofresource node200 include modules comprising a combination of hardware, software, or firmware. Modules in the form of adapters plug into physical resource devices to provide resource node capabilities. Furthermore, adapters comprising embedded boards, chips, ASICs, FPGAs, or other components integrate into a larger physical resource device to provide resource node capabilities. In addition, modules include enclosures that house one or more physical resource devices. Such modules include operating systems and communication stacks as firmware infrastructure to support resource node functionality. Because modules can comprise software, it is also contemplated software programs or drivers install on computers or other computer-like systems to provide resource node capabilities for the individual resources within the computer. Contemplated software or firmware executing onprocessing unit210 that providesresource node200 with its functionality including monolithic code that supports multiple resource nodes, collections of functions operating together, or individual tasks or threads.
Resource node200 operates as a virtual structure that presents a logical representation of a portion ofphysical resource260A through260M to resource consumers. Contemplated logical representations include logical partitions of disk drives or logical video frames of a monitor. The logical representations combine to form the complete disaggregated resource, which itself is a logical representation of a resource.
Ifresource node200 exists in a module that supports multiple other resource nodes, it is contemplated all resource nodes have unique addresses. In a preferred embodiment, each resource node acquires an address from external to the enclosure, from a DHCP server for example. In especially preferred embodiment, multiple resource nodes share a common physical address, an Ethernet MAC address, when obtaining an address by using unique virtual physical addresses when communicating with the address server. For example, an enclosure can obtain multiple IP addresses from a DHCP server by using virtual physical addresses for each resource node in the “chaddr” field, the client address field, of the DHCP client request even though the module has a single real MAC address. This approach alleviates issues where a DHCP server does not correctly implement the DHCP client ID properly.
Disaggregated Resource Node Groups
A resource node comprises the ability to function independently of all other resource nodes and offers resource consumers access to the physical resource for which the resource node is responsible without regard to all other resource nodes composing the disaggregated resource. Consequently, resource nodes combine together forming different structures based on how a group as a whole is intended to function. In a preferred embodiment, there are four types of group structures, a group of one operating as a complete resource, a parallel group structure where resource nodes provide redundant resources, a serial group structure where resource nodes provide no redundancy, or a combination of parallel and serial groups. A single resource node that operates as a group of one providing a single complete resource is a trivial case and does not represent a disaggregated resource.
FIG. 3A illustrates an example of a parallel group of four resource nodes.Disaggregated resource300 comprisesresource nodes305A through305D and represents a single resource from the perspective ofresource consumer310.Resource consumer310 interacts with disaggregatedresource300 throughcommunication path315.Resource nodes305A through305D offer the same fundamental resource, resource “A,” toresource consumer310. Therefore, if one ofresource nodes305A through305D disappears from view ofresource consumer310,resource consumer310 still is able to fully utilize disaggregatedresource300 even though disaggregatedresource300 has lost a resource node because the remaining nodes offer redundancy. An example of a parallel group includes a data storage array employing a number of mirrored disks. If a disk fails, the other mirrored disks provide data due to redundancy. An additional example of a parallel group includes a video display comprising multiple monitors displaying the same video data. Should one monitor fail, the remaining monitors continue to provide the video data. In a preferred embodiment, a parallel group comprises two or more logical disk partitions that mirror data from another group of one or more logical disk partitions. AlthoughFIG. 3A presents an example of four resource nodes, it is contemplated that a parallel group can comprise one or more resource nodes. It is further contemplated that a parallel group can comprise one or more other groups. Other contemplated parallel groups include archives or backups where data is stored for long term storage.
FIG. 3B illustrates an example of a serial group comprising four resource nodes.Disaggregated resource320 comprisesresource nodes325A through325D.Disaggregated resource320 appears as a single resource toresource consumer310.Resource consumer310 communicates with disaggregatedresource320 overcommunication path315.Resource node325A through325D each offer a single piece of a resource, “A” through “D” respectively, whereresource consumer310 requires resource “ABCD” to operate properly.Resource node325A through325D offers no redundancy; therefore, if one of the nodes disappears from view ofresource consumer310,disaggregate resource320 would no longer be usable. Examples of serial groups for storage arrays include two or more disks comprising RAID-0 stripes or two or more disks where the disks are spanned together to offer larger capacity. If one disk fails, the storage array is rendered useless until the array is fixed. Other contemplated serial groups including a parity group, or an individual group where a parity group represents a group that comprises parity information and where an individual represents a group of a single resource node. An alternative example of a serial group includes a composite video display comprising two or more monitors that are combined into a single larger display. If one monitor fails, then the complete display is not useful because some video information is missing.
FIG. 3C illustrates an example of a combination group comprising a parallel group of two redundant serial groups.Disaggregated resource350 comprisesserial group330 andserial group340, each offering the same resource “ABCD” toresource consumer310.Resource consumer310 communicates with disaggregatedresource350 overcommunication path315.Resource nodes335A through335D provide access to resource “A” through “D” respectively as doresource nodes345A through345D. An example of a combination group includes a RAID10 storage array where data is striped across multiple disks and those disks are mirrored. In a preferred embodiment, combination groups comprise two or more logical disk partitions. Furthermore, in a preferred embodiment combination groups comprise one or more other groups.
One or more resource nodes combine to form a group. One or more groups form an additional group. Finally, a disaggregated resource is a single top level group comprising one or more other groups. Groups become complex as resource nodes combine to offer various capabilities and services and because each resource node operates independently other nodes. Resource consumers require information to understand how resource nodes combine to form a disaggregated resource in order to properly interact with the disaggregated resource and to determine if the disaggregated resource has coherency.
In a preferred embodiment groups are classified by types where a type specifically references a role played by a collection of resource nodes. Furthermore, it is contemplated that resource consumers access a group collectively in addition to accessing individual resource nodes within the group. In the preferred embodiment, resource consumers access the group collectively through multicast messages.
Resource Node Information
Resource consumers obtain a view of a disaggregate resource based on information about resource nodes. Resource nodes are unaware of their role in a larger disaggregated resource because they focus on their main responsibility of providing access to a physical resource. Consequently each individual resource node lacks information about the complete disaggregated resource. Resource consumers obtain resource node information from each of the individual resource nodes and combine the information to form a description of the disaggregated resource in order to properly interact with it. In a preferred embodiment, resource node information resides within in a memory associated with the resource node; however, it is contemplated the resource node information can reside in alternative memories.
If a disaggregated resource comprises only a serial group, then a resource consumer only needs sufficient information to determine if the serial group has coherency. In other words, the resource consumer only needs to know if members of the group are missing. If the serial group does not have coherency (members of the serial group are missing), the disaggregated resource is not useable. Therefore, a resource consumer does not need complete information, i.e. information about which members are missing, but rather sufficient information indicating that members are missing. Furthermore, if a disaggregated resource comprises parallel groups, the resource consumer only requires sufficient information to determine if, through the redundancy of the parallel groups, the disaggregated resource is usable. Again, the resource consumer only needs sufficient information rather the complete information regarding the disaggregated resource.
Resource node information comprises elements that include the group type of a group of which a resource node is a member, resource node attributes, resource name, resource node name, resource node address, or other information desired by resource consumers to determine the coherency of a disaggregated resource. Resource consumers also use resource node information to determine the role of each resource node. If a resource consumer knows the role of a resource node, then the resource consumers is able to partially assist the resource node by performing operation in anticipation of passing resource requests to a resource node. For example, if a resource node represents a RAID-0 stripe, a resource consumer could perform necessary modulo arithmetic based on an LBA to determine if the stripe should receive a specific data block.
Group Types
Resource nodes combine together to form groups of different types. Each type of group represents a desired functionality, capability, or service. A group type provides resource consumers partial information regarding the role a group plays in the disaggregated resource.
FIG. 4A presents a set of possible group types for resource nodes composing a disaggregated storage array. The resource nodes are logical disk partitions in this example. Assume the storage array comprises a data set of sequential data blocks “ABCDEFGHI” that could represent a single file. The resource map of each logical disk partition determines for which data blocks the logical partition is responsible.Logical disk partitions410A and410B are mirrors because they both are responsible for identical data and provide redundancy; therefore, each logical disk partition has a “mirror” group type. One should note that each logical disk partition is a group of one node in the example shown. Mirror groups are a form of parallel group and have resource that is redundant to another group.Logical disk partitions420A through420C represent a stripe group where individual data blocks are written acrosslogical disk partitions420A through420C sequentially, then wrap around.Logical disk partitions430A through430B represent a span group where data fills one logical disk partition then flows over to the next logical disk partition. Both a stripe group and a span group are serial groups. In a preferred embodiment, contemplated group types include mirrors, stripes, or spans. In especially preferred embodiments, contemplated mirror sub-types include snap-shots, backups, or deferred mirrors; contemplated stripe sub-types include parity. Snap-shots are a type of mirror group that captures a dataset at a specific point in time. Backups are a type of mirror group that archives a data set. Deferred mirrors are a type of mirror that has an I/O latency with respect to a primary group. Parity is a type of stripe comprising parity information. Parity groups are useful when implementing RAID-3, 4, 5, 6, or other storage arrays that require parity.
FIG. 4B presents another example of a set of possible group types for resource nodes composing a disaggregated video display. The resource nodes are logical video frames in this example. Logical video frames440A and440B represent mirror groups where the same data is displayed on the two logical frames. Logical video frames450A through450F compose a composite display and are therefore a composite group. One should note thelogical video frames440A through440F do not have to be located on the same monitor or have to be located physically close to each other.
The purpose of the previous examples is to illustrate that group types are created based on the type of disaggregated resource. In addition, there are common group types regardless of the type of disaggregated resource, mirrors for example. Composite types are essentially a combination of span and stripe.
Groups can become quite complex depending on how the different group types combine to form a disaggregated resource. In a preferred embodiment groups are organized according to rules for manageability providing resource consumers structure so they can determine how groups should fit together and what role each group takes on. In a preferred embodiment, group types are hierarchically organized. For example in storage arrays it is contemplated that mirror groups are the top most group because each mirror represents one data set. The next level comprises stripe groups that provide performance enhancement, and then at the lowest level are span groups that provide capacity enhancement. It is contemplated that group type information is encoded in a memory. In a preferred embodiment, the group type information combines with a resource node name. In an especially preferred embodiment, group types also represent results of operations performed on other groups. For example in a disaggregated storage array, if a stripe group of logical disk partitions has a “mirror operation” performed on it, the result is a mirror group comprising two stripe groups, the original stripe group and a new stripe group.
Resource Node Names
Resource node names provide one or more pieces of information to remote consumers including identification or group membership information, logical position information within a disaggregated resource, partial role information, or other information that a resource consumer might need to access a disaggregated resource.
Identification and membership information allows a resource node to uniquely identify itself with respect to other resource nodes whether they are in the same disaggregated resource or from other disaggregated resources. Resource consumers can resolve the resource node name to an address which allows the resource consumer to communicate directly with a specific resource node. Resource node names and addresses ensure each resource node is distinguishable from other resource nodes. In a preferred embodiment, a resource node comprises the name of the disaggregated resource. In an especially preferred embodiment, a resource node name comprises a unique identifier including a UUID or a GUID. In addition, a resource node name of a preferred embodiment resolves to an internetworking address including a unicast address or a multicast address.
In a preferred embodiment, a resource node name comprises position information that informs a resource consumer where in a disaggregated resource a resource node fits. In an especially preferred embodiment the position information comprise a group type. Therefore, a resource node name carries partial resource node role information.
FIG. 5A provides an example of a physical structure of a possible disaggregated storage array comprising a number of resource nodes where the resource nodes are logical disk partitions. The example is provided to clarify how resource consumers can utilize resource node names. A resource consumer operates on data set comprising data blocks “ABCDEFGHI” stored ondisks501 through505. The storage array comprises three complete, redundant data sets for reliability. Each disk comprises one or more partitions controlled by a resource node that represents each partition as an addressable, logical disk partition.Resource node510 is a mirror partition comprising the complete data and is; therefore, a mirror group of one resource node.Mirror group520 also comprises the complete data stored on threestriped resource nodes522,524, and526.Mirror group530 also comprises the complete data set stored on twostriped resource nodes532 and534 andspan group535 that functions as a third stripe.Span group535 comprisesresource nodes537 and539. From the perspective of a resource consumer, this collection of resource nodes appears as a single logical volume that stores data set “ABCDEFGHI.” The resource consumer attempts to make sense of the structure through each resource node's name.FIG. 5B presents a logical representation of the same disaggregated resource ofFIG. 5A assuming groups are organized hierarchically as follows from top to bottom: mirrors, stripes, and spans.Logical volume500 comprises the groups to form a single disaggregate resource.
Given the example hierarchical structure illustrated inFIG. 5B, Table 1 lists a possible name associated with the eight nodes composinglogical volume500. Table 1 assumeslogical volume500 has name “Z” and that mirror groups are designated by the letter “M” and a number. In addition, stripe groups are designated by the letter “R” and a number. “R” is used in the example to reflect stripes are aRAID 0 group. Span groups are designated by the letter “S.”
TABLE 1
Resource Node Names for Example
Storage StructureLogical Volume 500 in
FIG. 5B
Resource NodeExample Name
Root Node 510Z
Resource Node
522Z.M1
Resource Node
524Z.M1.R1
Resource Node
526Z.M1.R2
Resource Node
532Z.M2
Resource Node
534Z.M2.R1
Resource Node
537Z.M2.R2
Resource Node
539Z.M2.R2.S1
Resource node names form two different classes: those that provide resource node role information and those that do not. Resource node role information helps resource consumers determine how to properly interact with individual resource nodes. For example in the case of amirror group520,resource nodes522,524, and526 are striped nodes. A resource consumer can infer through the names ofresource nodes522,524, and526 are each stripes. Therefore, based on knowledge of how stripes operate (stripe depth, LBA ranges, module arithmetic, or other information), a resource consumer can determine which resource node is responsible for individual LBAs in a logical volume. Consequently, the resource consumer performs LBA calculations locally to determine which resource node is responsible for an LBA, then directly interacts with an individual resource node. In a preferred embodiment, the interaction is through a unicast message directed from the resource consumer to the address of a resource node. If resource nodes handle LBA calculations, then resource node names only have to carry organization information and do not have to carry resource node role information. In this case, a resource consumer directly interacts with the entire group collectively and lets each member of a group determine if any action is required on their part. For example, a resource consumer interacting withmirror group520 sends a single message comprising an LBA to resourcenodes522,524, and526 collectively. In a preferred embodiment, the interaction is through a multicast message directed from the resource consumer to the multicast address of the group. Given this case, developers can use any naming or tagging system that results in a discernable structure for a disaggregated resource and is understandable by a resource consumer.
Through structured naming, resource consumers determine the overall structure of a disaggregated resource and identify gaps in the structure. For example, ifresource node524 does not respond to a discovery request by a resource consumer, the resource consumer understands there is a gap betweenresource node522 with name “Z.M1” andresource node526 with name “Z.M1.R2.” Therefore, the resource consumer has sufficient information to determine that mirror group520 (as serial group of striped resource nodes) is incomplete and can not be used. However, given a structured naming scheme, a resource consumer can not know the last member in a group because it is always possible that the last resource node might not have responded. For example, ifresource node526 ofmirror group520 does not respond to a discovery request, the resource consumer would believe thatresource node524 is the last member ofmirror group520 and would not know that group is incomplete. It is contemplated that resource node names carry complete information regarding group memberships so that resource consumers can make a full determination of disaggregated resource coherency; however, such naming is inefficient because names can become long, disorganized, or unmanageable. It is also contemplated that resource node names have additional characteristics including being discoverable via discovery request message, or comprise information regarding resource node responsibilities.
Resource node names form two different classes: those that provide resource node role information and those that do not. Resource node role information helps resource consumers determine how to properly interact with individual resource nodes. For example in the case of amirror group520,resource nodes522,524, and526 are striped nodes. A resource consumer can infer through the names ofresource nodes522,524, and526 are each stripes. Therefore, based on knowledge of how stripes operate (stripe depth, LBA ranges, module arithmetic, or other information), a resource consumer can determine which resource node is responsible for individual LBAs in a logical volume. Consequently, the resource consumer performs LBA calculations locally to determine which resource node is responsible for an LBA, then directly interacts with an individual resource node. In a preferred embodiment, the interaction is through a unicast message directed from the resource consumer to the address of a resource node. If resource nodes handle LBA calculations, then resource node names only have to carry organization information and do not have to carry resource node role information. In this case, a resource consumer directly interacts with the entire group collectively and lets each member of a group determine if any action is required on their part. For example, a resource consumer interacting withmirror group520 sends a single message comprising an LBA to resourcenodes522,524, and526 collectively. It a preferred embodiment, the interaction is through a multicast message directed from the resource consumer to the multicast address of the group. Given this case, developers can use any naming or tagging system that results in a discernable structure for a disaggregated resource and is understandable by a resource consumer.
Resource Node Attributes
Resource node attributes contribute to determining the role of a resource node, to determining the coherency of the disaggregated resource, or to helping a resource consumer to properly interact with a disaggregated resource.
Resource consumers use resource node attributes to determine if a serial group of resource nodes is complete or has coherency. It is contemplated that resource nodes have coherency attributes where each attribute is associated with a group type. For example, in a storage array representing a disaggregated resource with mirror groups, stripe groups, and span groups, coherency attributes could include a mirror attribute, a stripe attribute, and span attribute. In a preferred embodiment, each coherency attribute indicates that there are additional members, and therefore, nodes, associated with a particular group. Table 2 illustrates how coherency attributes contribute to a resource consumer's understanding of a disaggregated resource structure and the roles each node plays in the disaggregated resource based onlogical volume500 example presented inFIG. 5B. In Table 2, the “M” attribute indicates that there is an additional mirror group; the “R” attribute indicates that there is an additional stripe member, and the “S” indicates there is an additional span member. Even though the attributes are set on the individual nodes, the attributes are associated with the groups because groups can comprise other groups that further comprise multiple resource nodes, forexample mirror group530 comprisingspan group535 which functions as a stripe.
TABLE 2
Resource Node Names and Attributes for
Example Storage StructureLogical Volume 500
in FIG. 5B
ExampleAttributes
Resource NodeNameMRS
Root Node 510ZYNN
Resource Node
522Z.M1YYN
Resource Node
524Z.M1.R1YYN
Resource Node
526Z.M1.R2YNN
Resource Node
532Z.M2NYN
Resource Node
534Z.M2.R1NYN
Resource Node
537Z.M2.R2NNY
Resource Node
539Z.M2.R2.S1NNN
A resource consumer interacting withlogical volume500 with attributes has sufficient information to determine if the serial groups comprisinglogical volume500 have coherency and are complete. For example, the resource consumer can determine the completeness ofmirror group520, a serial group comprisingstriped resource nodes522,524, and526, by checking the attributes even if a resource node is not visible. Ifresource node526 is not visible to the resource consumer, then the resource consumer can determine that there are additional expected groups based on the “R” attribute being set onresource node524. Furthermore, if all members ofmirror group520 are visible to the resource consumer, then the resource consumer can determine that there are no additional members because the “R” attribute is not set onresource node526 indicating there are no additional stripes and, therefore, can determine that the group is complete.
The attributes also contribute information that allows a resource consumer to infer what role a resource node plays in the disaggregated resource. For example,resource node522 has the name “Z.M1” which partially indicates its role, that it is a mirror. However, the name does not contain information regarding its role as a stripe. The resource consumer can infer thatresource node522 is stripe by detecting that the “R” attribute is set indicating that an additional stripe is expected implyingresource node522 is also a stripe.
Maintaining coherency of parallel groups requires more complex attributes because if one member of the parallel group is not visible, other resource nodes that are redundant can supply the resource in place of the lost group member. Coherency is important when multiple resource consumers access a shared disaggregated resource where the physical resource has state from the perspective of the resource consumers. Due to a number of reasons including unreliable networks, a resource consumer could lose track of a resource node in a parallel structure; consequently, that node could become out of synch with other resource nodes even though the complete disaggregated resource still provides functionality from the perspective of the resource consumer due to redundancy. For example,logical volume500 is a parallel group comprising three mirror groups,root node510, mirror group520 (a serial group of striped resource nodes), and mirror group530 (a serial group of striped and spanned resource nodes) all comprising identical data sets. If a first resource consumer can seeonly mirror groups520 and530, but not510, then it could properly interact with the two visible groups. However, if a second resource consumer can seeonly mirror group510, but not530 and520, then the second resource consumer can properly interact withgroup510. Unfortunately, data onlogical volume500 is at risk if both resource consumers write to the volume because the volume no longer has coherency resulting in the groups losing synchronization. Coherency attributes can include a count of the number of groups or resource nodes comprising a parallel group. In the case oflogical volume500, there are three parallel groups supplying redundant data: therefore the member count is three. Furthermore, a resource consumer, upon detection that a group or node is missing, can change a valid count on the visible resource nodes to indicate how many groups are valid. For example, in the case of the first resource consumer seeing onlymirror group520 and530 would set a valid count to two (as opposed to three). Any other resource consumer would see a discrepancy between the valid count (2) and member count (3) and know the disaggregated resource has lost coherency.
In a preferred embodiment, resource nodes have both a resource valid attribute indicating how many members of a group are valid and a resource member attribute indicating the number of expected members in the disaggregated resource. In a more preferred embodiment, resource nodes comprise a key to ensure that only one resource consumer is able to modify resource attributes at a time, or to indicate when group member resource node attributes are modified. Contemplated keys include random numbers, sequential counts, UUID, or GUIDs. Additionally, in a preferred embodiment resource consumers periodically check the coherency of a disaggregated resource to ensure it is able to services resource requests.
In a preferred embodiment, through an advantageous selection of rules for creating an organizational structure of resource nodes, only one attribute is required for each group type rather than an attribute for each created group.
Additional resource node attributes are also contemplated. Specifically, attributes that indicate whether resource nodes are owned or share provide utility when multiple resource consumers interact with a disaggregated resource simultaneously.
Other Resource Node Information
Beyond group types, resource node names, and resource attributes, additional resource node information is contemplated including resource node capabilities, physical resource information, detailed resource node resource map information, or other information that enhances the operation of a disaggregated resource with respect to a resource consumer. Examples of resource node capabilities within storage array include block size, stripe size, logical partition capacity, or LBA responsibility information. Examples of resource node capabilities within a disaggregated video display include logical video frame size, pixel color depth, decoding information, or aspect ratio. All information regarding a resource node is contemplated.
Resource Maps
Resource maps provide a translation from a resource element ID, an LBA or logical pixel coordinate for example, to a physical address, a hard disk storage block or a pixel on a video monitor for example. Within this context “physical address” means an address that is directed toward a physical resource; therefore a physical address includes intermediary addresses that are further directed toward the physical resource. Resource maps, especially those located within a resource node determine a resource node's responsibility.
Resource maps are either static or dynamic. Static resource maps are stored in a memory and contain sufficient information for translation. Dynamic resource maps are also stored in a memory and are built based on resource node information. Resource consumers build a dynamic map, if necessary, and determine if the map is complete through the resource node information.
FIG. 6 depicts an example of a resource map. Resource consumers access a disaggregated resource through the use ofresource map600 by referencing elements of the disaggregated resource viaresource element IDs610A through610N.Resource map600 includes a translation fromresource element IDs610A through610N tophysical addresses620A through620N. A resource map comprises a combination of software or data structures to achieve the goal of translation. It is contemplated that a resource map could comprise a table; however, the map would be an inefficient use of memory due to the number of resource elements IDs that have to be handled. In a storage array a typical number of IDs comprise 248LBAs. In a video display, the number of pixels could easily be in the millions. In a preferred embodiment,resource map600 comprises a software function that translatesresource element IDs610A through610N tophysical addresses620A through620N. Consequently, resource maps provide a translation from a virtual coordinate system used to represent the disaggregated resource to a physical coordinate system across physical resources. A resource consumer collects resource node information from resource nodes that compose a disaggregated resource. The resource consumer then constructs a dynamic resource map in memory based on resource node names, resource node attributes, resource node addresses, or group types. If the resource consumer has an understanding of the roles of each resource node, then the resource consumer can have an understanding of howresource element ID610A through610N are distributed across all the resource nodes. In the example of a disaggregated storage array where data is striped across a number of resource nodes, a resource map takes the form of software function employing modulo arithmetic to determine which resource node is responsible for an LBA. The physical address in this case would be the address of the node responsible for the LBA. In a preferred embodiment, a resource element ID translates to one or more physical address in order to support parallel groups including mirrors.
The complete map of a disaggregated resource splits into a number of smaller maps; each of them also a resource map. Resource consumers need sufficient information to create a map that allows it to interact with the disaggregated resource. Resource nodes have a fine grained mapping of a physical resource which is often a static map.
FIG. 7 depicts an example of a split resource map of disaggregated storage array.Split resource map700 comprisesresource sub-map725 stored infirst memory720 andresource sub-map735 stored insecond memory730.Resource sub-map725 translatesLBAs726A through726N to resource node addresses728A through728N.Resource sub-map735 represents an example static resource map of a resource node addressed inresource sub-map725. Resource sub-map further translates LBAs736A through736M tophysical addresses738A through738M representing a physical location on a disk drive.Resource sub-map725 andresource sub-map735 do not have to have the same number of elements because a resource node's resource map generally represents a fraction of the complete disaggregated resource. A resource consumer interacting with the example storage array usesresource sub-map725 to find an address of a resource node. Resource consumer sends requests to a specific resource node, if required. The specific resource node could then use a resource map similar toexample resource sub-map735 to interact with a disk. In a preferred embodiment, resource maps and resource sub-maps employ software functions for translation. In an especially preferred embodiment, the software functions are used to yield resource node responsibilities including striping, parity, spanning, mirroring, or composite responsibilities.
Each resource map in a disaggregated resource comprises a level of granularity. Resource consumers often utilize coarse grain resource maps with a granularity at the resource node level. The resource node level corresponds to a granularity at physical partition level that is at or below a physical resource level. For example, in a storage array, a resource node represents a logical disk partition that corresponds to a disk partition that is smaller than a disk drive. In addition, in a video monitor, a resource node represents a logical video frame that corresponds to a frame that is smaller than the video monitor.
FIG. 8 depicts several resource maps with various levels of granularity.Physical resource840 comprisesphysical resource partition843 and847. A resource node is responsible for providing access tophysical resource840, and more particularly toresource partition843.Resource map810 has a granularity at the resource partition level because it translates resource element IDS to physical addresses that correspond to a physical resource partition level. In a preferred embodiment, the physical address of a physical resource partition corresponds to an address of a resource node.Physical resource partition843 further comprisesphysical resource elements844A through844N.Resource map820 has a granularity at the resource element level that is below the physical resource partition level because it can address individualphysical resource elements844A through844N. Contemplated resource elements include addressable blocks on a disk drive. Resource nodes typically employ resource maps that have granularity at the physical resource element level. It is contemplated that a resource map can have a granularity below the physical resource element level.Physical resource elements844A through844N comprise smaller pieces as depicted byatom845. For example, disk drives have addressable blocks where each block comprises a number of bytes and each byte comprises a number of bits.Resource map830 has a granularity at the atomic level. It is contemplated that resource nodes that employ resource maps having an atomic level granularity or below use multiple operations to access the physical resource. In the case of a storage array, a resource node would use a read-modify-write operation to change a byte within a block.
Accessing Disaggregated Resources
FIG. 9 depicts a possible set of steps by which entities can interact with disaggregated resources.
Atstep905, a manager creates a disaggregated resource. The manager responds to a need for the disaggregated resource and creates two or more resources nodes that have responsibility for physical resources in order to attempt to fulfill the need. For example, an IT manager establishes that an enterprise requires several terabytes of disk storage comprising mirrored data. Then, through utilities, the manager creates a number of logical disk partitions (resource nodes) representing partitions on a set of disk drives where the collection of logical disk partitions substantially fulfills the capacity and mirroring requirements. In a preferred embodiment, the manager uses a one or more software utilities designed to communicate with resource consumers, resource nodes, or modules that connect to physical resources. Given this, it is contemplated that a manager includes an administrator, a software package used to manage disaggregated resources, management servers, or management appliances. It is further contemplated that a manger includes a resource consumer, or a computer system external to the resource consumer and disaggregated resource.
Atstep910, the manager establishes an organizational structure for the resource nodes. The organization structure provides definitions for the roles and responsibilities of each resource node. Once the roles and responsibilities are established, a manager creates a corresponding set of resource node information and resource maps for deployment into the resource nodes. Resource consumers use knowledge of the rules for forming the organizational structure in order to convert resource node information in a useable map of the disaggregated resource or determine if the disaggregated resource has coherency. In a preferred embodiment, the organizational structure comprises a hierarchy based on group types. In an especially preferred embodiment, the hierarchy groups include mirrors, stripes, composites, or spans. Other contemplated hierarchical structures include trees, or directed graphs. Non-hierarchical structures are also contemplated including flat sequential lists with no preferred ordering of resource nodes.
Atstep915, a manager assigns resource node information and resource maps to each of the resource nodes composing the newly created disaggregated resource. Each resource node receives the resource node information and the resource map information then stores the information in a memory. The resource node information provides resource consumers information regarding what role the resource node takes on in the disaggregated resource. The resource map determines the responsibility of the resource node. In a preferred embodiment, resource node information includes group types, resource name, resource node name, or resource node attributes. Once the resource nodes composing the disaggregated resource have their resource node information and resource maps initialized, resource consumers can begin accessing the disaggregated resource aware of the disaggregated resource,
Atstep920, a resource consumer wishes to access the disaggregated resource. If the resource consumer is not aware of the disaggregated resource, the resource consumer sends a discovery message to the disaggregated resource. Possible discovery methods include reading resource node from a local information store, sending broadcast message to resource nodes, using standardized protocols including SSDP, requesting resource node information from a server external to the disaggregated resource, or other methods that result in delivering resource node information to the resource consumer. In a preferred embodiment, discovery includes identifying the physical modules that comprise resource nodes and sending name resolution requests with possible regular expression information to all resource nodes. If a resource node receives the request and its name matches the regular expression, it will respond. Contemplated discovery requests include those sent via unicast to individual resource nodes, via multicast sent to groups of resource nodes, or via broadcasts sent to one or more groups of resource nodes.
Atstep925, each resource node receives discovery messages sent by resource consumers. Upon reception and verification of authorization, if any authorization is required, of the discovery message, each individual resource node retrieves its own resource node information from its memory. The resource node information is formed in a response message which is sent back to the resource consumer atstep930. The resource consumer attempts to collect responses from all responding resource nodes. It is contemplated that not all resource nodes will respond. In a preferred embodiment, resource consumers have the ability to cycle through multiple discovery attempts to capture as much resource node information as possible given an unreliable network.
Atstep935, the resource consumer collects resource node information from responding nodes and constructs a resource map of the disaggregated resource. The resource consumer has an understanding of the rules of the organizational structure used to create the resource node information. Based on the rules and on the resource node information the resource consumer can determine if the constructed resource map is sufficiently complete or if the disaggregated resource has coherency. If the resource map is sufficiently complete, then the disaggregated resource is usable by the resource consumer. A sufficiently complete resource map is still considered complete as long as some members of a parallel group are visible. For example, if a storage array comprises a number of mirrored groups, each being a member of a parallel group, then one mirror could disappear from view, but the storage array would still be useful. If coherency is lost, the disaggregated resource might not be useable as is the case when coherency is lost in a serial group. Atstep940, the resource consumer assesses the constructed resource map and atstep942 it decides if the disaggregated resource has coherency. If the disaggregated resource has coherency, then the resource consumer can begin using the disaggregated resource atstep950. If the disaggregated resource does not have coherency, then the resource consumer determines if the resource map has sufficient group members to still be useable. In a preferred embodiment, the resource consumer checks resource node names, group type, or resource node attributes to check for coherency. Additionally, a preferred embodiment sorts the list of responding resource nodes, or removes duplicates, if any.
Atstep944, the resource consumer decides if the remaining group members are able to provide sufficient capabilities to service requests from the resource consumer. This is possible in the case where there are sufficient parallel groups, or redundant resources. If there are sufficient capabilities remaining, the resource consumer will modify the resource node attributes atstep945 to indicate a change in coherency to be detected by other resource consumers. In a preferred embodiment, a resource consumer modifies coherency attributes including a resource node valid attribute. If the disaggregated resource is not usable, the resource consumer optionally reports an error or optionally attempts the discovery process again atstep920 to pick up lost members. It is contemplated that a resource consumer could probe for specific lost members based on detecting gaps within the map structure and on sending regular expression discovery messages tailored to check for names the could appear in the gaps. After modifying resource node attributes atstep945, the resource consumer can begin using the disaggregated resource atstep950.
Atstep950, a resource consumer interacts with the disaggregated resource by sending messages to the disaggregated resource. In a preferred embodiment, sending messages comprises sending packets over a packet switched network to all the resource nodes, to groups of resource nodes, or to individual resource nodes that compose the disaggregated resource. In an especially preferred embodiment, communications between the resource consumer and disaggregated resource take the form of UDP packets that are broadcast, multicast, or unicast.
In a preferred embodiment a resource consumer employs optimization techniques when communicating with resource nodes over an unreliable communication path. Contemplated optimizations techniques including employing a slow start or congestion avoidance similar to TCP to ensure the communication path is solid. One factor that contributes to a communication path being unreliable is the physical nature of the infrastructure. For example, hubs, switches, or routers form a packet switched network that could represent an unreliable communication path. Not all networking equipment is the same nor does the equipment faithfully implement protocols or standards. Consequently, in an especially preferred embodiment where resource consumers use UDP to communicate with resource slow start or congestion avoidance ensures networking equipment is not overwhelmed due to speed of communications.
Atstep955, all resource nodes that are capable of receiving messages from a resource consumer, accept the messages. Because resource consumers can broadcast a single message to a group of resource nodes, one or more resource nodes within a group can receive the message. Each individual resource node determines if the message requires their individual attention based on their role or responsibility as set forth by their resource node information or resource maps. For example, a message from a resource consumer can include a resource element ID which the resource node compares against its resource map. If a resource node determines that is should not take any action, the message is silently discarded. If the resource node determines it should take action on the message, it proceeds to analyze the message.
At step956 a resource node determines if the resource consumer message is a request for a resource for which the resource node is responsible. If the message is a non-resource specific message, then message is handled appropriately atstep985 and a response is generated and sent if necessary, and resource consumers processes the response atstep990. Non-resource request messages include configuration messages, management messages, firmware updates, or other messages that are of interest to the resource node beyond a request for the resource. If the message is a resource request, the message is further analyzed.
Atstep960 in a preferred embodiment a resource node bypasses a communication stack to deliver the message directly to the main functionality of the resource node in order to improve over-all performance of the resource node. It is contemplated that a resource node comprises a TCP/IP protocol stack that supports UDP packets. When a packet is accepted by the resource node at an Ethernet level, the resource node checks the packet and delivers the packet data directly the resource node application rather than requiring full processing of the TCP/IP stack eliminating superfluous computation. By bypassing the communication stack, costs are reduced because inexpensive processing units deliver more desirable performance than a more expensive, powerful unit that uses the full TCP/IP stack.
Atstep962 the resource node checks the data in the resource request message to ensure that the resource node is able to handle the request or to determine if the request is an access fault. In a preferred embodiment resource request messages include one or more referenced (directly or indirectly) resource element IDS. The resource node checks its responsibilities to determine if it is able to handle the referenced resource element IDS. If some of the resource element IDS fall outside the scope of the resource node's responsibilities, then an access fault has occurred. The resource node reports the access fault back to the resource consumer and the resource consumer processes the response atstep990. In a preferred embodiment, au access fault shows a resource consumer that it is attempting to bridge resource nodes. For example, if two resource nodes form a span group in a storage array, when a resource consumer attempts write data for multiple LBAs, a bulk write, within a single message and the LBAs bridge from the first resource node to the second, the first resource node will generate an access fault. The resource consumer can then break the message up into individual requests each having a single LBA resulting in an aligned write to the resource nodes. If the message is not an access fault, the resource node continues its handling of the resource request.
Atstep965 the resource node fully processes the resource request. The full processing depends on the type of resource for which the resource node is responsible. Contemplated processing includes, I/O processes, checking status, resource management, resource node information management, resource map management, or other processing as determined by the resource node's responsibilities or a protocol designed for use with the resource node.
In a preferred embodiment, it is contemplated that one type of processing that a resource node conducts is the processing of a proxy command atstep966. A proxy command instructs a resource node to communicate with another resource node as if the first resource node were a resource consumer. The first resource node then relays the message to the second resource node which is waiting atstep955.
Atstep975 if the resource request is not a proxy command, the resource node continues processing the resource request and generates a response sent back to the resource consumer. The resource consumer receives the response atstep990.
It is contemplated that resource consumers and resource nodes communicate over an unreliable communication path that could result in loss of coherency of the disaggregated resource. Furthermore, multiple independent resource consumers access disaggregated resources simultaneously, each resource consumer having its own view of the disaggregated resource which could be out of synch with the other resource consumers. Therefore, in a preferred embodiment a resource consumer will periodically check for disaggregated resource coherency. Atstep992 the resource consumer checks to see if coherency requires checking. If so, the resource consumer returns to step920 and initiates a discovery. The periodicity of checking for coherency or conditions when coherency should be checked varies depending on the resource consumer and disaggregated resource environment. In a preferred embodiment, periodicities are greater than or equal to one second.
EXAMPLE DISAGGREGATED RESOURCES
The following examples illustrate how disaggregated resources can be employed to provide accessible resources for computer systems. Although a limited number of examples are presented, there are no implied restrictions or no implied limitations.
Example—Disaggregated Storage Array
An example of a disaggregated resource includes a data storage array comprising a plurality of hard disk drives. The storage array is virtualized by two or more resource nodes represented by logical disk partitions. Each logical disk partition has responsibility for a partition on a disk and comprises an IP address used to communicate with resource consumers. A logical disk partition also comprises a resource map that translates LBAs to physical disk locations used during I/O operations. The collection of logical disk partitions appears as a locally connect, logical volume to computer systems that represent resource consumers.
When the storage array is built, the logical disk partitions are created and given names that reflect their position and role in the group hierarchy of the logical volume. The group hierarchy includes groupings based on mirrors, stripes, or spans. The storage array represents itself as a single logical volume with a name. Each logical disk partition incorporates the logical volume name and group type information within the name of the logical disk partition. Furthermore, each logical disk partition also includes attributes indicating if there are more logical disk partitions in each type of group.
A resource consumer in the form of a software driver installs on a workstation beneath an operating system or file system. The low level placement of the driver allows existing software and applications to utilize the storage array without requiring modification. As software accesses the logical volume, the driver encapsulates I/O requests into a packets sent to the logical volume. In a preferred embodiment, the requests are sent to the logical volume collectively through a multicast message where the logical partitions composing the logical volume are all members of the multicast group. It is contemplated that the driver communicates with the logical volume through unicast messages as well.
The driver sends a discovery request to the logical volume and the logical disk partitions respond with their individual information including their names or attributes. Once the driver collects the resource node information, it builds the initial coarse grained map of the logical volume where the map comprises the roles each logical partition plays and the addresses of the logical partitions. Once the map is assembled and determined to be complete, the driver begins communicating directly with logical volume. If the map is incomplete as determined based on the names and attributes, the driver attempts to find missing elements or possibly generates errors. If the logical volume comprises mirrors, the driver is able to determine that a group of partitions could have lost coherency with the rest of the data set by detecting changes in the coherency attributes including the resource node valid attribute.
The driver sends read and write requests to the logical volume or to individual logical partitions. As the logical disk partitions receive the requests, each logical disk partition checks the LBAs of the requests and compare the LBAs to the logical disk partition's map of the disk partition to determine if action is required. If no action is required, the logical disk partition silently discards the packet; otherwise, the packet is processed.
In a preferred embodiment, logical disk partitions employ several optimizations. Packets from the driver can bypass the logical disk partition's communication stack to improve performance. In addition, packets are checked for access faults and the faults are reported back to the driver. The driver interprets the access fault as instructions to break requests up so individual logical disk partitions process the requests naturally without requiring logical disk partitions to communicate with each. Other interpretations of access faults are also contemplated in order to properly handle or report error conditions.
It is specifically contemplated that the data storage array uses modules attached to disk where the modules provide the logical disk partition functionality. Modules include rack mount enclosures that house 12 or 16 disks, desktop enclosures housing one to eight disks, single adapters that plug onto disks, or embedded modules integrated with other products.
Example—Disaggregated Video Display
Yet another example of a disaggregated resource includes a video display comprising a plurality of monitors. The video display is virtualized by two or more resource nodes represented by logical video frames where each logical video frame has an address and an extent of pixels, mostly likely in an (x,y) coordinate system. A logical video frame comprises a map that translates a virtual pixel address into a physical pixel address on one of the monitors. The collection of logical video frames appears as a locally connected video display from the perspective of an electrical device. Contemplated electrical devices include computers, TVs, video games, ATM machines, or other devices requiring a display.
The groups employed by the video display including composites groups where multiple logical video frames combine to form an aggregate display or mirror groups where the same video information is displayed more than once. It is contemplated a mirror includes a video recorder. The logical video frames also have names associated with their group types and the name of the video display. Coherency checks for the video display are useful to determine if a monitor has failed.
Just as in the storage example, a resource consumer for the video display can take the form of a driver. Furthermore, it is contemplated that a module comprising hardware, software, or firmware plugs into a video out of an electrical device and communicates with the video display transparently to the electrical device. For video streams, it is contemplated that image decoding can occur within the resource consumer, a third system, or within the logical video frame. Image decoding is required to determine which pixels of the image display should be mapped to which logical video frame and to provide for proper scaling for pixels.
Alternative Embodiments
In addition to the preceding examples alternative embodiments are also contemplated. Alternative embodiments include other computing related resources including processors where the processor bandwidth is treated as a resource, memory where memory is segmented into partitions similar to a storage array, networking interfaces where QoS or bandwidth is treated as a resource, power supplies, audio I/O, input devices, or others. Alternative embodiments also include non-computing resources including products supplied through a distribution system where a number of warehouses represent resource nodes.
It is also contemplated that more than one disaggregated resource can combine to form a larger heterogeneous resource. For example, several disaggregated resources including a storage array, video display, or processing array combine to form a disaggregated computer.
Hardware
In yet another aspect, it is contemplated that one could create hardware designed to adapt devices to allow the devices to function as an independent resource node, or in a more preferred embodiment, to function as multiple independent resource nodes where each resource node is responsible for a logical partition of the device. Therefore, the inventive subject matter includes hardware or firmware of such adapters as well as licensing, selling, advertising, managing, distributing, or operating the adapters.
Software
In still another aspect, it is contemplated that one could write software that would configure, simulate, or manage disaggregated resources and their associated infrastructure. From that perspective the inventive subject matter includes methods of writing such software, recording the software on a machine readable form, licensing, selling, distributing, installing, or operating such software on suitable hardware. Moreover, the software per se is deemed to fall within the scope of the inventive subject matter.
Advantages
Disaggregated resources provide a number of advantages. Individual resource nodes composing the disaggregated resource function independently of all other resource nodes which increases responsiveness or performance from the perspective of a resource consumer without requiring out-of-band communication. Each resource node provides partial information regarding the over map of the disaggregated resource allowing each resource consumer that requires access to the disaggregated resource to build its own effective map. This allows two resource consumers to share the same physical resources, or even the same logical resource, but access the disaggregated resources differently as required by their individual needs. For example, a first resource consumer could access one mirror group preferentially over another mirror group to reduce conflicts with the second resource consumer. Resource consumers are able to discover and access the disaggregated resource without working through an extraneous system that would incur cost overhead to a consumer. Finally disaggregated resources place resource map information with required granularity where it is necessary to ensure efficient access. Furthermore, the disaggregated resource can comprise resource maps with very fine levels of granularity offering a high degree of control over physical resources.
Thus, specific compositions and methods of disaggregated resources have been disclosed. It should be apparent, however, to those skilled in the art that many more modifications besides those already described are possible without departing from the inventive concepts herein. The inventive subject matter, therefore, is not to be restricted except in the spirit of the disclosure. Moreover, in interpreting the disclosure all terms should be interpreted in the broadest possible manner consistent with the context. In particular the terms “comprises” and “comprising” should be interpreted as referring to the elements, components, or steps in a non-exclusive manner, indicating that the referenced elements, components, or steps can be present, or utilized, or combined with other elements, components, or steps that are not expressly referenced.

Claims (29)

What is claimed is:
1. A method comprising:
transmitting a discovery request to each of a plurality of resource nodes that each have a unique Internet protocol address and, collectively, present a logical representation of a plurality of physical resources;
receiving, from one or more resource nodes of the plurality of resource nodes, node information that includes a name for each of the one or more resource nodes; and
determining, from the names of each of the one or more resource nodes, an organizational structure of the plurality of resource nodes, the organizational structure being a parallel structure that will provide a resource consumer with access to a first data block of a data set stored on the plurality of physical resources through at least two resource nodes, or a serial structure that will provide the resource consumer with access to the first data block through a first resource node and access to a second data block, which is consecutive with the first data block, of the data set through a second resource node.
2. The method ofclaim 1, wherein the one or more resource nodes is less than the plurality of resource nodes.
3. The method ofclaim 1, further comprising:
determining a coherency of a disaggregated resource that includes the plurality of resource nodes based at least in part on the node information received from the one or more resource nodes.
4. The method ofclaim 3, wherein the node information includes a name for each of the one or more resource nodes, and said determining a coherency of the disaggregated resource is based at least in part on the names of each of the one or more resource nodes.
5. The method ofclaim 4, wherein the node information further includes a coherency attribute and said determining the coherency of the disaggregated resource is further based at least in part on the coherency attribute.
6. The method ofclaim 5, wherein the organizational structure of the plurality of resource nodes includes a sequence of the plurality of resource nodes and the coherency attribute of a resource node of the one or more resource nodes is indicative of an additional resource node of the plurality of resource nodes that is later in the sequence.
7. The method ofclaim 1, further comprising:
generating a resource map to correspond one or more logical resource element identifiers to each of the plurality of resource nodes.
8. A method, comprising:
receiving, at a resource consumer device, node names corresponding to each of a plurality of resource nodes;
determining, using the resource consumer device, an organizational structure of the plurality of resource nodes based on the received node names, the organizational structure being a parallel structure that enables access to a data set through at least two of the plurality of resource nodes or a serial structure that enables access to a first data block of the data set through a first resource node and to a second data block consecutive to the first data block of the data set through a second resource node; and
generating, using the resource consumer device, a resource map based at least in part on the organizational structure; and
messaging, by the resource consumer device, one or more resource nodes of the plurality of resource nodes about the data set based at least in part on the resource map.
9. The method of claim 8, wherein the resource consumer device comprises a resource manager device.
10. The method of claim 8, further comprising:
determining, using the resource consumer device, a coherency of a disaggregated resource that includes a portion of the plurality of resource nodes based at least in part on the received node names corresponding to each of the plurality of resource nodes.
11. The method of claim 10, further comprising:
receiving, at the resource consumer device, a coherency attribute associated with the plurality of resource nodes; and
wherein said determining, using the resource consumer device, the coherency of the disaggregated resource based at least in part on the received node names is further based at least in part on the coherency attribute.
12. The method of claim 11,
wherein the organizational structure of the plurality of resource nodes includes a sequence of the plurality of resource nodes; and
wherein the coherency attribute associated with the plurality of resource nodes is indicative of an additional resource node that is later in the sequence.
13. The method of claim 8, wherein the resource map correlates one or more logical resource element identifiers to each of the plurality of resource nodes.
14. The method of claim 13, wherein each of the logical resource element identifiers corresponds to a physical resource.
15. The method of claim 8, wherein the received node names are configured to indicate a group type associated with the plurality of resource nodes.
16. A non-transitory computer-readable medium having instructions stored thereon that, when executed by a resource consumer device, cause the resource consumer device to:
discover a plurality of resource nodes each being associated with a corresponding unique protocol address;
receive node names corresponding to each of the plurality of resource nodes;
determine an organizational structure of the plurality of resource nodes based at least in part on the received node names, the organizational structure being a parallel structure that enables access to a data set through at least two of the plurality of resource nodes or a serial structure that enables access to a first data block of the data set through a first resource node and to a second data block consecutive to the first data block of the data set through a second resource node;
generate a resource map that maps a correspondence between a plurality of logical resource element identifiers and the plurality of resource nodes based at least in part on the organizational structure; and
message one or more resource nodes of the plurality of resource nodes about the data set based at least in part on the resource map.
17. The non-transitory computer-readable medium of claim 16, wherein the resource consumer device comprises a resource manager device.
18. The non-transitory computer-readable medium of claim 16, wherein execution of the instructions cause the resource consumer device further to:
determine a coherency of a disaggregated resource that includes a portion of the plurality of resource nodes based at least in part on the received node names corresponding to each of the plurality of resource nodes.
19. The non-transitory computer-readable medium of claim 18, wherein execution of the instructions cause the resource consumer device further to:
receive a coherency attribute associated with the plurality of resource nodes; and
wherein said determine the coherency of the disaggregated resource based at least in part on the received node names is further based at least in part on the coherency attribute.
20. The non-transitory computer-readable medium of claim 19,
wherein the organizational structure of the plurality of resource nodes includes a sequence of the plurality of resource nodes; and
wherein the coherency attribute associated with the plurality of resource nodes is indicative of an additional resource node that is later in the sequence.
21. The non-transitory computer-readable medium of claim 16, wherein each of the logical resource element identifiers corresponds to a physical resource.
22. The non-transitory computer-readable medium of claim 16, wherein the received node names are configured to indicate a group type associated with the plurality of resource nodes.
23. A system, comprising:
a memory device to store instructions; and
one or more resource consumer devices to execute the instructions stored in the memory device to:
receive node names corresponding to each of a plurality of resource nodes, each of the plurality of resource nodes being associated with a corresponding unique protocol address;
determine an organizational structure of the plurality of resource nodes based at least in part on the received node names, the organizational structure being a parallel structure that enables access to a data set through at least two of the plurality of resource nodes or a serial structure that enables access to a first data block of the data set through a first resource node and to a second data block consecutive to the first data block of the data set through a second resource node; and
generate a resource map that maps a correspondence between a plurality of logical resource element identifiers and the plurality of resource nodes based at least in part on the organizational structure; and
message one or more resource nodes of the plurality of resource nodes about the data set based at least in part on the resource map.
24. The system of claim 23, wherein the resource consumer device comprises a resource manager device.
25. The system of claim 23, wherein the one or more resource consumer devices is configured to execute the instructions stored in the memory device further to:
determine a coherency of a disaggregated resource associated with the plurality of resource nodes based at least in part on the received node names corresponding to each of the plurality of resource nodes.
26. The system of claim 25, wherein the one or more resource consumer devices is configured to execute the instructions stored in the memory device further to:
receive a coherency attribute associated with the plurality of resource nodes; and
wherein said determine the coherency of the disaggregated resource based at least in part on the received node names is further based at least in part on the coherency attribute.
27. The system of claim 26,
wherein the organizational structure of the plurality of resource nodes includes a sequence of the plurality of resource nodes; and
wherein the coherency attribute associated with the plurality of resource nodes is indicative of an additional resource node that is later in the sequence.
28. The system of claim 23, wherein each of the plurality of logical resource element identifiers corresponds to a physical resource.
29. The system of claim 23, wherein the node names are configured to indicate a group type associated with the plurality of resource nodes.
US16/422,8732005-08-162019-05-24Disaggregated resources and access methodsActive2030-03-20USRE48894E1 (en)

Priority Applications (1)

Application NumberPriority DateFiling DateTitle
US16/422,873USRE48894E1 (en)2005-08-162019-05-24Disaggregated resources and access methods

Applications Claiming Priority (3)

Application NumberPriority DateFiling DateTitle
US11/205,895US8819092B2 (en)2005-08-162005-08-16Disaggregated resources and access methods
US15/247,779USRE47411E1 (en)2005-08-162016-08-25Disaggregated resources and access methods
US16/422,873USRE48894E1 (en)2005-08-162019-05-24Disaggregated resources and access methods

Related Parent Applications (1)

Application NumberTitlePriority DateFiling Date
US11/205,895ReissueUS8819092B2 (en)2005-08-162005-08-16Disaggregated resources and access methods

Publications (1)

Publication NumberPublication Date
USRE48894E1true USRE48894E1 (en)2022-01-11

Family

ID=35709035

Family Applications (3)

Application NumberTitlePriority DateFiling Date
US11/205,895CeasedUS8819092B2 (en)2005-08-162005-08-16Disaggregated resources and access methods
US15/247,779Active2030-03-20USRE47411E1 (en)2005-08-162016-08-25Disaggregated resources and access methods
US16/422,873Active2030-03-20USRE48894E1 (en)2005-08-162019-05-24Disaggregated resources and access methods

Family Applications Before (2)

Application NumberTitlePriority DateFiling Date
US11/205,895CeasedUS8819092B2 (en)2005-08-162005-08-16Disaggregated resources and access methods
US15/247,779Active2030-03-20USRE47411E1 (en)2005-08-162016-08-25Disaggregated resources and access methods

Country Status (2)

CountryLink
US (3)US8819092B2 (en)
WO (1)WO2007021289A1 (en)

Families Citing this family (41)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US8005918B2 (en)2002-11-122011-08-23Rateze Remote Mgmt. L.L.C.Data storage devices having IP capable partitions
US7620981B2 (en)2005-05-262009-11-17Charles William FrankVirtual devices and virtual bus tunnels, modules and methods
US8819092B2 (en)2005-08-162014-08-26Rateze Remote Mgmt. L.L.C.Disaggregated resources and access methods
US8266634B2 (en)*2007-10-122012-09-11Microsoft CorporationResource assignment system with recovery notification
US8707318B2 (en)2007-10-122014-04-22Microsoft CorporationPartitioning system including a generic partitioning manager for partitioning resources
US7636758B1 (en)2008-07-102009-12-22Gene FeinAdvertisement forwarding storage and retrieval network
KR101760333B1 (en)*2011-03-022017-07-21삼성전자주식회사Communication method of target terminal and access point for group id management in mu-mimo transmission
US9069467B2 (en)*2011-06-012015-06-30Microsoft Technology Licensing, LlcIsolation of virtual machine I/O in multi-disk hosts
US10142411B2 (en)2015-05-292018-11-27Microsoft Technology Licensing, LlcDynamic swarm segmentation
US9529538B1 (en)2015-06-182016-12-27International Business Machines CorporationVirtual accounting container for supporting small volumes of data
US9977613B2 (en)*2015-12-302018-05-22Dell Products L.P.Systems and methods for zone page allocation for shingled media recording disks
US10235198B2 (en)*2016-02-242019-03-19Samsung Electronics Co., Ltd.VM-aware FTL design for SR-IOV NVME SSD
US9961139B2 (en)2016-05-242018-05-01International Business Machines CorporationCooperative download among low-end devices under resource constrained environment
US10423487B2 (en)2016-08-192019-09-24Samsung Electronics Co., Ltd.Data protection offloads using SSD peering
WO2018065804A1 (en)*2016-10-052018-04-12Kaleao LimitedHyperscale architecture
US10534598B2 (en)*2017-01-042020-01-14International Business Machines CorporationRolling upgrades in disaggregated systems
US11153164B2 (en)2017-01-042021-10-19International Business Machines CorporationLive, in-line hardware component upgrades in disaggregated systems
US10768844B2 (en)2018-05-152020-09-08International Business Machines CorporationInternal striping inside a single device
US11182322B2 (en)2018-09-252021-11-23International Business Machines CorporationEfficient component communication through resource rewiring in disaggregated datacenters
US10802988B2 (en)*2018-09-252020-10-13International Business Machines CorporationDynamic memory-based communication in disaggregated datacenters
US11163713B2 (en)2018-09-252021-11-02International Business Machines CorporationEfficient component communication through protocol switching in disaggregated datacenters
US11650849B2 (en)2018-09-252023-05-16International Business Machines CorporationEfficient component communication through accelerator switching in disaggregated datacenters
US10637733B2 (en)2018-09-252020-04-28International Business Machines CorporationDynamic grouping and repurposing of general purpose links in disaggregated datacenters
US10831698B2 (en)2018-09-252020-11-10International Business Machines CorporationMaximizing high link bandwidth utilization through efficient component communication in disaggregated datacenters
US10915493B2 (en)2018-09-252021-02-09International Business Machines CorporationComponent building blocks and optimized compositions thereof in disaggregated datacenters
US11012423B2 (en)2018-09-252021-05-18International Business Machines CorporationMaximizing resource utilization through efficient component communication in disaggregated datacenters
US10671557B2 (en)2018-09-252020-06-02International Business Machines CorporationDynamic component communication using general purpose links between respectively pooled together of like typed devices in disaggregated datacenters
US10754720B2 (en)2018-09-262020-08-25International Business Machines CorporationHealth check diagnostics of resources by instantiating workloads in disaggregated data centers
US10761915B2 (en)2018-09-262020-09-01International Business Machines CorporationPreemptive deep diagnostics and health checking of resources in disaggregated data centers
US11050637B2 (en)2018-09-262021-06-29International Business Machines CorporationResource lifecycle optimization in disaggregated data centers
US10838803B2 (en)2018-09-262020-11-17International Business Machines CorporationResource provisioning and replacement according to a resource failure analysis in disaggregated data centers
US11188408B2 (en)2018-09-262021-11-30International Business Machines CorporationPreemptive resource replacement according to failure pattern analysis in disaggregated data centers
US10831580B2 (en)2018-09-262020-11-10International Business Machines CorporationDiagnostic health checking and replacement of resources in disaggregated data centers
US11188429B2 (en)2018-11-292021-11-30International Business Machines CorporationBuilding a highly-resilient system with failure independence in a disaggregated compute environment
EP3964949B1 (en)*2019-05-272023-09-06Huawei Technologies Co., Ltd.Graphics processing method and apparatus
US11733902B2 (en)2021-04-302023-08-22International Business Machines CorporationIntegrating and increasing performance of disaggregated memory in operating systems
US12155666B2 (en)2021-05-282024-11-26Capital One Services, LlcEvaluation of effective access permissions in identity and access management (IAM) systems
US11902282B2 (en)2021-05-282024-02-13Capital One Services, LlcValidating compliance of roles with access permissions
US11562082B2 (en)*2021-05-282023-01-24Capital One Services, LlcCrafting effective policies for identity and access management roles
FR3129797B1 (en)*2021-11-262024-04-19Sagemcom Broadband Sas METHOD FOR CONFIGURING A COMMUNICATION NETWORK AND NODE IMPLEMENTING SAID CONFIGURATION METHOD
US12007888B2 (en)*2022-08-192024-06-11Micron Technology, Inc.Techniques to group media blocks

Citations (279)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US4422171A (en)1980-12-291983-12-20Allied Corporation, Law DepartmentMethod and system for data communication
JPS6133054A (en)1984-07-251986-02-15Nec CorpTransmission and reception system of packet signal
JPS62233951A (en)1986-04-021987-10-14Nec CorpMultiplex packet transmission system
JPS6390942A (en)1986-10-061988-04-21Nec CorpInterexchange data link control system
US4890227A (en)1983-07-201989-12-26Hitachi, Ltd.Autonomous resource management system with recorded evaluations of system performance with scheduler control including knowledge learning function
EP0485110A2 (en)1990-11-091992-05-13Emc CorporationLogical partitioning of a redundant array storage system
US5129088A (en)1987-11-301992-07-07International Business Machines CorporationData processing method to create virtual disks from non-contiguous groups of logically contiguous addressable blocks of direct access storage device
US5193171A (en)1989-12-111993-03-09Hitachi, Ltd.Method of managing space of peripheral storages and apparatus for the same
JPH05347623A (en)1992-04-071993-12-27Nec CorpMulti-cast communication system
TW223167B (en)1990-02-061994-05-01Canon Kk
EP0654736A2 (en)1993-11-191995-05-24Hitachi, Ltd.Dynamically expandable storage unit array system
GB2285558A (en)1993-12-281995-07-12Nec CorpIC card radio modem operable on a plurality of types of infrastructure network
US5444709A (en)1993-09-301995-08-22Apple Computer, Inc.Protocol for transporting real time data
JPH07325779A (en)1994-06-011995-12-12Fuji Xerox Co LtdInput/output controller
EP0700231A2 (en)1994-08-291996-03-06AT&T Corp.Methods and systems for interprocess communication and inter-network data transfer
US5506969A (en)1993-11-291996-04-09Sun Microsystems, Inc.Method and apparatus for bus bandwidth management
EP0706113A2 (en)1994-10-051996-04-10Hewlett-Packard CompanyMethods for adding storage disks to a hierarchic disk array while maintaining data availability
US5546541A (en)1991-02-051996-08-13International Business Machines CorporationSystem for routing transaction commands to an external resource manager when the target resource is not managed by the local transaction managing computer program
JPH08251198A (en)1995-03-151996-09-27Matsushita Electric Ind Co Ltd Multiplex transmission device
US5590276A (en)1992-01-081996-12-31Emc CorporationMethod for synchronizing reserved areas in a redundant storage array
US5590124A (en)*1993-05-071996-12-31Apple Computer, Inc.Link and discovery protocol for a ring interconnect architecture
US5617449A (en)1994-06-271997-04-01Nec CorporationIC memory card type radio modem
US5634111A (en)1992-03-161997-05-27Hitachi, Ltd.Computer system including a device with a plurality of identifiers
JPH09149060A (en)1995-11-271997-06-06Mitsubishi Electric Corp Broadcast communication method in multi-branch connection network
US5742604A (en)1996-03-281998-04-21Cisco Systems, Inc.Interswitch link mechanism for connecting high-performance network switches
US5758050A (en)1996-03-121998-05-26International Business Machines CorporationReconfigurable data storage system
US5758188A (en)1995-11-211998-05-26Quantum CorporationSynchronous DMA burst transfer protocol having the peripheral device toggle the strobe signal such that data is latched using both edges of the strobe signal
US5771354A (en)1993-11-041998-06-23Crawford; Christopher M.Internet online backup system provides remote storage for customers using IDs and passwords which were interactively established when signing up for backup services
US5850449A (en)1995-10-261998-12-15Sun Microsystems, Inc.Secure network protocol system and method
JPH10333839A (en)1997-05-291998-12-18Hitachi Ltd Fiber Channel connection storage controller
US5867686A (en)1993-11-091999-02-02Conner; Kenneth H.High speed real-time information storage system
US5884038A (en)1997-05-021999-03-16Whowhere? Inc.Method for providing an Internet protocol address with a domain name server
US5889935A (en)1996-05-281999-03-30Emc CorporationDisaster control features for remote data mirroring
US5930786A (en)1995-10-201999-07-27Ncr CorporationMethod and apparatus for providing shared data to a requesting client
US5937169A (en)1997-10-291999-08-103Com CorporationOffload of TCP segmentation to a smart adapter
US5948062A (en)1995-10-271999-09-07Emc CorporationNetwork file server using a cached disk array storing a network file directory including file locking information and data mover computers each having file system software for shared read-write file access
US5949977A (en)1996-10-081999-09-07Aubeta Technology, LlcMethod and apparatus for requesting and processing services from a plurality of nodes connected via common communication links
US5983024A (en)1997-11-261999-11-09Honeywell, Inc.Method and apparatus for robust data broadcast on a peripheral component interconnect bus
US5991891A (en)*1996-12-231999-11-23Lsi Logic CorporationMethod and apparatus for providing loop coherency
US6018779A (en)1997-12-152000-01-25Emc CorporationSystem for encapsulating a plurality of selected commands within a single command and transmitting the single command to a remote device over a communication link therewith
US6081879A (en)*1997-11-042000-06-27Adaptec, Inc.Data processing system and virtual partitioning method for creating logical multi-level units of online storage
US6101559A (en)1997-10-222000-08-08Compaq Computer CorporationSystem for identifying the physical location of one or more peripheral devices by selecting icons on a display representing the one or more peripheral devices
US6105122A (en)1998-02-062000-08-15Ncr CorporationI/O protocol for highly configurable multi-node processing system
JP2000267979A (en)1999-03-122000-09-29Nec CorpStorage system
US6128664A (en)1997-10-202000-10-03Fujitsu LimitedAddress-translating connection device
US6157955A (en)1998-06-152000-12-05Intel CorporationPacket processing system including a policy engine having a classification unit
US6157935A (en)1996-12-172000-12-05Tran; Bao Q.Remote data access and management system
WO2001001270A1 (en)1999-06-302001-01-04Webtv Networks, Inc.Interactive television triggers having connected content/disconnected content attribute
US6181927B1 (en)1997-02-182001-01-30Nortel Networks CorporationSponsored call and cell service
US6202060B1 (en)1996-10-292001-03-13Bao Q. TranData management system
JP2001094987A (en)1999-09-222001-04-06Matsushita Electric Ind Co Ltd Image data transmission method
US6246683B1 (en)1998-05-012001-06-123Com CorporationReceive processing with network protocol bypass
US6253273B1 (en)1998-02-062001-06-26Emc CorporationLock mechanism
US6259448B1 (en)1998-06-032001-07-10International Business Machines CorporationResource model configuration and deployment in a distributed computer network
US6275898B1 (en)1999-05-132001-08-14Lsi Logic CorporationMethods and structure for RAID level migration within a logical unit
US20010020273A1 (en)1999-12-032001-09-06Yasushi MurakawaMethod of virtual private network communication in security gateway apparatus and security gateway apparatus using the same
US6288716B1 (en)1997-06-252001-09-11Samsung Electronics, Co., LtdBrowser based command and control home network
US6295584B1 (en)*1997-08-292001-09-25International Business Machines CorporationMultiprocessor computer system with memory map translation
US20010026550A1 (en)2000-03-292001-10-04Fujitsu LimitedCommunication device
US20010034758A1 (en)2000-02-242001-10-25Dan KikinisVirtual private network (VPN) for servicing home gateway system through external disk management
US20010037371A1 (en)1997-04-282001-11-01Ohran Michael R.Mirroring network data to establish virtual storage area network
US20010049739A1 (en)2000-06-022001-12-06Koji WakayamaApparatus and method for interworking between MPLS network and non-MPLS network
US6330236B1 (en)1998-06-112001-12-11Synchrodyne Networks, Inc.Packet switching method with time-based routing
US6330615B1 (en)1998-09-142001-12-11International Business Machines CorporationMethod of using address resolution protocol for constructing data frame formats for multiple partitions host network interface communications
US6330616B1 (en)1998-09-142001-12-11International Business Machines CorporationSystem for communications of multiple partitions employing host-network interface, and address resolution protocol for constructing data frame format according to client format
JP2001359200A (en)2000-06-122001-12-26Yamaha CorpWireless audio equipment
US20020016811A1 (en)1999-04-072002-02-07International Business Machines CorporationComputer system and method for sharing a job with other computers on a computer network using IP multicast
WO2002015018A1 (en)2000-08-112002-02-213Ware, Inc.Architecture for providing block-level storage access over a computer network
US20020026558A1 (en)2000-06-022002-02-28Reuter James M.Architecture for parallel distributed table driven I/O mapping
US20020029256A1 (en)1999-06-112002-03-07Zintel William M.XML-based template language for devices and services
US20020031086A1 (en)2000-03-222002-03-14Welin Andrew M.Systems, processes and integrated circuits for improved packet scheduling of media over packet
US20020035621A1 (en)1999-06-112002-03-21Zintel William MichaelXML-based language description for controlled devices
US20020039196A1 (en)2000-02-252002-04-04Luca ChiarabiniSystem and method for downloading and for printing data from an external content source
US6377990B1 (en)1998-06-152002-04-23Lodgenet Entertainment CorporationSystem for providing internet access from locations different from those for which the user's software was configured
US20020052962A1 (en)1998-11-162002-05-02Ludmila CherkasovaHybrid and predictive admission control strategies for a server
US6385638B1 (en)1997-09-042002-05-07Equator Technologies, Inc.Processor resource distributor and method
US6389448B1 (en)1999-12-062002-05-14Warp Solutions, Inc.System and method for load balancing
US20020062387A1 (en)2000-10-302002-05-23Michael YatzivInterface emulation for storage devices
US6396480B1 (en)1995-07-172002-05-28Gateway, Inc.Context sensitive remote control groups
US20020065875A1 (en)2000-11-302002-05-30Shawn BracewellSystem and method for managing states and user context over stateless protocols
US6401183B1 (en)1999-04-012002-06-04Flash Vos, Inc.System and method for operating system independent storage management
US20020087811A1 (en)*2000-12-282002-07-04Manoj KhareMethod and apparatus for reducing memory latency in a cache coherent multi-node architecture
US20020091830A1 (en)2001-01-102002-07-11Koji MuramatsuDistributed-processing system and command transfer method in the same
CN1359214A (en)2000-12-132002-07-17Lg电子株式会社 Household appliance remote control device and control method thereof
US6434683B1 (en)2000-11-072002-08-13Storage Technology CorporationMethod and system for transferring delta difference data to a storage device
US6434147B1 (en)1999-01-082002-08-13Nortel Netwoks LimitedMethod and system for sequential ordering of missing sequence numbers in SREJ frames in a telecommunication system
JP2002252880A (en)2001-02-262002-09-06Sanyo Electric Co LtdLiquid crystal projector
US6449607B1 (en)1998-09-112002-09-10Hitachi, Ltd.Disk storage with modifiable data management function
US20020126658A1 (en)2001-03-062002-09-12Nec CorporationMain unit address restricted notification system
WO2002071775A1 (en)2001-03-012002-09-12Mitsubishi Denki Kabushiki KaishaMobile ip packet communication system
US20020133539A1 (en)2001-03-142002-09-19Imation Corp.Dynamic logical storage volumes
US20020138628A1 (en)2001-01-252002-09-26Crescent Networks, Inc.Extension of address resolution protocol (ARP) for internet protocol (IP) virtual networks
US6466571B1 (en)1999-01-192002-10-153Com CorporationRadius-based mobile internet protocol (IP) address-to-mobile identification number mapping for wireless communication
US6470342B1 (en)1999-03-122002-10-22Compaq Computer CorporationProcess of maintaining a distributed map of transaction identifiers and using hashing to access these maps
US6473774B1 (en)1998-09-282002-10-29Compaq Computer CorporationMethod and apparatus for record addressing in partitioned files
JP2002318725A (en)2001-04-202002-10-31Hitachi Ltd Disk array system
US20020165978A1 (en)2001-05-072002-11-07Terence ChuiMulti-service optical infiniband router
US6480934B1 (en)1998-09-282002-11-12Hitachi, Ltd.Storage control unit and method for handling data storage system using thereof
US6487555B1 (en)1999-05-072002-11-26Alta Vista CompanyMethod and apparatus for finding mirrored hosts by analyzing connectivity and IP addresses
US20030018784A1 (en)*2001-01-252003-01-23Lette John T.System and method for processing requests from newly registered remote application consumers
US20030023811A1 (en)2001-07-272003-01-30Chang-Soo KimMethod for managing logical volume in order to support dynamic online resizing and software raid
US20030026246A1 (en)2001-06-062003-02-06Zarlink Semiconductor V.N. Inc.Cached IP routing tree for longest prefix search
US20030041138A1 (en)2000-05-022003-02-27Sun Microsystems, Inc.Cluster membership monitor
US6535925B1 (en)1999-11-092003-03-18Telefonaktiebolaget L M Ericsson (Publ)Packet header compression using division remainders
US20030065733A1 (en)2001-09-282003-04-03Pecone Victor KeyModular architecture for a network storage controller
US20030070144A1 (en)*2001-09-042003-04-10Christoph SchnelleMapping of data from XML to SQL
US20030069995A1 (en)2001-10-052003-04-10Fayette Brad K.Method and system for communicating among heterogeneous systems
US6549983B1 (en)1998-05-202003-04-15Samsung Electronics Co., Ltd.Cache memory system and method for managing the same
US6553028B1 (en)1999-04-302003-04-22Cisco Technology, Inc.Method and apparatus for multicast switching using a centralized switching engine
US20030079018A1 (en)2001-09-282003-04-24Lolayekar Santosh C.Load balancing in a storage network
US20030081592A1 (en)2001-06-012003-05-01Ainkaran KrishnarajahMethod and apparatus for transporting different classes of data bits in a payload over a radio interface
US20030093567A1 (en)2001-09-282003-05-15Lolayekar Santosh C.Serverless storage services
US6567863B1 (en)1998-12-072003-05-20Schneider Electric Industries SaProgrammable controller coupler
US20030101239A1 (en)2001-11-272003-05-29Takeshi IshizakiStorage device with VLAN support
US20030118053A1 (en)2001-12-262003-06-26Andiamo Systems, Inc.Methods and apparatus for encapsulating a frame for transmission in a storage area network
US6587464B1 (en)1999-01-082003-07-01Nortel Networks LimitedMethod and system for partial reporting of missing information frames in a telecommunication system
US20030130986A1 (en)*1998-06-302003-07-10Tamer Philip E.System for determining the mapping of logical objects in a data storage system
US6597680B1 (en)1998-11-162003-07-22Telefonaktiebolaget Lm Ericsson (Publ)Packet traffic channel reassignment
US6601135B1 (en)2000-11-162003-07-29International Business Machines CorporationNo-integrity logical volume management method and system
US6601101B1 (en)2000-03-152003-07-293Com CorporationTransparent access to network attached devices
US20030152041A1 (en)2002-01-102003-08-14Falk HerrmannProtocol for reliable, self-organizing, low-power wireless network for security and building automation systems
US20030161312A1 (en)2002-02-272003-08-28International Business Machines CorporationApparatus and method of maintaining two-byte IP identification fields in IP headers
US6618743B1 (en)1998-10-092003-09-09Oneworld Internetworking, Inc.Method and system for providing discrete user cells in a UNIX-based environment
US20030172157A1 (en)2001-06-282003-09-11Wright Michael H.System and method for managing replication sets of data distributed over one or more computer systems
US20030172149A1 (en)2002-01-232003-09-11Andiamo Systems, A Delaware CorporationMethods and apparatus for implementing virtualization of storage within a storage area network
US20030182349A1 (en)2002-03-212003-09-25James LeongMethod and apparatus for decomposing I/O tasks in a raid system
US6629178B1 (en)2000-06-152003-09-30Advanced Micro Devices, Inc.System and method for controlling bus access for bus agents having varying priorities
US6629264B1 (en)2000-03-302003-09-30Hewlett-Packard Development Company, L.P.Controller-based remote copy system with logical unit grouping
US6629162B1 (en)2000-06-082003-09-30International Business Machines CorporationSystem, method, and product in a logically partitioned system for prohibiting I/O adapters from accessing memory assigned to other partitions during DMA
US6636958B2 (en)2001-07-172003-10-21International Business Machines CorporationAppliance server with a drive partitioning scheme that accommodates application growth in size
US20030204611A1 (en)2002-04-292003-10-30Mccosh John C.Communications tester and method of using same
US20030202510A1 (en)2002-04-262003-10-30Maxxan Systems, Inc.System and method for scalable switch fabric for computer network
US6678241B1 (en)1999-11-302004-01-13Cisc Technology, Inc.Fast convergence with topology switching
US6681244B1 (en)2000-06-092004-01-203Com CorporationSystem and method for operating a network adapter when an associated network computing system is in a low-power state
US6683883B1 (en)2002-04-092004-01-27Sancastle Technologies Ltd.ISCSI-FCP gateway
US20040025477A1 (en)2000-11-142004-02-12Massimiliano SicheraMethod and apparatus for inserting a cover sheet between a transparent film and a book-like case
US6693912B1 (en)1999-06-042004-02-17Oki Electric Industry Co., Ltd.Network interconnecting apparatus and active quality-of-service mapping method
JP2004054562A (en)2002-07-192004-02-19Nec CorpMethod of controlling input and output for network file system
JP2004056728A (en)2002-07-242004-02-19Hitachi Ltd Switching node device for storage network and access method of remote storage device
US6701431B2 (en)2000-01-282004-03-02Infineon Technologies AgMethod of generating a configuration for a configurable spread spectrum communication device
US6701432B1 (en)1999-04-012004-03-02Netscreen Technologies, Inc.Firewall including local bus
US20040047367A1 (en)2002-09-052004-03-11Litchfield Communications, Inc.Method and system for optimizing the size of a variable buffer
US6711164B1 (en)1999-11-052004-03-23Nokia CorporationMethod and apparatus for performing IP-ID regeneration to improve header compression efficiency
US6710786B1 (en)1997-02-032004-03-23Oracle International CorporationMethod and apparatus for incorporating state information into a URL
WO2004025477A2 (en)2002-09-162004-03-25Level 5 Networks LimitedNetwork interface and protocol supporting mappings of virtual memory locations at different processing devices
US20040078465A1 (en)2002-10-172004-04-22Coates Joshua L.Methods and apparatus for load balancing storage nodes in a distributed stroage area network system
US6728210B1 (en)1998-12-212004-04-27Nec America, Inc.Multi-logical access for a serial data link
US6732171B2 (en)2002-05-312004-05-04Lefthand Networks, Inc.Distributed network storage system with virtualization
US6732230B1 (en)1999-10-202004-05-04Lsi Logic CorporationMethod of automatically migrating information from a source to an assemblage of structured data carriers and associated system and assemblage of data carriers
US20040088293A1 (en)2002-10-312004-05-06Jeremy DaggettMethod and apparatus for providing aggregate object identifiers
US6741554B2 (en)2002-08-162004-05-25Motorola Inc.Method and apparatus for reliably communicating information packets in a wireless communication network
US6742034B1 (en)1999-12-162004-05-25Dell Products L.P.Method for storage device masking in a storage area network and storage controller and storage subsystem for using such a method
WO2004044732A1 (en)2002-11-122004-05-27Zetera CorporationElectrical devices with improved communication
US20040100952A1 (en)1997-10-142004-05-27Boucher Laurence B.Method and apparatus for dynamic packet batching with a high performance network interface
US6754662B1 (en)2000-08-012004-06-22Nortel Networks LimitedMethod and apparatus for fast and consistent packet classification via efficient hash-caching
US6757845B2 (en)2000-11-302004-06-29Bitmicro Networks, Inc.Method and apparatus for testing a storage device
US20040148380A1 (en)2002-10-282004-07-29Richard MeyerMethod and system for dynamic expansion and contraction of nodes in a storage area network
US6772161B2 (en)2001-12-192004-08-03Hewlett-Packard Development Company, L.P.Object-level migration in a partition-based distributed file system
US6775673B2 (en)2001-12-192004-08-10Hewlett-Packard Development Company, L.P.Logical volume-level migration in a partition-based distributed file system
US6775672B2 (en)2001-12-192004-08-10Hewlett-Packard Development Company, L.P.Updating references to a migrated object in a partition-based distributed file system
US20040162914A1 (en)2003-02-132004-08-19Sun Microsystems, Inc.System and method of extending virtual address resolution for mapping networks
US20040160975A1 (en)2003-01-212004-08-19Charles FrankMulticast communication protocols, systems and methods
US20040181476A1 (en)*2003-03-132004-09-16Smith William R.Dynamic network resource brokering
US6795534B2 (en)2000-09-042004-09-21Nec CorporationData recording system for IP telephone communication
US20040184455A1 (en)2003-03-192004-09-23Institute For Information IndustrySystem and method used by a gateway for processing fragmented IP packets from a private network
US6799255B1 (en)1998-06-292004-09-28Emc CorporationStorage mapping and partitioning among multiple host processors
US6799244B2 (en)1999-12-132004-09-28Hitachi, Ltd.Storage control unit with a volatile cache and a non-volatile backup cache for processing read and write requests
CN1532723A (en)2003-03-212004-09-29ض�Polymerization of service registraion form
US20040215688A1 (en)*2002-11-122004-10-28Charles FrankData storage devices having ip capable partitions
US6826613B1 (en)2000-03-152004-11-303Com CorporationVirtually addressing storage devices through a switch
US6834326B1 (en)2000-02-042004-12-213Com CorporationRAID method and device with network protocol between controller and storage devices
US6853382B1 (en)2000-10-132005-02-08Nvidia CorporationController for a memory system having multiple partitions
US6854021B1 (en)2000-10-022005-02-08International Business Machines CorporationCommunications between partitions within a logically partitioned computer
US20050033740A1 (en)2000-05-222005-02-10Broadcom CorporationMethod and apparatus for performing a binary search on an expanded tree
WO2005017738A1 (en)2003-08-132005-02-24Fujitsu LimitedPrint control method, print controller and print control program
US20050044199A1 (en)2003-08-062005-02-24Kenta ShigaStorage network management system and method
US6862606B1 (en)2001-05-112005-03-01Novell, Inc.System and method for partitioning address space in a proxy cache server cluster
US20050058131A1 (en)2003-07-292005-03-17Samuels Allen R.Wavefront detection and disambiguation of acknowledgments
US20050068924A1 (en)2001-11-122005-03-31Jan LindskogSystem and method for providing quality of service in ieee 802.11 systems
US6876657B1 (en)2000-12-142005-04-05Chiaro Networks, Ltd.System and method for router packet control and ordering
US6882637B1 (en)1999-10-142005-04-19Nokia Networks OyMethod and system for transmitting and receiving packets
US6886035B2 (en)1996-08-022005-04-26Hewlett-Packard Development Company, L.P.Dynamic load balancing of a network of client and server computer
US20050102522A1 (en)2003-11-122005-05-12Akitsugu KandaAuthentication device and computer system
US6895511B1 (en)1998-10-292005-05-17Nortel Networks LimitedMethod and apparatus providing for internet protocol address authentication
US6895461B1 (en)2002-04-222005-05-17Cisco Technology, Inc.Method and apparatus for accessing remote storage using SCSI and an IP network
US6894976B1 (en)2000-06-152005-05-17Network Appliance, Inc.Prevention and detection of IP identification wraparound errors
US6901497B2 (en)2000-10-272005-05-31Sony Computer Entertainment Inc.Partition creating method and deleting method
US6904470B1 (en)2003-03-262005-06-07Emc CorporationDevice selection by a disk adapter scheduler
US6907473B2 (en)1998-10-302005-06-14Science Applications International Corp.Agile network protocol for secure communications with assured system availability
US20050138003A1 (en)2003-12-182005-06-23Andrew GloverSystem and method for database having relational node structure
US6912622B2 (en)2002-04-152005-06-28Microsoft CorporationMulti-level cache architecture and cache management method for peer-to-peer name resolution protocol
US6917616B1 (en)1998-09-182005-07-12Alcatel Canada Inc.Method and apparatus for reduction and restoration of data elements pertaining to transmitted data packets in a communications network
US6922688B1 (en)1998-01-232005-07-26Adaptec, Inc.Computer system storage
US20050166022A1 (en)*2004-01-282005-07-28Hitachi, Ltd.Method and apparatus for copying and backup in storage systems
US20050165883A1 (en)*1998-05-132005-07-28Lynch Thomas W.Symbiotic computing system and method of operation therefor
US6928473B1 (en)2000-09-262005-08-09Microsoft CorporationMeasuring network jitter on application packet flows
US20050175005A1 (en)2000-06-212005-08-11Mosaid Technologies, Inc.Method and apparatus for physical width expansion of longest prefix match lookup table
US6934799B2 (en)2002-01-182005-08-23International Business Machines CorporationVirtualization of iSCSI storage
US6941555B2 (en)1998-11-052005-09-06Bea Systems, Inc.Clustered enterprise Java™ in a secure distributed processing system
US20050198371A1 (en)2004-02-192005-09-08Smith Michael R.Interface bundles in virtual network devices
US6947430B2 (en)2000-03-242005-09-20International Business Machines CorporationNetwork adapter with embedded deep packet processing
JP2005265914A (en)2004-03-162005-09-29Ricoh Co Ltd Zoom lens, camera, and portable information terminal device
US20050246401A1 (en)2004-04-302005-11-03Edwards John KExtension of write anywhere file system layout
US20050259646A1 (en)2004-05-192005-11-24Smith Michael RVirtual network device clusters
US20050267929A1 (en)*2004-06-012005-12-01Hitachi, Ltd.Method of dynamically balancing workload of a storage system
US20050270856A1 (en)2004-06-032005-12-08Inphase Technologies, Inc.Multi-level format for information storage
US6978271B1 (en)2000-10-312005-12-20Unisys CorporationMechanism for continuable calls to partially traverse a dynamic general tree
US6977927B1 (en)2000-09-182005-12-20Hewlett-Packard Development Company, L.P.Method and system of allocating storage resources in a storage area network
US20050286517A1 (en)2004-06-292005-12-29Babbar Uppinder SFiltering and routing of fragmented datagrams in a data network
US6983326B1 (en)2001-04-062006-01-03Networks Associates Technology, Inc.System and method for distributed function discovery in a peer-to-peer network environment
US6985956B2 (en)2000-11-022006-01-10Sun Microsystems, Inc.Switching system
US6993587B1 (en)2000-04-072006-01-31Network Appliance Inc.Method and apparatus for election of group leaders in a distributed network
US20060029070A1 (en)2002-11-122006-02-09Zetera CorporationProtocol adapter for electromagnetic device elements
US20060036602A1 (en)2004-08-132006-02-16Unangst Marc JDistributed object-based storage system that stores virtualization maps in object attributes
US20060045089A1 (en)2004-08-272006-03-02International Business Machines CorporationMethod and apparatus for providing network virtualization
US20060077902A1 (en)2004-10-082006-04-13Kannan Naresh KMethods and apparatus for non-intrusive measurement of delay variation of data traffic on communication networks
US7039934B2 (en)1999-12-102006-05-02Sony CorporationRecording system
US20060101130A1 (en)2002-11-122006-05-11Mark AdamsSystems and methods for deriving storage area commands
US7051087B1 (en)2000-06-052006-05-23Microsoft CorporationSystem and method for automatic detection and configuration of network parameters
US7065579B2 (en)2001-01-222006-06-20Sun Microsystems, Inc.System using peer discovery and peer membership protocols for accessing peer-to-peer platform resources on a network
US20060133365A1 (en)2004-12-162006-06-22Shankar ManjunathaMethod, system and article for improved network performance by avoiding IP-ID wrap-arounds causing data corruption on fast networks
US7069295B2 (en)2001-02-142006-06-27The Escher Group, Ltd.Peer-to-peer enterprise storage
US7072986B2 (en)2001-11-072006-07-04Hitachi, Ltd.System and method for displaying storage system topology
US7072823B2 (en)2001-03-302006-07-04Intransa, Inc.Method and apparatus for accessing memory using Ethernet packets
US7073090B2 (en)1993-04-232006-07-04Emc CorporationRemote data mirroring system having a remote link adapter
US20060168345A1 (en)*2005-01-212006-07-27Microsoft CorporationResource identifier zone translation
US20060176903A1 (en)2000-02-032006-08-10GemplusConveying protocol units for portable electronic objects via a protocol for microcomputer peripherals
US20060206662A1 (en)2005-03-142006-09-14Ludwig Thomas ETopology independent storage arrays and methods
US7111303B2 (en)2002-07-162006-09-19International Business Machines CorporationVirtual machine operating system LAN
US7120666B2 (en)2002-10-302006-10-10Riverbed Technology, Inc.Transaction accelerator for client-server communication systems
US20060272015A1 (en)2005-05-262006-11-30Frank Charles WVirtual devices and virtual bus tunnels, modules and methods
WO2006127013A1 (en)2005-05-262006-11-30Zetera CorporationVirtual devices and virtual bus tunnels, modules and methods
US7145866B1 (en)2001-03-012006-12-05Emc CorporationVirtual network devices
US7146427B2 (en)2002-04-232006-12-05Lsi Logic CorporationPolling-based mechanism for improved RPC timeout handling
US7149769B2 (en)2002-03-262006-12-12Hewlett-Packard Development Company, L.P.System and method for multi-destination merge in a storage area network
US7152069B1 (en)2002-10-152006-12-19Network Appliance, Inc.Zero copy writes through use of mbufs
WO2007021289A1 (en)2005-08-162007-02-22Zetera CorporationDisaggregated resources and access methods
US7188194B1 (en)2002-04-222007-03-06Cisco Technology, Inc.Session-based target/LUN mapping for a storage area network and associated method
US7200641B1 (en)2000-12-292007-04-03Emc CorporationMethod and system for encoding SCSI requests for transmission using TCP/IP
US7203730B1 (en)2001-02-132007-04-10Network Appliance, Inc.Method and apparatus for identifying storage devices
US20070083662A1 (en)2005-10-062007-04-12Zetera CorporationResource command messages and methods
US7206805B1 (en)1999-09-092007-04-17Oracle International CorporationAsynchronous transcription object management system
WO2007043999A1 (en)2005-10-062007-04-19Zetera CorporationResource command messages and methods
US20070101023A1 (en)2005-10-282007-05-03Microsoft CorporationMultiple task offload to a peripheral device
US20070110047A1 (en)*2004-01-302007-05-17Sun-Kwon KimMethod of collecting and searching for access route of information resource on internet and computer readable medium stored thereon program for implementing the same
US7225243B1 (en)2000-03-142007-05-29Adaptec, Inc.Device discovery methods and systems implementing the same
US7237036B2 (en)1997-10-142007-06-26Alacritech, Inc.Fast-path apparatus for receiving data corresponding a TCP connection
US20070147347A1 (en)2005-12-222007-06-28Ristock Herbert W ASystem and methods for locating and acquisitioning a service connection via request broadcasting over a data packet network
US7243144B2 (en)2002-09-262007-07-10Hitachi, Ltd.Integrated topology management method for storage and IP networks
US20070168396A1 (en)2005-08-162007-07-19Zetera CorporationGenerating storage system commands
US7254620B2 (en)2002-06-032007-08-07Hitachi, Ltd.Storage system
US7260638B2 (en)2000-07-242007-08-21Bluesocket, Inc.Method and system for enabling seamless roaming in a wireless network
US7263108B2 (en)2002-08-062007-08-28Netxen, Inc.Dual-mode network storage systems and methods
US7278142B2 (en)2000-08-242007-10-02Veritas Operating CorporationDynamic computing environment using remotely allocable resources
US20070230476A1 (en)2005-02-042007-10-04Huawei Technologies Co., Ltd.Method for Information Transmission
US20070237157A1 (en)2006-04-102007-10-11Zetera CorporationMethods of resolving datagram corruption over an internetworking protocol
US7296050B2 (en)2002-01-182007-11-13Hewlett-Packard Development Company L.P.Distributed computing system and method
US7327735B2 (en)2002-11-272008-02-05Alcatel Canada Inc.System and method for detecting lost messages transmitted between modules in a communication device
US7333451B1 (en)1999-10-182008-02-19Nortel Networks LimitedBuffer management for mobile internet protocol
US7389358B1 (en)2000-09-132008-06-17Fortinet, Inc.Distributed virtual system to support managed, network-based services
US7404000B2 (en)2001-09-282008-07-22Emc CorporationProtocol translation in a storage system
US7406523B1 (en)2000-11-212008-07-29Microsoft CorporationClient-server communications system and method using a semi-connectionless protocol
US20080181158A1 (en)2005-03-242008-07-31Nokia CorporationNotification of a Receiving Device About a Forthcoming Transmission Session
US7415018B2 (en)2003-09-172008-08-19Alcatel LucentIP Time to Live (TTL) field used as a covert channel
US7421736B2 (en)2002-07-022008-09-02Lucent Technologies Inc.Method and apparatus for enabling peer-to-peer virtual private network (P2P-VPN) services in VPN-enabled network
US7428584B2 (en)2002-10-072008-09-23Hitachi, Ltd.Method for managing a network including a storage system
US7436789B2 (en)2003-10-092008-10-14Sarnoff CorporationAd Hoc wireless node and network
US7447209B2 (en)2004-03-092008-11-04The University Of North CarolinaMethods, systems, and computer program products for modeling and simulating application-level traffic characteristics in a network based on transport and network layer header information
US20080279106A1 (en)2003-10-032008-11-133Com CorporationSwitching fabrics and control protocols for them
US7463582B2 (en)2000-04-142008-12-09Hughes Network Systems, LlcSystem and method for scaling a two-way satellite system
US7475124B2 (en)2002-09-252009-01-06Emc CorporationNetwork block services for client access of network-attached data storage in an IP network
US7526577B2 (en)2003-09-192009-04-28Microsoft CorporationMultiple offload of network state objects with support for failover events
US7535913B2 (en)2002-03-062009-05-19Nvidia CorporationGigabit ethernet adapter supporting the iSCSI and IPSEC protocols
US7536525B2 (en)2004-11-092009-05-19Dell Products L.P.Virtual machine hot cloning including freezing and unfreezing memory in a distributed network
US7558264B1 (en)2001-09-282009-07-07Emc CorporationPacket classification in a storage system
US7707304B1 (en)2001-09-282010-04-27Emc CorporationStorage switch for storage area network
US7742454B2 (en)2004-12-162010-06-22International Business Machines CorporationNetwork performance by dynamically setting a reassembly timer based on network interface
US7742473B2 (en)2002-11-122010-06-22Mark AdamsAccelerator module
US7912059B1 (en)2002-02-082011-03-22Hatteras NetworksMethods, aggregation devices, and computer program products for distinguishing between sub-networks coupled to aggregation device ports by using an independent sub-network identifier domain space for each port

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
WO2000079362A2 (en)1999-06-232000-12-28Mangosoft CorporationDistributed virtual web cache implemented entirely in software

Patent Citations (321)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US4422171A (en)1980-12-291983-12-20Allied Corporation, Law DepartmentMethod and system for data communication
US4890227A (en)1983-07-201989-12-26Hitachi, Ltd.Autonomous resource management system with recorded evaluations of system performance with scheduler control including knowledge learning function
JPS6133054A (en)1984-07-251986-02-15Nec CorpTransmission and reception system of packet signal
JPS62233951A (en)1986-04-021987-10-14Nec CorpMultiplex packet transmission system
JPS6390942A (en)1986-10-061988-04-21Nec CorpInterexchange data link control system
US5129088A (en)1987-11-301992-07-07International Business Machines CorporationData processing method to create virtual disks from non-contiguous groups of logically contiguous addressable blocks of direct access storage device
US5193171A (en)1989-12-111993-03-09Hitachi, Ltd.Method of managing space of peripheral storages and apparatus for the same
TW223167B (en)1990-02-061994-05-01Canon Kk
EP0485110A2 (en)1990-11-091992-05-13Emc CorporationLogical partitioning of a redundant array storage system
US5546541A (en)1991-02-051996-08-13International Business Machines CorporationSystem for routing transaction commands to an external resource manager when the target resource is not managed by the local transaction managing computer program
US5590276A (en)1992-01-081996-12-31Emc CorporationMethod for synchronizing reserved areas in a redundant storage array
US5634111A (en)1992-03-161997-05-27Hitachi, Ltd.Computer system including a device with a plurality of identifiers
JPH05347623A (en)1992-04-071993-12-27Nec CorpMulti-cast communication system
US7073090B2 (en)1993-04-232006-07-04Emc CorporationRemote data mirroring system having a remote link adapter
US5590124A (en)*1993-05-071996-12-31Apple Computer, Inc.Link and discovery protocol for a ring interconnect architecture
US5444709A (en)1993-09-301995-08-22Apple Computer, Inc.Protocol for transporting real time data
US5771354A (en)1993-11-041998-06-23Crawford; Christopher M.Internet online backup system provides remote storage for customers using IDs and passwords which were interactively established when signing up for backup services
US5867686A (en)1993-11-091999-02-02Conner; Kenneth H.High speed real-time information storage system
EP0654736A2 (en)1993-11-191995-05-24Hitachi, Ltd.Dynamically expandable storage unit array system
US5506969A (en)1993-11-291996-04-09Sun Microsystems, Inc.Method and apparatus for bus bandwidth management
GB2285558A (en)1993-12-281995-07-12Nec CorpIC card radio modem operable on a plurality of types of infrastructure network
JPH07325779A (en)1994-06-011995-12-12Fuji Xerox Co LtdInput/output controller
US5617449A (en)1994-06-271997-04-01Nec CorporationIC memory card type radio modem
EP0700231A2 (en)1994-08-291996-03-06AT&T Corp.Methods and systems for interprocess communication and inter-network data transfer
EP0706113A2 (en)1994-10-051996-04-10Hewlett-Packard CompanyMethods for adding storage disks to a hierarchic disk array while maintaining data availability
JPH08251198A (en)1995-03-151996-09-27Matsushita Electric Ind Co Ltd Multiplex transmission device
US6396480B1 (en)1995-07-172002-05-28Gateway, Inc.Context sensitive remote control groups
US5930786A (en)1995-10-201999-07-27Ncr CorporationMethod and apparatus for providing shared data to a requesting client
US5850449A (en)1995-10-261998-12-15Sun Microsystems, Inc.Secure network protocol system and method
US5948062A (en)1995-10-271999-09-07Emc CorporationNetwork file server using a cached disk array storing a network file directory including file locking information and data mover computers each having file system software for shared read-write file access
US5758188A (en)1995-11-211998-05-26Quantum CorporationSynchronous DMA burst transfer protocol having the peripheral device toggle the strobe signal such that data is latched using both edges of the strobe signal
JPH09149060A (en)1995-11-271997-06-06Mitsubishi Electric Corp Broadcast communication method in multi-branch connection network
US5758050A (en)1996-03-121998-05-26International Business Machines CorporationReconfigurable data storage system
US5742604A (en)1996-03-281998-04-21Cisco Systems, Inc.Interswitch link mechanism for connecting high-performance network switches
US5889935A (en)1996-05-281999-03-30Emc CorporationDisaster control features for remote data mirroring
US6886035B2 (en)1996-08-022005-04-26Hewlett-Packard Development Company, L.P.Dynamic load balancing of a network of client and server computer
US5949977A (en)1996-10-081999-09-07Aubeta Technology, LlcMethod and apparatus for requesting and processing services from a plurality of nodes connected via common communication links
US6202060B1 (en)1996-10-292001-03-13Bao Q. TranData management system
US6157935A (en)1996-12-172000-12-05Tran; Bao Q.Remote data access and management system
US5991891A (en)*1996-12-231999-11-23Lsi Logic CorporationMethod and apparatus for providing loop coherency
US6710786B1 (en)1997-02-032004-03-23Oracle International CorporationMethod and apparatus for incorporating state information into a URL
US6181927B1 (en)1997-02-182001-01-30Nortel Networks CorporationSponsored call and cell service
US20010037371A1 (en)1997-04-282001-11-01Ohran Michael R.Mirroring network data to establish virtual storage area network
US5884038A (en)1997-05-021999-03-16Whowhere? Inc.Method for providing an Internet protocol address with a domain name server
JPH10333839A (en)1997-05-291998-12-18Hitachi Ltd Fiber Channel connection storage controller
US6288716B1 (en)1997-06-252001-09-11Samsung Electronics, Co., LtdBrowser based command and control home network
US6295584B1 (en)*1997-08-292001-09-25International Business Machines CorporationMultiprocessor computer system with memory map translation
US6385638B1 (en)1997-09-042002-05-07Equator Technologies, Inc.Processor resource distributor and method
US7237036B2 (en)1997-10-142007-06-26Alacritech, Inc.Fast-path apparatus for receiving data corresponding a TCP connection
US20040100952A1 (en)1997-10-142004-05-27Boucher Laurence B.Method and apparatus for dynamic packet batching with a high performance network interface
US6128664A (en)1997-10-202000-10-03Fujitsu LimitedAddress-translating connection device
US6101559A (en)1997-10-222000-08-08Compaq Computer CorporationSystem for identifying the physical location of one or more peripheral devices by selecting icons on a display representing the one or more peripheral devices
US5937169A (en)1997-10-291999-08-103Com CorporationOffload of TCP segmentation to a smart adapter
US6081879A (en)*1997-11-042000-06-27Adaptec, Inc.Data processing system and virtual partitioning method for creating logical multi-level units of online storage
US5983024A (en)1997-11-261999-11-09Honeywell, Inc.Method and apparatus for robust data broadcast on a peripheral component interconnect bus
US6018779A (en)1997-12-152000-01-25Emc CorporationSystem for encapsulating a plurality of selected commands within a single command and transmitting the single command to a remote device over a communication link therewith
US6922688B1 (en)1998-01-232005-07-26Adaptec, Inc.Computer system storage
US6105122A (en)1998-02-062000-08-15Ncr CorporationI/O protocol for highly configurable multi-node processing system
US6253273B1 (en)1998-02-062001-06-26Emc CorporationLock mechanism
US6246683B1 (en)1998-05-012001-06-123Com CorporationReceive processing with network protocol bypass
US20050165883A1 (en)*1998-05-132005-07-28Lynch Thomas W.Symbiotic computing system and method of operation therefor
US6549983B1 (en)1998-05-202003-04-15Samsung Electronics Co., Ltd.Cache memory system and method for managing the same
US6259448B1 (en)1998-06-032001-07-10International Business Machines CorporationResource model configuration and deployment in a distributed computer network
US6330236B1 (en)1998-06-112001-12-11Synchrodyne Networks, Inc.Packet switching method with time-based routing
US6157955A (en)1998-06-152000-12-05Intel CorporationPacket processing system including a policy engine having a classification unit
US6377990B1 (en)1998-06-152002-04-23Lodgenet Entertainment CorporationSystem for providing internet access from locations different from those for which the user's software was configured
US6799255B1 (en)1998-06-292004-09-28Emc CorporationStorage mapping and partitioning among multiple host processors
US20030130986A1 (en)*1998-06-302003-07-10Tamer Philip E.System for determining the mapping of logical objects in a data storage system
US6449607B1 (en)1998-09-112002-09-10Hitachi, Ltd.Disk storage with modifiable data management function
US6330616B1 (en)1998-09-142001-12-11International Business Machines CorporationSystem for communications of multiple partitions employing host-network interface, and address resolution protocol for constructing data frame format according to client format
US20020029286A1 (en)1998-09-142002-03-07International Business Machines CorporationCommunication between multiple partitions employing host-network interface
US6330615B1 (en)1998-09-142001-12-11International Business Machines CorporationMethod of using address resolution protocol for constructing data frame formats for multiple partitions host network interface communications
US6917616B1 (en)1998-09-182005-07-12Alcatel Canada Inc.Method and apparatus for reduction and restoration of data elements pertaining to transmitted data packets in a communications network
US6473774B1 (en)1998-09-282002-10-29Compaq Computer CorporationMethod and apparatus for record addressing in partitioned files
US6480934B1 (en)1998-09-282002-11-12Hitachi, Ltd.Storage control unit and method for handling data storage system using thereof
US6618743B1 (en)1998-10-092003-09-09Oneworld Internetworking, Inc.Method and system for providing discrete user cells in a UNIX-based environment
US6895511B1 (en)1998-10-292005-05-17Nortel Networks LimitedMethod and apparatus providing for internet protocol address authentication
US6907473B2 (en)1998-10-302005-06-14Science Applications International Corp.Agile network protocol for secure communications with assured system availability
US6941555B2 (en)1998-11-052005-09-06Bea Systems, Inc.Clustered enterprise Java™ in a secure distributed processing system
US20020052962A1 (en)1998-11-162002-05-02Ludmila CherkasovaHybrid and predictive admission control strategies for a server
US6597680B1 (en)1998-11-162003-07-22Telefonaktiebolaget Lm Ericsson (Publ)Packet traffic channel reassignment
US6567863B1 (en)1998-12-072003-05-20Schneider Electric Industries SaProgrammable controller coupler
US6728210B1 (en)1998-12-212004-04-27Nec America, Inc.Multi-logical access for a serial data link
US6587464B1 (en)1999-01-082003-07-01Nortel Networks LimitedMethod and system for partial reporting of missing information frames in a telecommunication system
US6434147B1 (en)1999-01-082002-08-13Nortel Netwoks LimitedMethod and system for sequential ordering of missing sequence numbers in SREJ frames in a telecommunication system
US6466571B1 (en)1999-01-192002-10-153Com CorporationRadius-based mobile internet protocol (IP) address-to-mobile identification number mapping for wireless communication
US6470342B1 (en)1999-03-122002-10-22Compaq Computer CorporationProcess of maintaining a distributed map of transaction identifiers and using hashing to access these maps
JP2000267979A (en)1999-03-122000-09-29Nec CorpStorage system
US6401183B1 (en)1999-04-012002-06-04Flash Vos, Inc.System and method for operating system independent storage management
US6701432B1 (en)1999-04-012004-03-02Netscreen Technologies, Inc.Firewall including local bus
US20020016811A1 (en)1999-04-072002-02-07International Business Machines CorporationComputer system and method for sharing a job with other computers on a computer network using IP multicast
US6553028B1 (en)1999-04-302003-04-22Cisco Technology, Inc.Method and apparatus for multicast switching using a centralized switching engine
US6487555B1 (en)1999-05-072002-11-26Alta Vista CompanyMethod and apparatus for finding mirrored hosts by analyzing connectivity and IP addresses
US6275898B1 (en)1999-05-132001-08-14Lsi Logic CorporationMethods and structure for RAID level migration within a logical unit
US6693912B1 (en)1999-06-042004-02-17Oki Electric Industry Co., Ltd.Network interconnecting apparatus and active quality-of-service mapping method
US20020035621A1 (en)1999-06-112002-03-21Zintel William MichaelXML-based language description for controlled devices
US20020029256A1 (en)1999-06-112002-03-07Zintel William M.XML-based template language for devices and services
WO2001001270A1 (en)1999-06-302001-01-04Webtv Networks, Inc.Interactive television triggers having connected content/disconnected content attribute
US7206805B1 (en)1999-09-092007-04-17Oracle International CorporationAsynchronous transcription object management system
JP2001094987A (en)1999-09-222001-04-06Matsushita Electric Ind Co Ltd Image data transmission method
US6882637B1 (en)1999-10-142005-04-19Nokia Networks OyMethod and system for transmitting and receiving packets
US7333451B1 (en)1999-10-182008-02-19Nortel Networks LimitedBuffer management for mobile internet protocol
US6732230B1 (en)1999-10-202004-05-04Lsi Logic CorporationMethod of automatically migrating information from a source to an assemblage of structured data carriers and associated system and assemblage of data carriers
US6711164B1 (en)1999-11-052004-03-23Nokia CorporationMethod and apparatus for performing IP-ID regeneration to improve header compression efficiency
US6535925B1 (en)1999-11-092003-03-18Telefonaktiebolaget L M Ericsson (Publ)Packet header compression using division remainders
US6678241B1 (en)1999-11-302004-01-13Cisc Technology, Inc.Fast convergence with topology switching
US20010020273A1 (en)1999-12-032001-09-06Yasushi MurakawaMethod of virtual private network communication in security gateway apparatus and security gateway apparatus using the same
US6389448B1 (en)1999-12-062002-05-14Warp Solutions, Inc.System and method for load balancing
US7039934B2 (en)1999-12-102006-05-02Sony CorporationRecording system
US6799244B2 (en)1999-12-132004-09-28Hitachi, Ltd.Storage control unit with a volatile cache and a non-volatile backup cache for processing read and write requests
US6742034B1 (en)1999-12-162004-05-25Dell Products L.P.Method for storage device masking in a storage area network and storage controller and storage subsystem for using such a method
US6701431B2 (en)2000-01-282004-03-02Infineon Technologies AgMethod of generating a configuration for a configurable spread spectrum communication device
US20060176903A1 (en)2000-02-032006-08-10GemplusConveying protocol units for portable electronic objects via a protocol for microcomputer peripherals
US6834326B1 (en)2000-02-042004-12-213Com CorporationRAID method and device with network protocol between controller and storage devices
US20010034758A1 (en)2000-02-242001-10-25Dan KikinisVirtual private network (VPN) for servicing home gateway system through external disk management
US20020039196A1 (en)2000-02-252002-04-04Luca ChiarabiniSystem and method for downloading and for printing data from an external content source
US7225243B1 (en)2000-03-142007-05-29Adaptec, Inc.Device discovery methods and systems implementing the same
US6601101B1 (en)2000-03-152003-07-293Com CorporationTransparent access to network attached devices
US6826613B1 (en)2000-03-152004-11-303Com CorporationVirtually addressing storage devices through a switch
US20020031086A1 (en)2000-03-222002-03-14Welin Andrew M.Systems, processes and integrated circuits for improved packet scheduling of media over packet
US6947430B2 (en)2000-03-242005-09-20International Business Machines CorporationNetwork adapter with embedded deep packet processing
US20010026550A1 (en)2000-03-292001-10-04Fujitsu LimitedCommunication device
US6629264B1 (en)2000-03-302003-09-30Hewlett-Packard Development Company, L.P.Controller-based remote copy system with logical unit grouping
US6993587B1 (en)2000-04-072006-01-31Network Appliance Inc.Method and apparatus for election of group leaders in a distributed network
US7463582B2 (en)2000-04-142008-12-09Hughes Network Systems, LlcSystem and method for scaling a two-way satellite system
US20030041138A1 (en)2000-05-022003-02-27Sun Microsystems, Inc.Cluster membership monitor
US20050033740A1 (en)2000-05-222005-02-10Broadcom CorporationMethod and apparatus for performing a binary search on an expanded tree
US20020026558A1 (en)2000-06-022002-02-28Reuter James M.Architecture for parallel distributed table driven I/O mapping
US20010049739A1 (en)2000-06-022001-12-06Koji WakayamaApparatus and method for interworking between MPLS network and non-MPLS network
US7051087B1 (en)2000-06-052006-05-23Microsoft CorporationSystem and method for automatic detection and configuration of network parameters
US6629162B1 (en)2000-06-082003-09-30International Business Machines CorporationSystem, method, and product in a logically partitioned system for prohibiting I/O adapters from accessing memory assigned to other partitions during DMA
US6681244B1 (en)2000-06-092004-01-203Com CorporationSystem and method for operating a network adapter when an associated network computing system is in a low-power state
JP2001359200A (en)2000-06-122001-12-26Yamaha CorpWireless audio equipment
US6894976B1 (en)2000-06-152005-05-17Network Appliance, Inc.Prevention and detection of IP identification wraparound errors
US6629178B1 (en)2000-06-152003-09-30Advanced Micro Devices, Inc.System and method for controlling bus access for bus agents having varying priorities
US20050175005A1 (en)2000-06-212005-08-11Mosaid Technologies, Inc.Method and apparatus for physical width expansion of longest prefix match lookup table
US7260638B2 (en)2000-07-242007-08-21Bluesocket, Inc.Method and system for enabling seamless roaming in a wireless network
US6754662B1 (en)2000-08-012004-06-22Nortel Networks LimitedMethod and apparatus for fast and consistent packet classification via efficient hash-caching
WO2002015018A1 (en)2000-08-112002-02-213Ware, Inc.Architecture for providing block-level storage access over a computer network
US7278142B2 (en)2000-08-242007-10-02Veritas Operating CorporationDynamic computing environment using remotely allocable resources
US6795534B2 (en)2000-09-042004-09-21Nec CorporationData recording system for IP telephone communication
US7389358B1 (en)2000-09-132008-06-17Fortinet, Inc.Distributed virtual system to support managed, network-based services
US6977927B1 (en)2000-09-182005-12-20Hewlett-Packard Development Company, L.P.Method and system of allocating storage resources in a storage area network
US6928473B1 (en)2000-09-262005-08-09Microsoft CorporationMeasuring network jitter on application packet flows
US6854021B1 (en)2000-10-022005-02-08International Business Machines CorporationCommunications between partitions within a logically partitioned computer
US6853382B1 (en)2000-10-132005-02-08Nvidia CorporationController for a memory system having multiple partitions
US6901497B2 (en)2000-10-272005-05-31Sony Computer Entertainment Inc.Partition creating method and deleting method
US20020062387A1 (en)2000-10-302002-05-23Michael YatzivInterface emulation for storage devices
US6978271B1 (en)2000-10-312005-12-20Unisys CorporationMechanism for continuable calls to partially traverse a dynamic general tree
US6985956B2 (en)2000-11-022006-01-10Sun Microsystems, Inc.Switching system
US6434683B1 (en)2000-11-072002-08-13Storage Technology CorporationMethod and system for transferring delta difference data to a storage device
US20040025477A1 (en)2000-11-142004-02-12Massimiliano SicheraMethod and apparatus for inserting a cover sheet between a transparent film and a book-like case
US6601135B1 (en)2000-11-162003-07-29International Business Machines CorporationNo-integrity logical volume management method and system
US7406523B1 (en)2000-11-212008-07-29Microsoft CorporationClient-server communications system and method using a semi-connectionless protocol
US7353266B2 (en)2000-11-302008-04-01Microsoft CorporationSystem and method for managing states and user context over stateless protocols
US20020065875A1 (en)2000-11-302002-05-30Shawn BracewellSystem and method for managing states and user context over stateless protocols
US6757845B2 (en)2000-11-302004-06-29Bitmicro Networks, Inc.Method and apparatus for testing a storage device
CN1359214A (en)2000-12-132002-07-17Lg电子株式会社 Household appliance remote control device and control method thereof
US6876657B1 (en)2000-12-142005-04-05Chiaro Networks, Ltd.System and method for router packet control and ordering
US20020087811A1 (en)*2000-12-282002-07-04Manoj KhareMethod and apparatus for reducing memory latency in a cache coherent multi-node architecture
US7200641B1 (en)2000-12-292007-04-03Emc CorporationMethod and system for encoding SCSI requests for transmission using TCP/IP
US20020091830A1 (en)2001-01-102002-07-11Koji MuramatsuDistributed-processing system and command transfer method in the same
US7065579B2 (en)2001-01-222006-06-20Sun Microsystems, Inc.System using peer discovery and peer membership protocols for accessing peer-to-peer platform resources on a network
US20020138628A1 (en)2001-01-252002-09-26Crescent Networks, Inc.Extension of address resolution protocol (ARP) for internet protocol (IP) virtual networks
US20030018784A1 (en)*2001-01-252003-01-23Lette John T.System and method for processing requests from newly registered remote application consumers
US7203730B1 (en)2001-02-132007-04-10Network Appliance, Inc.Method and apparatus for identifying storage devices
US7069295B2 (en)2001-02-142006-06-27The Escher Group, Ltd.Peer-to-peer enterprise storage
JP2002252880A (en)2001-02-262002-09-06Sanyo Electric Co LtdLiquid crystal projector
US7145866B1 (en)2001-03-012006-12-05Emc CorporationVirtual network devices
WO2002071775A1 (en)2001-03-012002-09-12Mitsubishi Denki Kabushiki KaishaMobile ip packet communication system
US20020126658A1 (en)2001-03-062002-09-12Nec CorporationMain unit address restricted notification system
US20020133539A1 (en)2001-03-142002-09-19Imation Corp.Dynamic logical storage volumes
US7072823B2 (en)2001-03-302006-07-04Intransa, Inc.Method and apparatus for accessing memory using Ethernet packets
US6983326B1 (en)2001-04-062006-01-03Networks Associates Technology, Inc.System and method for distributed function discovery in a peer-to-peer network environment
JP2002318725A (en)2001-04-202002-10-31Hitachi Ltd Disk array system
US20020165978A1 (en)2001-05-072002-11-07Terence ChuiMulti-service optical infiniband router
US6862606B1 (en)2001-05-112005-03-01Novell, Inc.System and method for partitioning address space in a proxy cache server cluster
US20030081592A1 (en)2001-06-012003-05-01Ainkaran KrishnarajahMethod and apparatus for transporting different classes of data bits in a payload over a radio interface
US20030026246A1 (en)2001-06-062003-02-06Zarlink Semiconductor V.N. Inc.Cached IP routing tree for longest prefix search
US20030172157A1 (en)2001-06-282003-09-11Wright Michael H.System and method for managing replication sets of data distributed over one or more computer systems
US6636958B2 (en)2001-07-172003-10-21International Business Machines CorporationAppliance server with a drive partitioning scheme that accommodates application growth in size
US20030023811A1 (en)2001-07-272003-01-30Chang-Soo KimMethod for managing logical volume in order to support dynamic online resizing and software raid
US20030070144A1 (en)*2001-09-042003-04-10Christoph SchnelleMapping of data from XML to SQL
US7558264B1 (en)2001-09-282009-07-07Emc CorporationPacket classification in a storage system
US20030093567A1 (en)2001-09-282003-05-15Lolayekar Santosh C.Serverless storage services
US7707304B1 (en)2001-09-282010-04-27Emc CorporationStorage switch for storage area network
US20030079018A1 (en)2001-09-282003-04-24Lolayekar Santosh C.Load balancing in a storage network
US7404000B2 (en)2001-09-282008-07-22Emc CorporationProtocol translation in a storage system
US20030065733A1 (en)2001-09-282003-04-03Pecone Victor KeyModular architecture for a network storage controller
US20030069995A1 (en)2001-10-052003-04-10Fayette Brad K.Method and system for communicating among heterogeneous systems
US7072986B2 (en)2001-11-072006-07-04Hitachi, Ltd.System and method for displaying storage system topology
US20050068924A1 (en)2001-11-122005-03-31Jan LindskogSystem and method for providing quality of service in ieee 802.11 systems
US20030101239A1 (en)2001-11-272003-05-29Takeshi IshizakiStorage device with VLAN support
US6775673B2 (en)2001-12-192004-08-10Hewlett-Packard Development Company, L.P.Logical volume-level migration in a partition-based distributed file system
US6775672B2 (en)2001-12-192004-08-10Hewlett-Packard Development Company, L.P.Updating references to a migrated object in a partition-based distributed file system
US6772161B2 (en)2001-12-192004-08-03Hewlett-Packard Development Company, L.P.Object-level migration in a partition-based distributed file system
US20030118053A1 (en)2001-12-262003-06-26Andiamo Systems, Inc.Methods and apparatus for encapsulating a frame for transmission in a storage area network
US20030152041A1 (en)2002-01-102003-08-14Falk HerrmannProtocol for reliable, self-organizing, low-power wireless network for security and building automation systems
US7296050B2 (en)2002-01-182007-11-13Hewlett-Packard Development Company L.P.Distributed computing system and method
US6934799B2 (en)2002-01-182005-08-23International Business Machines CorporationVirtualization of iSCSI storage
US20030172149A1 (en)2002-01-232003-09-11Andiamo Systems, A Delaware CorporationMethods and apparatus for implementing virtualization of storage within a storage area network
US7912059B1 (en)2002-02-082011-03-22Hatteras NetworksMethods, aggregation devices, and computer program products for distinguishing between sub-networks coupled to aggregation device ports by using an independent sub-network identifier domain space for each port
US20030161312A1 (en)2002-02-272003-08-28International Business Machines CorporationApparatus and method of maintaining two-byte IP identification fields in IP headers
US7535913B2 (en)2002-03-062009-05-19Nvidia CorporationGigabit ethernet adapter supporting the iSCSI and IPSEC protocols
US20030182349A1 (en)2002-03-212003-09-25James LeongMethod and apparatus for decomposing I/O tasks in a raid system
US7149769B2 (en)2002-03-262006-12-12Hewlett-Packard Development Company, L.P.System and method for multi-destination merge in a storage area network
US6683883B1 (en)2002-04-092004-01-27Sancastle Technologies Ltd.ISCSI-FCP gateway
US6912622B2 (en)2002-04-152005-06-28Microsoft CorporationMulti-level cache architecture and cache management method for peer-to-peer name resolution protocol
US6895461B1 (en)2002-04-222005-05-17Cisco Technology, Inc.Method and apparatus for accessing remote storage using SCSI and an IP network
US7188194B1 (en)2002-04-222007-03-06Cisco Technology, Inc.Session-based target/LUN mapping for a storage area network and associated method
US7146427B2 (en)2002-04-232006-12-05Lsi Logic CorporationPolling-based mechanism for improved RPC timeout handling
US20030202510A1 (en)2002-04-262003-10-30Maxxan Systems, Inc.System and method for scalable switch fabric for computer network
US20030204611A1 (en)2002-04-292003-10-30Mccosh John C.Communications tester and method of using same
US20050144199A2 (en)2002-05-312005-06-30Lefthand Networks, Inc.Distributed Network Storage System With Virtualization
US6732171B2 (en)2002-05-312004-05-04Lefthand Networks, Inc.Distributed network storage system with virtualization
US7254620B2 (en)2002-06-032007-08-07Hitachi, Ltd.Storage system
US7421736B2 (en)2002-07-022008-09-02Lucent Technologies Inc.Method and apparatus for enabling peer-to-peer virtual private network (P2P-VPN) services in VPN-enabled network
US7111303B2 (en)2002-07-162006-09-19International Business Machines CorporationVirtual machine operating system LAN
JP2004054562A (en)2002-07-192004-02-19Nec CorpMethod of controlling input and output for network file system
JP2004056728A (en)2002-07-242004-02-19Hitachi Ltd Switching node device for storage network and access method of remote storage device
US7263108B2 (en)2002-08-062007-08-28Netxen, Inc.Dual-mode network storage systems and methods
US6741554B2 (en)2002-08-162004-05-25Motorola Inc.Method and apparatus for reliably communicating information packets in a wireless communication network
US20040047367A1 (en)2002-09-052004-03-11Litchfield Communications, Inc.Method and system for optimizing the size of a variable buffer
WO2004025477A2 (en)2002-09-162004-03-25Level 5 Networks LimitedNetwork interface and protocol supporting mappings of virtual memory locations at different processing devices
US7475124B2 (en)2002-09-252009-01-06Emc CorporationNetwork block services for client access of network-attached data storage in an IP network
US7243144B2 (en)2002-09-262007-07-10Hitachi, Ltd.Integrated topology management method for storage and IP networks
US7428584B2 (en)2002-10-072008-09-23Hitachi, Ltd.Method for managing a network including a storage system
US7152069B1 (en)2002-10-152006-12-19Network Appliance, Inc.Zero copy writes through use of mbufs
US20040078465A1 (en)2002-10-172004-04-22Coates Joshua L.Methods and apparatus for load balancing storage nodes in a distributed stroage area network system
US20040148380A1 (en)2002-10-282004-07-29Richard MeyerMethod and system for dynamic expansion and contraction of nodes in a storage area network
US7120666B2 (en)2002-10-302006-10-10Riverbed Technology, Inc.Transaction accelerator for client-server communication systems
US20040088293A1 (en)2002-10-312004-05-06Jeremy DaggettMethod and apparatus for providing aggregate object identifiers
US7599342B2 (en)2002-11-122009-10-06Charles FrankMultiplexing storage element interface
US7742473B2 (en)2002-11-122010-06-22Mark AdamsAccelerator module
US20060126666A1 (en)2002-11-122006-06-15Charles FrankLow level storage protocols, systems and methods
WO2004045149A1 (en)2002-11-122004-05-27Zetera CorporationCommunication protocols, systems and methods
WO2004044753A1 (en)2002-11-122004-05-27Zetera CorporationData storage devices having ip capable partitions
US7698526B2 (en)2002-11-122010-04-13Charles FrankAdapted disk drives executing instructions for I/O command processing
WO2004044732A1 (en)2002-11-122004-05-27Zetera CorporationElectrical devices with improved communication
US20060182107A1 (en)2002-11-122006-08-17Zetera CorporationElectrical devices with improved communication
US7688814B2 (en)2002-11-122010-03-30Charles FrankMethods of conveying information using fixed sized packets
US8005918B2 (en)2002-11-122011-08-23Rateze Remote Mgmt. L.L.C.Data storage devices having IP capable partitions
US7649880B2 (en)2002-11-122010-01-19Mark AdamsSystems and methods for deriving storage area commands
US20060101130A1 (en)2002-11-122006-05-11Mark AdamsSystems and methods for deriving storage area commands
US20060253543A1 (en)2002-11-122006-11-09Zetera CorporationProviding redundancy for a device within a network
US7643476B2 (en)2002-11-122010-01-05Charles FrankCommunication protocols, systems and methods
US7602773B2 (en)2002-11-122009-10-13Charles FrankTransferring data to a target device
US20040170175A1 (en)2002-11-122004-09-02Charles FrankCommunication protocols, systems and methods
US7720058B2 (en)2002-11-122010-05-18Charles FrankProtocol adapter for electromagnetic device elements
US20040213226A1 (en)2002-11-122004-10-28Charles FrankCommunication protocols, systems and methods
US20060026257A1 (en)2002-11-122006-02-02Zetera CorporationLegacy storage device adapter
US7916727B2 (en)2002-11-122011-03-29Rateze Remote Mgmt. L.L.C.Low level storage protocols, systems and methods
US7870271B2 (en)2002-11-122011-01-11Charles FrankDisk drive partitioning methods and apparatus
US7882252B2 (en)2002-11-122011-02-01Charles FrankProviding redundancy for a device within a network
US20040215688A1 (en)*2002-11-122004-10-28Charles FrankData storage devices having ip capable partitions
US7184424B2 (en)2002-11-122007-02-27Zetera CorporationMultiplexing storage element interface
US20060029070A1 (en)2002-11-122006-02-09Zetera CorporationProtocol adapter for electromagnetic device elements
US8473578B2 (en)2002-11-122013-06-25Rateze Remote Mgmt, L.L.C.Data storage devices having IP capable partitions
US20060029068A1 (en)2002-11-122006-02-09Zetera CorporationMethods of conveying information using fixed sized packets
US8694640B2 (en)2002-11-122014-04-08Rateze Remote Mgmt. L.L.C.Low level storage protocols, systems and methods
US20060029069A1 (en)2002-11-122006-02-09Zetera CorporationAdapated disk drives executing instructions for I/O command processing
US7327735B2 (en)2002-11-272008-02-05Alcatel Canada Inc.System and method for detecting lost messages transmitted between modules in a communication device
US7170890B2 (en)2002-12-162007-01-30Zetera CorporationElectrical devices with improved communication
US20040160975A1 (en)2003-01-212004-08-19Charles FrankMulticast communication protocols, systems and methods
US20040162914A1 (en)2003-02-132004-08-19Sun Microsystems, Inc.System and method of extending virtual address resolution for mapping networks
US20040181476A1 (en)*2003-03-132004-09-16Smith William R.Dynamic network resource brokering
US20040184455A1 (en)2003-03-192004-09-23Institute For Information IndustrySystem and method used by a gateway for processing fragmented IP packets from a private network
CN1532723A (en)2003-03-212004-09-29ض�Polymerization of service registraion form
US7181521B2 (en)2003-03-212007-02-20Intel CorporationMethod and system for selecting a local registry master from among networked mobile devices based at least in part on abilities of the mobile devices
US6904470B1 (en)2003-03-262005-06-07Emc CorporationDevice selection by a disk adapter scheduler
US20050058131A1 (en)2003-07-292005-03-17Samuels Allen R.Wavefront detection and disambiguation of acknowledgments
US20050044199A1 (en)2003-08-062005-02-24Kenta ShigaStorage network management system and method
US20060126118A1 (en)2003-08-132006-06-15Fujitsu LimitedPrint control method, print control apparatus, and computer product
WO2005017738A1 (en)2003-08-132005-02-24Fujitsu LimitedPrint control method, print controller and print control program
US7415018B2 (en)2003-09-172008-08-19Alcatel LucentIP Time to Live (TTL) field used as a covert channel
US7526577B2 (en)2003-09-192009-04-28Microsoft CorporationMultiple offload of network state objects with support for failover events
US20080279106A1 (en)2003-10-032008-11-133Com CorporationSwitching fabrics and control protocols for them
US7436789B2 (en)2003-10-092008-10-14Sarnoff CorporationAd Hoc wireless node and network
US20050102522A1 (en)2003-11-122005-05-12Akitsugu KandaAuthentication device and computer system
US20050138003A1 (en)2003-12-182005-06-23Andrew GloverSystem and method for database having relational node structure
WO2005072179A2 (en)2004-01-212005-08-11Zetera CorporationMulticast protocol for a redundant array of storage areas
US20050166022A1 (en)*2004-01-282005-07-28Hitachi, Ltd.Method and apparatus for copying and backup in storage systems
US20070110047A1 (en)*2004-01-302007-05-17Sun-Kwon KimMethod of collecting and searching for access route of information resource on internet and computer readable medium stored thereon program for implementing the same
US20050198371A1 (en)2004-02-192005-09-08Smith Michael R.Interface bundles in virtual network devices
US7447209B2 (en)2004-03-092008-11-04The University Of North CarolinaMethods, systems, and computer program products for modeling and simulating application-level traffic characteristics in a network based on transport and network layer header information
JP2005265914A (en)2004-03-162005-09-29Ricoh Co Ltd Zoom lens, camera, and portable information terminal device
US20050246401A1 (en)2004-04-302005-11-03Edwards John KExtension of write anywhere file system layout
US20050259646A1 (en)2004-05-192005-11-24Smith Michael RVirtual network device clusters
US20050267929A1 (en)*2004-06-012005-12-01Hitachi, Ltd.Method of dynamically balancing workload of a storage system
US20050270856A1 (en)2004-06-032005-12-08Inphase Technologies, Inc.Multi-level format for information storage
US20050286517A1 (en)2004-06-292005-12-29Babbar Uppinder SFiltering and routing of fragmented datagrams in a data network
US20060036602A1 (en)2004-08-132006-02-16Unangst Marc JDistributed object-based storage system that stores virtualization maps in object attributes
US20060045089A1 (en)2004-08-272006-03-02International Business Machines CorporationMethod and apparatus for providing network virtualization
US20060077902A1 (en)2004-10-082006-04-13Kannan Naresh KMethods and apparatus for non-intrusive measurement of delay variation of data traffic on communication networks
US7536525B2 (en)2004-11-092009-05-19Dell Products L.P.Virtual machine hot cloning including freezing and unfreezing memory in a distributed network
US20060133365A1 (en)2004-12-162006-06-22Shankar ManjunathaMethod, system and article for improved network performance by avoiding IP-ID wrap-arounds causing data corruption on fast networks
US7742454B2 (en)2004-12-162010-06-22International Business Machines CorporationNetwork performance by dynamically setting a reassembly timer based on network interface
US20060168345A1 (en)*2005-01-212006-07-27Microsoft CorporationResource identifier zone translation
US20070230476A1 (en)2005-02-042007-10-04Huawei Technologies Co., Ltd.Method for Information Transmission
US7702850B2 (en)2005-03-142010-04-20Thomas Earl LudwigTopology independent storage arrays and methods
WO2006098753A1 (en)2005-03-142006-09-21Zetera CorporationTopology independent storage arrays and methods
US20060206662A1 (en)2005-03-142006-09-14Ludwig Thomas ETopology independent storage arrays and methods
US20080181158A1 (en)2005-03-242008-07-31Nokia CorporationNotification of a Receiving Device About a Forthcoming Transmission Session
US20060272015A1 (en)2005-05-262006-11-30Frank Charles WVirtual devices and virtual bus tunnels, modules and methods
US7620981B2 (en)2005-05-262009-11-17Charles William FrankVirtual devices and virtual bus tunnels, modules and methods
US8726363B2 (en)2005-05-262014-05-13Rateze Remote Mgmt, L.L.C.Information packet communication with virtual objects
US8387132B2 (en)2005-05-262013-02-26Rateze Remote Mgmt. L.L.C.Information packet communication with virtual objects
WO2006127013A1 (en)2005-05-262006-11-30Zetera CorporationVirtual devices and virtual bus tunnels, modules and methods
WO2007021289A1 (en)2005-08-162007-02-22Zetera CorporationDisaggregated resources and access methods
US7743214B2 (en)2005-08-162010-06-22Mark AdamsGenerating storage system commands
US20070168396A1 (en)2005-08-162007-07-19Zetera CorporationGenerating storage system commands
US20070043771A1 (en)2005-08-162007-02-22Ludwig Thomas EDisaggregated resources and access methods
US8819092B2 (en)2005-08-162014-08-26Rateze Remote Mgmt. L.L.C.Disaggregated resources and access methods
WO2007043999A1 (en)2005-10-062007-04-19Zetera CorporationResource command messages and methods
US20070083662A1 (en)2005-10-062007-04-12Zetera CorporationResource command messages and methods
US20070101023A1 (en)2005-10-282007-05-03Microsoft CorporationMultiple task offload to a peripheral device
US20070147347A1 (en)2005-12-222007-06-28Ristock Herbert W ASystem and methods for locating and acquisitioning a service connection via request broadcasting over a data packet network
WO2007120685A2 (en)2006-04-102007-10-25Zetera CorporationMethods of resolving datagram corruption over an internetworking protocol
US20070237157A1 (en)2006-04-102007-10-11Zetera CorporationMethods of resolving datagram corruption over an internetworking protocol
US7924881B2 (en)2006-04-102011-04-12Rateze Remote Mgmt. L.L.C.Datagram identifier management
WO2007149563A2 (en)2006-06-202007-12-27Rateze Remote Mgmt. L.L.C.Generating storage system commands

Non-Patent Citations (52)

* Cited by examiner, † Cited by third party
Title
"LIMITED DISTRIBUTED DASD CHECKSUM, A RAID HYBRID.", IBM TECHNICAL DISCLOSURE BULLETIN, INTERNATIONAL BUSINESS MACHINES CORP. (THORNWOOD), US, vol. 35., no. 04A., 1 September 1992 (1992-09-01), US , pages 404 - 405., XP000314813, ISSN: 0018-8689
"Computer Networking Essentials" Copyright 2001, Cisco Systems, Inc., 2001.
"Limited distributed DASD Checksum, a RAID Hybrid" IBM Technical Disclosure Bulletin, vol. 35, No. 4a, Sep. 1992, pp. 404-405, XP000314813 Armonk, NY, USA.
Anderson, et al., "Serverless Network File Systems," In Proceedings of the 15th Symposium on Operating Systems Principles, Dec. 1995.
Beck, Micah, et al., An End-to-End Approach for Globally Scalable network Storage, ACM SIGCOMM Computer Communication Review; vol. 32, Issue 4, Proceedings of the 2002 SIGCOMM Conference; pp. 339-346; Oct. 2002.
Bruschi and Rosti, "Secure multicast in wireless networks of mobile hosts: protocols and issues", Mobile Networks and Applications, vol. 7, issue 6 (Dec. 2002), pp. 503-511.
Bruschi, et al., "Secure multicast in wireless networks of mobile hosts: protocols and issues", Mobile Networks and Applications, vol. 7, issue 6 (Dec. 2002), pp. 503-511.
CHAVEZ A ET AL: "Challenger: a multi-agent system for distributed resource allocation", PROCEEDINGS OF THE FIRST INTERNATIONAL CONFERENCE ON AUTONOMOUS AGENTS MARINA DEL REY, CA., FEB. 5 - 8, 1997., NEW YORK, ACM., US, vol. CONF. 1, 5 February 1997 (1997-02-05), US , pages 323 - 332., XP002092534, ISBN: 978-0-89791-877-0, DOI: 10.1145/267658.267736
Chavez, A Multi-Agent System for Distributed Resource Allocation, MIT Media Lab, XP-002092534, Int'l Conference on Autonomous Agents, Proceedings of the First Int'l Conference on Autonomous Agents, Marina del Rey, California, US, Year of Publication: 1997.
Chavez, A Multi-Agent System for Distributed Resource Allocation, MIT Media Lab, XP-002092534.
Cisco Systems, "Computer Networking Essentials," Copyright 2001.
Dean and Ghemawat; MapReduce: Simplified Data Processing on Large Clusters; OSDI'04: Sixth Symposium on Operating System Design and Implementaion, San Francisco, CA (2004), pp. 137-150; downloaded Jul. 2021 from research.google/pubs/pub62.
Dean and Ghemawat; MapReduce:Simplified Data Processing on Large Clusters HTML Slides; 2004; 32 pages; downloaded Jul. 2021 from research.google/pubs/pub62 and research.google.com/archive/mapreduce-osdi04-slides/index.html.
E K. Lee, et al., "Petal: Distributed Virtual Disks," 7th International Conference on Architectural Support for Programming Languages and Operation Systems, 7 ed., ASPLOS (US), p. 84-92, (Oct. 1, 1996).
E. K. Lee, et al., "A Comparison of Two Distributed Disk Systems," SRC—Reserach Report, Systems Reserch Center (Palo Alto, US), p. all, (Apr. 30, 1998).
Ghemawat, Gobioff, and Leung; The Google File System; Proceedings of the 19th ACM Symposium on Operating Systems Principles, ACM, Bolton Landing, NY (2003), pp. 20-43; downloaded Jul. 2021 from research.google/pubs/pub51.
Gibson, Garth; A Cost Effective High-Bandwidth Storage Architecture; ACM SIGOPS Operating Systems Review, Col. 32, issue 5, pp. 92-103; 1998.
Gibson, Garth; File Server Scaling with Network-Attached Secure Disks; Joint Int'l Conference on Measurement & Modeling of Computer Systems Proceedings of the 1997 ACM SIGMETRICS Int'l Conference on Measurement & Modeling of Computer Systems; pp. 272-284; 1997.
IBM Technical Disclosure Bulletin, Vo. 35, No. 4a, pp. 404-405, XP000314813, Armonk, NY, USA, Sep. 1992.
International Preliminary Report on Patentability, issued in PCT Patent Application No. PCT/US2005/036022, dated Feb. 20, 2008, 8 pages.
International Search Report and Written Opinion, issued in PCT Patent Application No. PCT/US2005/036022, dated Mar. 3, 2006, 10 pages.
International Search Report and Written Opinion, issued in PCT Patent Application No. PCT/US2005/036022, mailed Mar. 3, 2006, 10 pages.
International Search Report for Application No. PCT/US02/40205 dated May 12, 2003.
International Search Report for Application No. PCT/US02/40205 dated May 27, 2004.
International Search Report for Application. No. PCTUS05/01542 dated Aug. 25, 2008.
J. Satran, et al., "Internet Small Computer Systems Interface (ISCSI)," Memo, The Internet Society, p. all, (Apr. 1, 2004).
Ki-Il Kim et al., "Internet Multicast Provisioning Issues for Hierarchical Architecture", 2001, IEEE.
Kim et al., "Internet Multicast Provisioning Issues for Hierarchical Architecture", Dept of Computer Science, Chung-Nam National University, Daejeon, Korea, Ninth IEEE International Conference, pp. 401- 404., IEEE, published Oct. 12, 2001.
Kim et al., "Internet multicast provisioning issues for hierarchical architecture", Networks, 2001, Proceedings, Ninth IEEE International Conference, published Oct. 12, 2001, pp. 401-404.
Lee and Thekkath, "Petal: Distributed Virtual Disks", Systems Research Center.
LEE E K ET AL: "A Comparison of Two Distributed Disk Systems", SRC RESEARCH REPORT., XX, XX, 30 April 1998 (1998-04-30), XX , pages complete, XP002368118
LEE E. K., THEKKATH C. A.: "PETAL: DISTRIBUTED VIRTUAL DISKS.", 7TH. INTERNATIONAL CONFERENCE ON ARCHITECTURAL SUPPORT FOR PROGRAMMING LANGUAGES AND OPERATION SYSTEMS. CAMBRIDGE, MA., OCT. 1 - 5, 1996., NEW YORK, ACM., US, vol. CONF. 7, 1 October 1996 (1996-10-01), US , pages 84 - 92., XP000681711, ISBN: 978-0-89791-767-4, DOI: 10.1145/237090.237157
Lee et al. "A Comparison of Two Distributed Disk Systems" Digital Systems Research Center—Research Report SRC-155, Apr. 30, 1998, XP002368118.
Lee et al. "Petal: Distributed Virtual Disks", 7th International Conference on Architectural Support for Programming Languages and Operation Systems. Cambridge, MA., Oct. 1-5, 1996. International Conference on Architectural Support for Programming Languages and Operation Systems (ASPLOS), New, Vol. Conf. 7, Oct. 1, 1996, pp. 84-92, XP000681711, ISBN: 0-89791-767-7.
Lee, et al. "Petal: Distributed Virtual Disks", 7th International Conference on Architectural Support for Programming Languages and Operation Systems. Cambridge, MA., Oct. 1-5, 1996. International Conference on Architectural Support for Programming Languages and Operation Systems (ASPLOS), New, vol. Conf. 7, pp. 84-92, XP000681711, ISBN: 0-89791-767-7, Oct. 1, 1996.
Lin, et al., "RMTP: A Reliable Multicast Transport Protocol," Proceedings of IEEE INFOCOM '96, vol. 3, pp. 1414-1424, 1996.
Listing of Related Cases, dated Jan. 28, 2020, Schwabe Williamson & Wyatt, 2 pages.
Listing of Related Cases, dated Oct. 30, 2017, Schwabe Williamson & Wyatt, 3 pages.
PCT International Search Report for PCT App. No. PCTUS05/01542 dated Aug. 25, 2008.
Quinn, et al., "IP Multicast Applications: Challenges and Solutions," Network Working Group, RFC 3170, Sep. 2001.
Robinson, Chad; A Guide to Virtual Services; Linux Journal, vol. 1997 Issue 35; Mar. 1997.
Satran et al. "Internet Small Computer Systems Interface (iSCSI)" IETF Standard, Internet Engineering Task Force, IETF, CH, Apr. 2004, XP015009500, ISSN: 000-0003.
Satran et al. "Internet Small Computer Systems Interface (iSCSI)" IETF Standard, Internet Engineering Task Force, IETF, CH, XP015009500, ISSN: 000-0003, Apr. 2004.
Satran et al., "Internet Small Computer Systems Interface (iSCSI)" Internet Draft draft-ietf-ips-iscsi-19.txt, Nov. 3, 2002.
Satran et al., iSCSI, Internet Draft draft-ietf-ips-iscsi-19.txt.
Thomas E. Anderson, Michael D. Dahlin, Jeanna M. Neefe, David A. Patterson, Drew S. Roselli, and Randolph Y. Wang, Serverless network file systems. Dec. 1995. In Proceedings of the 15th Symposium on Operating Systems Principles.
Virtual Web mini-HOWTO; Parag Mehta; www.faqs.or/docs/Linux-mini/Virtual-Web.html; Jun. 6, 2001.
VMWARE INC.: "Vmware workstation user manual", USER'S MANUAL VMWARE WORKSTATION, XX, XX, no. VERSION 3.2, 5 September 2002 (2002-09-05), XX , pages 1 - 420, XP002443319
VMWare Workstation User's Manual, VMWare, Inc., p. 1-420, XP002443319; www.vmware.com/pdf/ms32_manual.pdf; p. 18-21; p. 214-216; p. 273-282; copyright 1998-2002.
VMWare Workstations User's Manual, Version 3.2, VMWare, Inc., Copyright 1998-2002.
WebTen User's Guide; Version 3.0, Jan. 2000; http://www.tenan.com/products/webten/WebTenUserGuide/1_Introduction.html; Jan. 2000.
WebTen User's Guide; Version 7.0; http://www.tenon.com/products/webten/WebTenUserGuide/8_VirtualHosts.html, Chapter 8; Mar. 2008.

Also Published As

Publication numberPublication date
US20070043771A1 (en)2007-02-22
WO2007021289A1 (en)2007-02-22
USRE47411E1 (en)2019-05-28
US8819092B2 (en)2014-08-26

Similar Documents

PublicationPublication DateTitle
USRE48894E1 (en)Disaggregated resources and access methods
US7620981B2 (en)Virtual devices and virtual bus tunnels, modules and methods
US9787780B1 (en)Method and apparatus for web based storage on-demand
US7827317B2 (en)Apparatus for management of mixed protocol storage networks
US20070112931A1 (en)Scsi-based storage area network having a scsi router that routes traffic between scsi and ip networks
US20090222509A1 (en)System and Method for Sharing Storage Devices over a Network
US20040098458A1 (en)Distributed computing infrastructure including multiple collaborative sessions
US20100125857A1 (en)Cluster control protocol
US10855515B2 (en)Implementing switchover operations between computing nodes
US20140229695A1 (en)Systems and methods for backup in scale-out storage clusters
US8924513B2 (en)Storage system
US9602600B1 (en)Method and apparatus for web based storage on-demand
US20040139194A1 (en)System and method of measuring and monitoring network services availablility
US9432329B2 (en)Network address assignment with duplication detection
US9674312B2 (en)Dynamic protocol selection
US7003589B2 (en)Method and arrangement for generating unique identifiers for logical units of SCSI devices
US10200462B2 (en)Memory system including plurality of server nodes sharing storage array and operating method of memory system
US7627650B2 (en)Short-cut response for distributed services
JP4640335B2 (en) Data storage system
US20190037013A1 (en)Methods for managing workload throughput in a storage system and devices thereof
CN214202379U (en)Distributed shared file system
van Renesse et al.Autonomic computing: A system-wide perspective
US10768834B2 (en)Methods for managing group objects with different service level objectives for an application and devices thereof
US7539711B1 (en)Streaming video data with fast-forward and no-fast-forward portions
US20200068042A1 (en)Methods for managing workloads in a storage system and devices thereof

Legal Events

DateCodeTitleDescription
ASAssignment

Owner name:RATEZE REMOTE MGMT. L.L.C., DELAWARE

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ZETERA CORPORATION;REEL/FRAME:049282/0542

Effective date:20080415

FEPPFee payment procedure

Free format text:ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

MAFPMaintenance fee payment

Free format text:PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment:8

CCCertificate of correction
ASAssignment

Owner name:INTELLECTUAL VENTURES I LLC, DELAWARE

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:RATEZE REMOTE MGMT. L.L.C.;REEL/FRAME:070416/0142

Effective date:20250305


[8]ページ先頭

©2009-2025 Movatter.jp