This application claims the benefit, under 35 U.S.C. §365 of International Application PCT/EP2011/061043 , filed Jun. 30, 2011, which was published in accordance with PCT Article 21(2)on Jan. 5, 2012in English and which claims the benefit of European patent application No. 10305724,6, filed Jul. 2, 2010.
In modern multimedia environments, e.g. environments for digital video production typically comprising several digital cameras, display monitors, scanners etc., large amounts of high resolution multimedia data is transferred via a high speed network connecting the aforementioned devices also referred to as network devices. For permanent storage of data a suitable storage device plays a key role in such a multimedia environment. Usually, a block based network storage device such as an array of hard disks or flash memories is connected to the network devices via a serial network, like Ethernet, FireWire or USB. A high data transfer rate to and from the network storage device is crucial for the performance of the whole multimedia environment, especially for real time applications.
It is an object of the present invention to provide a computer system comprising a plurality of network devices that are connected to a block based network storage device via a serial network link and a method for operating said computer system, wherein a read/write process from and to the block based storage device offers an improved data rate.
The object is reached by the subject matter of the independent claims, advantageous embodiments are subject matter of the dependent claims.
According to the invention, a method for operating a computer system comprising a network storage device being connected by a serial network link to a plurality of network devices is provided. The network storage device comprises a block based storage device for storing data related to the network devices. Said network storage device further comprises a scalable cache selector having a cache memory that is sub-divided into a plurality of cache queues. Each cache queue is dedicated to one of the aforementioned network devices. The scalable cache selector further comprises a queue selector for assigning data packets received from and being sent to the network devices to the respective cache queue. The method according to the invention comprises the following steps:
The method according to the invention is based on the following considerations:
According to the art, a cache memory is used for buffering data to be written to or to be read from a hard disk; the same applies to other block based storage devices. Such a hard disk cache memory buffers the data traffic from and to the actual hard disk, thereby releasing the drive from excessive movement of the read/write-head. It will now be referred to a computer system comprising such a block based storage device that is connected by a serial network link to a plurality of network devices. In such a system, a data stream received by the hard disk contains information/data packets coming from different sources/network devices such as different digital cameras. Due to the fact that the network connection is a serial network link, e.g. Ethernet, FireWire or USB, a sequence of data packets having different origins is delivered to the hard disk.
A cache memory according to the art is a simple buffer that stores information irrespective to its origin. Consequently, a data block that is written to the block based storage device, e.g. the hard disk, contains a “mixture” of data, i.e. data having a plurality of different origins. Referring to the multimedia environment as described above, by way of an example only, such a block could contain data that is related e.g. to a first and a second digital camera. In case, a user of such a multimedia environment desires to review a video stream from e.g. camera number one, data related to the stream of said camera has to be “collected” from a plurality of different blocks of the hard disk. As one data block may contain data of different origins, by reading such a data block in order to view data of a single origin, also data not requested are read. As a consequence, the read/write-head of the hard disk has to perform a huge number of movements. Obviously, this is a drawback with respect to the achievable data rate.
The method according to the invention is tackling this drawback at its root: The data stream received via the serial network link is stored in a structured cache memory instead of a simple buffer. In other words, data packets comprised by the data stream are sorted on the basis of their origin. Data packets received from a first source/first network device, e.g. a first digital camera are stored in a first cache queue while data packets coming from a second network device are stored in a second cache queue and so on. In case one of these cache queues exceeds a certain threshold level, preferably the threshold level is chosen to match with a block size of the block based storage device, a whole data block is transferred/written to the block based storage device. Consequently, the data stored in the block based storage device is sorted block by block according to the sources/network devices that are connected to the network storage device. In other words, each block of the storage device contains only data related to a single network device.
In the preceding paragraphs the method according to the invention has been explained for a write process by way of an example only. It is understood, the method is also applicable to a read process. This option will be explained in the detailed description.
The terms input and output data packet, frequently used in the following will be explained. Input and output are considered relative to the cache memory. Accordingly, a data packet coming from a network device or from the block based data storage that has to be stored inside the cache memory is an input data packet, while an output data packet is always leaving the cache memory in the direction towards network device or towards the block based data storage.
Preferably, during a process of writing to the block based storage device, step a) comprises receiving at least one input data packet from a network device via the serial network link and step c) comprises sending an output data packet to said block based storage device, wherein the predetermined size corresponds to a block size of the block based storage device. Further preferably, the predetermined size of the output data packet equals the block size of block based storage device.
Writing to the block based storage device according to the aforementioned method is advantageous because a data landscape on the block based storage device is created that contains huge segments containing data related to just one source. In other words, each segment of the storage device contains only data related to a single network device. Consequently, the data comprised by said block based storage device is much more sorted compared to a block based storage devices that has undergone a write processes known in the art. As a consequence, the storage device is accessible much faster—in case a hard disk is applied as a block based storage device a significant lower number of movements of the read/write-head is necessary.
Preferably, during a process of reading from the block based storage device, step a) comprises receiving at least one data block from the block based storage and step c) comprises sending an output data packet of a predetermined size to the serial network link. Further preferably, the predetermined size of the output data packet equals a frame size of the serial network link and further preferably the size of the data block received from the block based storage equals a block size of the block based storage device.
Advantageously, data related to a certain network device is read from the block based storage block by block. In case a hard disk is applied, the number of movements of the read/write-head is reduced to a minimum. As a consequence, the data rate increases. It is notably advantageous that with the aforementioned method, high resolution movie data may be read out from a hard disc drive in real time.
A network storage device according to the invention is provided for being connected by a serial network link to a plurality of network devices. The network storage device comprises a block based storage device for storing data related to the network devices. The network storage device further comprises a scalable cache selector having a cache memory that is sub-divided into a plurality of cache queues, wherein each cache queue is dedicated to one of the network devices. The scalable cache selector is capable of executing the method for reading and/or writing as described above.
Preferably, the block based storage device of the computer system is a hard disk drive or a flash drive. In case of a hard disk it is even more advantageous because movement of the read/write head is reduced, which speeds up reading and writing to the hard disk and reduces wearout.
Same or similar advantages that have been mentioned with respect to the method according to the invention apply to the computer system according to the invention.
In the following, the invention will be described in more details with reference to the figures.
All applications/network devices ND1 . . . ND3 are capable of sending and receiving data streams via the network, e.g.: the first network device ND1 sends an input data packet 3 comprising a pay-load package pill and a label L1 to the network bridge NB. The second and third network device ND2, ND3 can act in the same way, as indicated in
The network storage device NSD comprises the scalable cache selector SCS and a block based storage device BBSD, e.g. an array of hard disc or flash memories.
In the following, first of all, the functionality of the network storage devices NSD during a process of writing to the block based storage device BBSD will be explained by reference to
A data stream, comprising a plurality of input data packets 3 sent by different network devices ND1 . . . ND3 is received at the queue selector QS of the network storage devices NSD from the network bridge NB via the serial network link 4. The queue selector QS and a cache memory 10, both further comprised by the scalable cache selector SCS in the network storage device NSD, are linked together via a cache controller 12. The cache memory 10 comprises a plurality of cache queues QL1 . . . QL3. The major task of the queue selector QS is sorting the incoming data packets 3 into the cache queues QL1 . . . QL3 of the cache memory 10. The queue selector QS comprises a cache queue file 8 comprising entries QL1′ . . . QL3′ for storing information of the different cache queues QL1 . . . QL3 for this purpose. According to the exemplary embodiment given by
Input data packets 3 received at the queue selector QS each comprise a payload package p111 . . . p131 and a label L1 . . . L3. Depending on the network protocol, the label L1 . . . L3 is a suitable network header. The Label L1 . . . L3 is indicative to the network device ND1 . . . ND3 sending the respective input data packet 3. The queue selector QS reads the label L1 . . . L3 of the input data packet 3 and stores the payload package p111 . . . p131 in the appropriate cache queue QL1 . . . QL3 that is dedicated to the respective network device ND1 . . . ND3. E.g.: the input data packet 3 sent by the third network device ND3 comprising payload package p131 and label L3 will be stored in the third cache queue QL3, as it is indicated in
With increasing number of incoming input data packets 3 the cache queues QL1 . . . QL3 of the cache memory 10 are filled up with payload data more and more. The cache queues QL1 . . . QL3 are filled up until their level reaches a predetermined threshold level. According to the embodiment given in
In a next step, a whole data block containing solely data related to one network device ND1 . . . ND3 is written to block based storage device BBSD. This data block is an output data packet 5. According to
The same method of writing to the block based storage device BBSD applies to the further cache queues QL2 and QL3, in case they reach their threshold value BS. By reference to the exemplary embodiment in
Preferably, the size of the cache queues QL . . . QL3 given by the start and end addresses (Start, End) is sufficient to capture at least two blocks with a block size BS. When the queue selector QS sends an output data packet 5, i.e. a data block to the block based storage device BBSD from a first cache queue QL1 . . . QL3, each other cache queue QL1 . . . QL3 can be filled up with incoming payload data packages p111 . . . p132 in parallel. However, preferably a block must be sent completely before other payload packages p111 . . . p132 can be stored in the respective cache queue QL1 . . . QL3.
In the following, a data flow from the block based storage device BBSD, i.e. a read operation will be explained by reference to
The read operation is initiated by a network device ND1 . . . ND3 requesting data from the network storage device NSD. By way of an example only, in
The cache queues QL1 . . . QL3 are dedicated to a respective one of the network devices ND1 . . . ND3, as it is known from the write-process described in
When a piece of a block blk11 . . . blk32 remains in the designated cache queue QL1 . . . QL3, it has to be send in the next transfer cycle, i.e. when a new block has been stored in the respective cache queue QL1 . . . QL3 and the threshold level FS is reached again. As it is known from the writing process, preferably, the block has to be sent completely before another block can be stored in the respective cache queue QL1 . . . QL3. But due to remaining pieces of the blocks, it is sometimes necessary to send two blocks. When the queue selector QS sends sub-streams to the network bridge NB, from a first cache queue QL1 . . . QL3, each other cache queue QL1 . . . QL3 can be filled with data blocks coming from the block based storage device BBSD, assumed there is enough space in the cache memory 10.
Number | Date | Country | Kind |
---|---|---|---|
10305724 | Jul 2010 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2011/061043 | 6/30/2011 | WO | 00 | 1/2/2013 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2012/001122 | 1/5/2012 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
7386627 | Lango et al. | Jun 2008 | B1 |
7472231 | Cihla et al. | Dec 2008 | B1 |
8171487 | Buesing et al. | May 2012 | B2 |
20010037406 | Philbrick et al. | Nov 2001 | A1 |
20020108005 | Larson et al. | Aug 2002 | A1 |
20050251500 | Vahalia et al. | Nov 2005 | A1 |
20080028147 | Eagleton et al. | Jan 2008 | A1 |
20100070652 | Maciocco et al. | Mar 2010 | A1 |
20100199039 | Bauman et al. | Aug 2010 | A1 |
Number | Date | Country |
---|---|---|
1664794 | Sep 2005 | CN |
W02007100521 | Sep 2007 | WO |
Entry |
---|
Ari et al., “SANBoost Automated SAN-Level Caching in Storage Area Networks”, 2004 International Conference on Automatic Computing, May 17, 2004, pp. 164-171. |
Kataoka et al., “Distributed Cache System for Large-Scale Networks”, 2006 Proceedings of the International Multi-Conference on Computing in the Global Information Technology, Aug. 1, 2006, pp. 1-40. |
He et al., “STICS-To-IP Cache for Storage Area Networks”, Journal of Parallel and Distributed Computing, vol. 64, No. 9, Sep. 2004, pp. 1069-1085. |
Yasuda et al., “Concept and Evaluation of X-NAS a Highly Scalable NAS System”, 20th IEEE Conference on Mass Storage Systems and Technologies, Apr. 1, 2003, pp. 219-227. |
Zhang et al., “BUCS—A Bottom-Up Cache Structure for Networked Storage Servers”, Proceedings of the 2004 International Conference on Parallel Processing, Aug. 15, 2004, pp. 310-317. |
Motwani et al., “Caching Queues in Memory Buffers”, 2004 ACM-SIAM Symposium on Discrete Algorithms, New Orleans, Louisiana, USA, Jan. 11, 2004, pp. 541-549. |
Karedla et al., “Caching Strategies to Improve Disk System Performance”, Computer, vol. 27, No. 3, Mar. 1994, pp. 38-46. |
Number | Date | Country | |
---|---|---|---|
20130110965 A1 | May 2013 | US |