The present invention relates to the effective simultaneous transfer of data in a multicast broadcast across a data bus to at least two data storage elements, and the managing of that data relative to the transfer. In particular, the invention relates to an apparatus and method, in a system that contains at least two storage elements, for transferring as well as managing data to multiple storage elements, where that management is to achieve some specific purpose or goal.
Methods for transmitting data over a network from a source to multiple end-points are well known. Typical examples of such transfers are broadcast, unicast, dualcast, multicast, peer-to-peer, and peer-to-peer multicast.
A commonly accepted verbatim definition of multicast, found on websites belonging to Microsoft, Cisco, EMC, Wikipedia, two issued patents (U.S. Pat. No. 7,378,960 & U.S. Pat. No. 7,541,913), one pending (20090121929) patent application, scores of blogs and other websites totaling 63 different websites is,
Although usage in a network is more popular, the inventors of the present invention recognize that the scope of multicast has been pushed past the limitation of a network, in the above definition, to also include the environment of a bus based system.
In issued U.S. Pat. No. 5,720,027 Sarkozy demonstrated this by the use of multicast in a bus based system where the end unit was first armed, and then a multicast transmission was made over the bus and only the so-called targeted or armed devices acted on that transmission. This was done to shorten aggregate data transfer times.
There is strong motivation to arrange data transfers in such a simultaneous or near simultaneous fashion. On most systems, which employ multiple storage elements, one of the most time consuming events, after the mechanical delays of drives, is the serial transmission of data transfers to multiple devices. The need for these duplicate transmissions might be for data redundancy, or replication purposes, or RAID parity calculation reasons, to cite just a few examples.
A method which reduces the number of data transfers required to accomplish a storage command is very valuable and improves overall performance dramatically. The larger the amount of data to be moved, the longer it takes to transfer, and the larger the corresponding time savings. The more drive elements involved, the greater the opportunity for time savings. Harvesting these time savings boosts data transfer time dramatically.
The inventors recognize that the prior art, although showing the way to achieve simultaneous data transfers across a system data bus, neither provides for nor suggests any way or method to manage the content of those transfers.
The prior art treats these data transfers as a node level transfer, treating the end unit as a holistic, self managing, macro type device.
It is the object of the present invention to provide an improved apparatus and method for managing multicast data transfers by adding the steps of providing for increased management of the data being transferred. This applies to both bus based and non bus based multicast systems. The purposes of managing these multicast transfers might include, but not be limited to, providing temporary data redundancy operations, encryption operations, audit control operations, data search operations, access control operations, archive operations, replication operations, or the like.
It is a further object of the present invention to provide an improved apparatus and method for managing multicast data transfers by adding the steps of providing for increased management of some process or stored data where the management function does not act upon the contents of the data being transferred, but acts in result of the transfer itself. An example of this, discussed below, would be the invocation of an alarm condition caused by accessing a specific storage address.
It is a further object of the present invention to provide an improved apparatus and method for multicast data transfers by transmitting those transfers over at least two interconnected busses.
It is a further object of the present invention to provide an improved apparatus and method for managing multicast data transfers over interconnected buses.
Consequently, we define, multicast Management or to Manage a multicast transfer as (“Management”) occurring in the context of a multicast data transfer where as a direct result of the transfer either the content of the data transferred is altered; manipulated; scheduled for some purpose, for example, archiving, deletion, virtualization; indexed for some purpose, for example, future search, data reduction purposes; flagged for some purpose, for example, an audit trail, special monitoring; encrypted; decrypted, logged for some purpose, for example, access control; or the act of transfer to a specific predefined address initiates some specific response or action, for example, alarm function or any of the actions itemized in this paragraph.
Recall that in U.S. Pat. No. 5,720,027 Sarkozy, the end point of the multicast transfer was not just an unintelligent disk drive—if there is such a thing, but rather a controller board which then attached to multiple disk drives. Accordingly, we define a storage element, (“Storage Element”) as a device (i) powered by electricity, or some other means, (ii) containing provision for data storage of any kind, (iii) with at least one data interface, (iv) including at least some processing intelligence, and (v) may include substantial processing and communication capabilities. A Storage Element is a good example of a data bus addressable device (Addressable Device”) where such a device is attached to a data bus and directly addressable by some kind of commands over that bus.
Three different examples conforming to the definition of such a Storage Element includes (1) a SCSI disk drive with an on board capability to store and execute a driver; (2) a bus based board with data processing capability with either one or more data storage devices on the board itself, or which externally connects to one or more data storage devices; or (3) a more complex system, perhaps even a stand alone server, at least operating to emulate a multicast end point as described in (1) or (2).
Note that within the multicast managed system shown in
Note also that the dashed box 516 may repeat across the bus multiple times, that is connected to the bus there may be multiple 516 boxes corresponding to multiple controller boards with associated drives.
In an embodiment of the invention, a driver or program executing within the Storage Element interfaces with a host interface intelligence. These two independently functioning resources operate in a common understanding to do more than just WRITE and READ data. They operate across a common specification to manage the data that is stored for a specific purpose, for example data encryption or decryption, or redundant copy management.
The features and advantages of the present invention will become apparent to those skilled in the art from the following description with reference to the drawings, in which:
One major aspect of the present invention is an ability to manage multicast data to achieve temporary data redundancy benefits. Consider the situation where data files from a satellite burst are coming from overhead and necessitate the WRITE of very large files quickly. This data must be written with additional redundancy as a WRITE failure will cause a data loss. Three copies are required and after 1 hour, when the data has been processed, two may be removed. In this example, consider that the Storage Elements are represented as depicted in
A prior art solution, must arrange these very large WRITEs in series with idle time for the other drives. As they are large WRITEs they will overrun system cache and cause the throughput to slow down.
A method of intelligent control, (Method of Intelligent Control) is defined between the host controller and the Storage Element as some unambiguous predefined common communication. The use of a specific syntax as a Method of Intelligent Control is a simple example.
Other examples might be where the Storage Elements may have one or more predefined conditions to which they are programmed to act to some multicast transfer. Access to a specific address, for example, may invoke some security change, such as the invocation (a READ to that address) of an alarm condition, the de-invocation of an alarm condition (WRITE to that address), or the need to use one of multiple pre-stored different encryption keys, for example, by accessing the address associated with the desired key.
In such a practice, a wide range of multicast managed responses could be imagined and implemented in a system, of the present invention with Storage Elements, all without a need to change any existing command syntax of the host controller. All necessary information could be contained by the use of specially designated addresses, and the predefined context associated with those addresses, and optionally, the data written or read to or from those addresses.
Note also, that even though a multicast transfer is going to multiple Storage Elements, that each Storage Element may be configured to result in a different behavior. For example, different encryption keys might be stored in the same address of different Storage Elements, and one access of the address associated with the desired management function, could result in loading different keys for each of the different Storage Elements.
In the interest of clarity, the examples used in this specification will use syntax commands as a Method of Intelligent Control, although it is clearly stated that the present invention is not limited to the use of syntax.
In the present example, a simple syntax command was used to manage each Storage Element as to where to store the large file, whether the storage was permanent or temporary, and if temporary, how long to retain the data. Those skilled in the art can imagine several different syntax examples to achieve this. Our example is as follows.
The drivers in Storage Elements D0, D2, & D3 are intelligent enough to recognize and act on only the control information associated with their drive designation, and to understand whether they accept a WRITE as permanent, or temporary for a fixed time. When the specified temporary time expires, Storage Elements D2 & D3 are free to allocate the corresponding location and size as free space. The specific drives may thus allocate bad blocks and sector re-allocations to that released space.
Another major aspect of the present invention is an ability to use multicast data to better manage the process of keeping a primary copy, a secondary copy, a backup copy, an archive copy, and metadata about the data being stored. In this example, consider that the Storage Elements are represented as depicted in
Now consider a host system connected to multiple Storage Elements as described. Our host system, in this example, wants to maintain a primary copy, a secondary copy, a backup copy, an archive copy, and metadata about the data being stored.
For this example we assume that the length of a single time period is sufficient to transfer an entire copy of the file to be Written. Note that making all 5 transfers takes 5 full time periods.
Once again, those skilled in the art can imagine their own syntax examples to achieve this. Our example is as follows.
Note that according to the above syntax, the data is not to be actually written, at this time, for either the Archive unit, D3, or the MetaData unit, D4. Some System Administrators may choose to WRITE an Archive copy, but in this example we did not. We recorded that host request, in the syntax, that D3 is the Archive location for this transfer, and that no action be taken for 90 days. In the Archive scheduler on subsystem D3, it will record the authorization number and archive period and 90 days from this date/time it will read the Metadata for this transfer and see if there has been any access to the Primary subsystem for this file. If so, it will reset the timer for 90 days from the point of last access. If not, it will initiate a copy of the file, and after the file has been copied, it will alert the Primary that it should virtualize the Primary copy and direct a pointer to the Archive location where the file is now be located.
The authorization number is suggested to be a host assigned monotonically increasing number. Each transfer practicing this invention uses a common authorization number across that transfer. It can be used to identify a common transfer across the subsystem Storage Elements. It can also be used to index into a Metadata database concerning the control transfer information (that is the data used in the syntax command which governs a specific transfer) and which includes the date and time of the issued command. The first half of the authorization number is the date/time number as issued by the host.
Note that by including the role of the subsystem Storage Element (eg: Primary, Secondary Copy, Backup, Archive, Metadata) the host system may actually alter the role of subsystem Storage Element on a file Write by file Write basis. Thus the same subsystem Storage Element may play the role of a primary storage for one transfer and also play the roles of secondary copy in a separate transfer. This may be desirable under some circumstances.
However, the Metadata subsystem does not vary from transaction to transaction. It always remains the same.
Another major aspect of the present invention is an ability to manage a multicast transfer operation and act upon a decryption/encryption instruction.
Consider the managed multicast system shown in
Further suppose that the data security requirements are to encrypt it prior to storage with a different encryption key for each Storage Element.
Once again, those skilled in the art can imagine their own syntax examples to achieve this. Our example is as follows. For the case where we need to send the same information to Storage Elements D2 and D3, as well as main memory, and where we use a well known public key/private key crypto scheme where the private key has been previously stored on the various Drive Elements and stored there in some non-obvious fashion, like by partitioning the key into multiple parts and relying on operational code to reassemble it.
This would enable the processing capability on the different Drive Elements to encrypt the data to be stored using the private and public keys within each drive element. The inventors note that there is always a tradeoff between performance and security. If the performance requirement would not allow a public key/private key encryption system a less rigorous encryption could be used.
In a communication process such as this, host interface board 510 in
Nothing in this specification should be understood to limit the present invention to the required use of a specific example of a managed multicast example provided in this specification . These examples are discussion points of general method and approach to use managed multicast to improve data transfers. Other possible managed multicast objectives might search functions, data de-dup functions, access control functions, for example.
Nothing in this specification should be understood to limit this invention to the use of syntax, or the use of associating actions with specific addresses as examples of a Method of Intelligent Control. Other Methods of Intelligent Control might be used for example, writing the action name desired and the parameters of various associated actions to some common address point and then decoding that data for subsequent action.
The discussion above has shown a process for reducing the number of data transfers by practicing Managed multicast on the internal bus, and we have seen how, in addition to potentially improving throughput, Managed multicast can achieve other desirable goals.
The inventors of the present invention recognize that it is possible to further improve on reducing the number of data transfers by interconnecting the internal buses of the different systems and multicasting across this interconnection. For clarity, the method of interconnecting the buses is not claimed as part of the present invention, but for example we could connect buses via an external PCI Express bridge adapter, now available commercially, or using a wireless PCI Express extension adapter.
The root phrase interconnect, or interconnection, or interconnected, (“Interconnected”) is defined as an electronic interface between two different data buses so that data commands and transfers can travel from the data bus of one subsystem to the data bus of a second subsystem and be acted upon. It is expected, that the data buses of the two subsystems are of the same type, but not necessarily manufacture, so that no protocol conversion is required to adapt one data bus to the other, but rather that they are connected in the sense of a bus extender. The different subsystems (“Subsystems”) may be similar or dissimilar, and they may have different components, but they must have data buses of the same type as discussed above. For example, in
Significantly, this practice of Interconnection introduces the ability to share node resources, such as memory and or controllers resources, which might be installed on the different storage nodes. This is a powerful benefit in terms of both performance and reliability.
By providing this Interconnect measure of addressing additional resources, the Storage Cluster can operate in a more powerful configuration improving performance as well as reliability. Reliability is improved by this opening up of multiple data paths, adapters, memory banks, and controllers. In total, this change provides for an improved method of clustering storage appliances or systems.
In the example of the storage platform, each node has a fibre channel host adaptor 605, main memory 608 & 614, at least one processor 609 & 615, and two or more RAID controllers 606 and 607 & 612 and 613. A bus extender 604 is used to Interconnect the two data busses. In this example, adaptor board 605 is an example of a communicating initiator, (“Communicating Initiator”) where such a device, in response to an external source or event or internal/external condition, initiates a communication to one or more target devices addressable over either the native or extended data bus.
This method of data transfers being multicast across multiple data bus Interconnections, results in reducing the total number of data transfers. In addition, any of the nodes Interconnected in the cluster are addressable and therefore candidates for usage.
By Interconnecting several systems using the internal bus and an adaptor as discussed above, the present invention can accomplish a cluster of systems that can share the resources that are attached to every local node machine. It is especially important and powerful when memories are shared in this way, because the total amount of memory across all the systems will result in a huge cache memory pool that any node can access. This not only improves on fault tolerance connections but also dramatically increases performance by making it possible to use any or multiple nodes to serve a particular client request.
An examination of
Prior art storage systems are connected via communication networks such as TCP/IP or InfiniBand. These networks add additional overhead, cost and complexity to any cluster configuration.
A second method of directing a multicast transfer across multiple data busses can be achieved by applying multicast at the communication level as well as at the Interconnected bus level. This will provide a second method of Interconnection, disclosed by the present invention, providing an even higher degree of Fault Tolerance. In this approach the initiator host adaptor will generate the multicast to multiple nodes directly, which all get the same data to improve on cache availability. Because the overall cluster cache will be the sum of all the individual nodes, this allows this cluster to approach a solid state disk behavior in performance, because the amount of memory available from all storage nodes can become quite large.
In addition a multicast transfer at the communication level, could well benefit from the aggregation of resources across the Interconnected data buses to better act upon the requested transfer(s).
Nothing in this specification should be understood to limit this invention with a particular data bus or network. Nor should any limitation apply if a system data bus is apportioned, for any purpose, into more than one bus.
In summary, the present invention presents an apparatus and method for multicast data transfers in a system with Interconnected data busses of at least two Subsystems. These multicast data transfers involve multiple Addressable Devices where at least one Addressable Device is connected to the data bus of one Subsystem and at least one other Addressable device is connected to the data bus of at least a second system. In the examples provided above a data storage system was used. This was for clarity purposes and those skilled in the art will recognize that the present invention is not limited to a data storage application, but addresses a much wider sense, including, but not limited to, search applications, and alarm systems, air traffic control applications, etc.
This application claims priority of U.S. provisional application Ser. No. 61/402,399, filed Aug. 30, 2010, entitled, “Apparatus and Method in a system for Multicast Data Transfers over an Interconnected Bus”.
Number | Date | Country | |
---|---|---|---|
61402399 | Aug 2010 | US |