Summary of the invention
In order to solve the problems of the technologies described above, the invention provides a kind of network communicating system and method that realizes that file is downloaded, make the speed of download of client in the communication network not be subjected to the restriction of server handling ability and network bandwidth bottleneck.Like this, even when the number of clients of access server is a lot of at the same time, the speed of user's download file can not be affected yet.
Further aim of the present invention is to provide a kind of method for down loading of file, makes the user can enjoy the online multimedia business, and for example online music or online video or the like of watching listened to greatly satisfies the demand of user to the online multimedia QoS.
The network communicating system that realization file of the present invention is downloaded comprises: describe TPT server and more than one client by reciprocity P2P server, file server, seed that communication network connects;
Wherein, described P2P server is used for announcing Downloadable file to described more than one client, and lands, withdraws from, downloads, inquires about the seed request by what described communication network was handled client;
Described file server is used to store the file that offers client downloads;
Described TPT server is used to store the TPT file of the file correspondence that offers client downloads;
Described more than one client is downloaded the TPT file of required file correspondence by described communication network from described TPT server, and downloads required file according to other clients or the described file server of the TPT file of being downloaded from described communication network.
More than one client of the present invention is downloaded the TPT file of required file correspondence from the TPT server by HTML (Hypertext Markup Language) or file transfer protocol (FTP).
More than one client of the present invention is passed through transmission control protocol or other client downloads required file of User Datagram Protoco (UDP) from communication network, or downloads required file by HTML (Hypertext Markup Language) or file transfer protocol (FTP) from described file server.
The method that realization file of the present invention is downloaded is applicable to comprise the network communicating system of describing TPT server and more than one client by reciprocity P2P server, file server, the seed of communication network connection, comprising:
A, after the user selects to need downloaded files from the file of issue by client, this client according to user-selected filename download to the TPT server corresponding with this document, comprise the TPT file that this document identifies FileID;
B, described client are landed the P2P server, obtain the user ID UIN of this client;
C, described client are sent to the P2P server and are downloaded and seed inquiry request, and carry the UIN and the described FileID of step a of this client in described download request;
D, P2P server join the UIN of this client in the middle of this FileID corresponding file group list, and other client-side information that returns in this document group list is given described client;
E, described client connect according to other client-side informations and these clients that the P2P server returns, and from each fragment data of the required file of these client exchange.
The described issue of step a comprises: according to the TPT file of each the file correspondence of documenting that is about to offer user's download, and the TPT file of making uploaded to the TPT server; The file that offers user's download is uploaded to file server; On the P2P server, announce the file that is about to offer user's download, carry out download and inquiry by client for the user.
TPT file of the present invention further comprises size, the check value of each fragment data and the check value and the version number of this TPT file of fragment data number He each fragment data of institute's respective file;
Further comprise behind the described client downloads TPT file of step a: whether the form and the version of the check TPT file of downloading be correct, if check is correct, then continues execution in step b; Otherwise, forbid described file of this user's download and end;
Behind fragment data, further the check value according to each fragment data carries out verification to the fragment data that exchanges to step e in client other client exchange from communication network, if verification is correct, then receives; Otherwise, abandon this fragment data.
The HASH computing is adopted in verification of the present invention.
Further comprise after step c: whether the UIN of this client of P2P server check and the FileID of the file in download of wanting be correct, check simultaneously whether this document was issued, if UIN and FileID are correct and this document was issued, then continue execution in step d; Otherwise the notice client can't be downloaded this document and finish.
Whether the FileID of the check of the present invention file in download of wanting correctly is: the filename of file in download is passed through 32 the integer values and the FileID that obtain after the HASH computing compare, if identical, then check correctly, otherwise check incorrect.
When step c client sent download request, the network type or the fire compartment wall type that further send this client arrived described P2P server;
In steps d, the P2P server will be further sends to described client according to the network type of this client or fire compartment wall type with the client-side information that has identical network type or a fire compartment wall type with described client in this document group list.
In steps d, described P2P server further returns the download configuration parameter of reception FileID respective file to described client;
Step e is described to be exchanged for: the download configuration parameter that described client is returned according to P2P obtains each fragment data of required file from described other client exchange.
The described download configuration parameter of steps d is by the decision of the configuration file of P2P server, mainly comprises: the uploading and download maximum speed limit/minimum speed limit, P2P and upload speed limit, P2P and download speed limit, the number of clients that is connected at most, the blanking time of inquiry seed, P2P and download and can reduce the speed, the P2P that download from described file server when arriving what speed and download can promote from speed, the P2P of described file server download when arriving what speed and upload speed limit percentage of the number of threads that starts during download, each thread.
At step e, described client exchange obtains further comprising behind all fragment datas: will exchange the fragment data that comes and be reassembled into the downloaded files of wanting in order.
At step e, described client is further downloaded the fragment data that needs from file server when carrying out the fragment data exchange with described other clients.
The method of the invention further comprises: after client was being landed the P2P server, the timed sending heartbeat signal was to the P2P server; The P2P server regularly detects the heartbeat signal from all clients of having landed, as the overtime heartbeat signal that do not receive, then kicks out of clients corresponding, is released to the resource that this client is distributed, and deletes this client-side information from relevant file grouping tabulation.
The method of the invention further comprises: the P2P server receive client withdraw from request after, be released to the resource that client is distributed, and from relevant file grouping tabulation this client-side information of deletion.
This shows, network communicating system of the present invention and method are by combining reciprocity P2P technology with existing method for down loading, make client directly other clients from communication network directly download required file, so, can save server and bandwidth consumption in a large number on the one hand, also can accelerate the speed of client downloads data on the other hand, thereby greatly strengthen user's experience.
In addition, method of the present invention is in other client downloads fragment datas, can also directly download required fragment data from file server, so not only can guarantee the continuity and the order of the fragment data from communication network, downloaded, realize online multimedia service, can also avoid under the less situation of seed the problem that speed of download is slower.
Moreover, method of the present invention has been downloaded the network type or the fire compartment wall type of all seeds of identical file by record in described file grouping tabulation, for the seed management of P2P server provides information accurately, and can select optimum seed for this client according to the current client type that will download this document, further guarantee the speed of download of this client.
Embodiment
For the purpose, technical scheme and the advantage that make invention is clearer, below with reference to the accompanying drawing embodiment that develops simultaneously, the present invention is described in further detail.
Core concept of the present invention is that reciprocity Internet technology P2P (Peer to Peer) technology is combined with the file download technology, client is changed into the downloading mode of direct swap data between the client from the pattern of single server data download, thereby the processing bottleneck that can change owing to server limits the number clients purpose defective of file in download simultaneously.
In addition, the present invention carries out burst by the file that capacity is bigger, be about to file and be divided into several portions, make client simultaneously a plurality of clients from communication network or file server download the different bursts of identical file, can further guarantee the speed of download of client.Simultaneously, owing to need the direct data download of other client that the client of data download can be from communication network, therefore, the number of clients of data download is many more simultaneously in the communication network, it is concentrated more to distribute, the effect of data interaction is just good more between them, thereby can improve the speed of download of data greatly.
Based on above-mentioned thought, the invention provides a kind of network communicating system, this network communicating system mainly comprises as shown in Figure 2: P2P server, file server, seed are described (TPT) server and more than one client.Described P2P server, TPT server and file server are connected to described more than one client by communication network respectively, to realize the information interaction of client to described P2P server, TPT server and file server; Each client in the communication network also is connected to other client by communication network, to realize the exchanges data between the client.
Wherein, but described P2P server mainly is responsible for the issue of file in download, lands, withdraws from, downloads, inquires about requests such as seed, heartbeat maintenance by what described communication network was handled client;
Described file server is used to store the file that offers user's download;
Described TPT server is used to store corresponding each and offers the TPT file of the file correspondence of user's download;
Described more than one client is downloaded the TPT file of required file correspondence by described communication network from the TPT server, and according to the TPT file of being downloaded other clients or file server each fragment data of downloading required file from described communication network.
In the file process of downloading, client in the communication network can pass through HTTP, FTP or other multiple communication mode is downloaded the TPT file from the TPT server, download each fragment data of required file from described file server, perhaps each fragment data by transmission control protocol (TCP) or other the client downloads required file of User Datagram Protoco (UDP) (UDP) from described communication network.
In the process by above-mentioned network communicating system file in download, client at first needs need to select downloaded files from the file of P2P server issue; Then, from the TPT file of TPT server download this document correspondence, therefrom obtain the relevant information of this document, for example size of the number of the FileID of this document, fragment data and each fragment data or the like; Next, other is online and downloaded the client-side information of this document to the P2P server lookup according to these relevant informations, promptly to P2P server lookup seed; After having obtained seed, this client will be downloaded each fragment data of this document from the seed that inquires, simultaneously, the continuity of each fragment data of file in download and order in order to guarantee, client can also be downloaded required fragment data from described file server simultaneously.
To describe the method that realization file of the present invention is downloaded in detail by specific embodiment below.As shown in Figure 3, document down loading method of the present invention specifically may further comprise the steps:
A, offer the file of user's download in P2P server, file server and the issue of TPT server in advance.
The described issue of this step mainly comprises:
At first, according to the TPT file of each file of documenting that is about to offer user's download, and the FPT file of making uploaded to described TPT server;
Then, the file that offers user's download is uploaded to described file server;
At last, on described P2P server, announce the file that is about to offer user's download, carry out download and inquiry by client for the user.
Wherein, described TPT file has mainly comprised the check value of the check value of size, each fragment data of the fragment data number of sign FileID, this document of this TPT file institute respective file and each fragment data and this TPT file self and version number or the like.
The fragment data number of described file and burst size are to be determined by the size of this TPT file institute respective file and the type of service of user's actual selection, for example, if the online music services of listening to, then the size of fragment data is generally the 16K byte, the fragment data number of this document equals the merchant of file size and 16K byte at this moment, and if the online video traffic of watching, then the size of fragment data is generally the 50K byte, and the fragment data number of this document equals the merchant of file size and 50K byte at this moment.
In addition, described FileID is exactly that filename to this document carries out the check value that obtains after the verification, wherein, calculating FileID, the check value of each fragment data or the checking algorithm that check value adopted of TPT file can be multiple checking algorithm commonly used, for example breathes out assorted (HASH) computing or the like.For example, in a preferred embodiment of the invention, described FileID is exactly that the filename of institute's respective file is through 32 the integer values that obtain after the HASH computing.
B, when the user selects to need downloaded files from announced file by client, this client is downloaded the TPT file corresponding with this document to the TPT server according to want downloaded files name;
After download obtained the TPT file, described client can also further be resolved this TPT file, and checked the correctness of the TPT file of downloading, if check is correct, then continued execution in step C, otherwise, forbid described file of this user's download and end.
Described verifying as: check the form of this TPT file and version whether correct.
Described check can further include adopts corresponding method of calibration, and for example HASH computing itself is carried out verification to this TPT file.
C, described client are landed the P2P server, and the P2P server returns unique user ID (UIN) to described client.
The described UIN of this step is that the selective sequential in predefined number range of P2P server is come out, this number range is relevant with the online user number that the P2P server can be supported at most, for example, if P2P server at most can 100,000 online users, then the span of UIN can be 1~100000.
After D, client obtain UIN, select downloaded files, send download request, in described download request, carry the UIN of this client and the FileID of the file in download of wanting to the P2P server according to the user.
Whether the UIN of E, this client of P2P server check and the FileID of the file in download of wanting be correct, checks simultaneously whether this document was issued, if UIN and FileID are correct and this document was issued, and execution in step F then; Otherwise the notice client can't be downloaded this document and finish.
The FileID that the described P2P server check of this step is wanted file in download whether 32 the integer values and the FileID that obtain after the HASH computing for the filename with want file in download passes through of correct method compares, if it is identical, then check is correct, otherwise checks incorrect.
F, P2P server join the UIN of this client in the middle of this document corresponding file group list, return this document corresponding download configuration parameter simultaneously and give client.
Described file grouping tabulation will be carried out taxonomic revision with all clients of downloading institute's file publishing in simple terms exactly, the P2P server can carry out the information of all clients of downloading identical file related with this document, and all client-information records that will be associated with identical file are inquired about for client in this document corresponding file group list.Described client-side information comprises: client address, client place network of network type or fire compartment wall type or the like.
The described file corresponding download of this step configuration parameter mainly comprises: the number of threads that starts during download, each thread upload and download maximum speed limit/minimum speed limit, P2P uploads speed limit, P2P downloads speed limit, maximum number of clients that connect, the blanking time of inquiry seed, P2P can reduce the speed of download from file server when download arriving what speed, P2P can promote the speed of download from file server when download arriving what speed, P2P uploads speed limit percentage or the like.
Above-mentioned these configuration parameters are by the decision of the configuration file of P2P server, described configuration file generally includes two types of default configuration and particular arrangement, wherein, default configuration has comprised the general configuration parameters at All Files, and particular arrangement has only comprised the special configuration parameters at some respective files.If the file of being issued does not have corresponding particular arrangement file, then the P2P server can return the default configuration parameter to client, if corresponding particular arrangement file is arranged, then the P2P server can return client together with default configuration parameter and special configuration parameters.Need to prove that all configuration files of P2P server can dynamically update, promptly can when the P2P server moves, make amendment or upgrade.
After G, client were received this document corresponding download configuration parameter, the FileID that sends the UIN of self and the file in download of wanting was to the P2P server, and other downloads the client-side information of this document to the P2P server lookup, promptly to P2P server lookup seed.
Client is when sending the request of inquiry seed, the network type or the fire compartment wall type that can also further send this client arrive described P2P server, and request P2P server is inquired about other client-side information that has the identical network type in the same grouping according to the network type of this client.
H, P2P server promptly return other seed information to described client according to the information of returning other client in this document institute respective file group list from UIN, the FileID of this client.
If comprised the network type of this client in the request of client query seed, then P2P server general further will have the client-side information of identical network type or fire compartment wall type according to the network type or the fire compartment wall type of this client with described client in this document group list, and promptly seed information sends to described client.So, the connectedness when described client and these seeds carry out data interaction is just very high, and the speed of transfer of data will be faster also simultaneously.
I, described client attempt connecting with described seed, and inquire about the fragment data that whether has self required file or this document in these seeds, if have, then, obtain each fragment data of the file in download of wanting according to download configuration parameter in the TPT file and described seed swap data.
In this step, described client will be by TCP/UDP mode each fragment data from described seed clearing house need.
After exchanging to each fragment data, client also will further be carried out verification according to the check value of downloading each fragment data that parsing obtains the TPT file from step B to exchanging the fragment data that comes, if verification is correct, then receive described fragment data; Otherwise, abandon described fragment data.
In this step, because the fragment data that comes from each seed exchange is a random alignment, therefore, in order to obtain complete file, client also needs the fragment data that exchange comes is combined into the downloaded files of wanting again in order.
From said process as can be seen, after adopting the P2P technology, the bottleneck problem of settlement server effectively, simultaneously because all on-line client all can be shared self downloaded files other clients to communication network, therefore, to have sufficient seed under normal conditions in the communication network exists, and the number of clients of downloading identical file is many more, it is concentrated more to distribute, the effect of data interaction is just good more between them, like this, make a station server can support a large number of users to download simultaneously, and can guarantee all users' speed of download.
In addition, the network type or the fire compartment wall type of all seeds of identical file have been downloaded by record in described file grouping tabulation, for the seed management of P2P server provides information accurately, and can select optimum seed for this client according to the current client type that will download this document, further guarantee the speed of download of this client.
But, because the fragment data that the said method exchange comes is a random alignment, therefore, have only client after having downloaded all fragment datas of file, could obtain correct, complete file, this will be acceptable to general file downloading service, but this can give the online multimedia business, for example online music or the online video frequency program etc. of watching listened to brings bigger time-delay, influences user's experience.
Therefore, in a preferred embodiment of the invention, in order to guarantee the orderly continuously of client institute downloading data fragmentation, client is when carrying out the fragment data exchange with seed, also can start common HTTP or FTP downloading mode according to the download configuration parameter that the P2P server returns, download the fragment data that needs from file server, and guarantee the continuity and the order of client institute downloading data fragmentation by certain algorithm and communication mechanism.
For example, in the online process of listening to music, for the music that is used for listening to, if this music file is not also downloaded fully, then this user client can preferentially be used the mode of HTTP download, obtains music file fragment data required this music process from file server, simultaneously, for the music file of not playing as yet or the fragment data of music file, the mode that still can adopt P2P to download is downloaded.
Above-mentioned this method for down loading had both been accelerated the speed of downloading, and had reduced the load of file server, had guaranteed the orderly continuously of institute's file in download simultaneously again.
Wherein, the download configuration parameter control that client is returned by the P2P server from the ratio of file server downloading slicing data, and can dynamically adjust according to actual conditions, thereby guarantee in most cases, most fragment datas is by obtaining with other client exchange, thereby can save a large amount of server bandwidth resources.
The described method of above preferred embodiment can support a large number of users to enjoy the online multimedia business simultaneously, for example onlinely listens to music, or the online video frequency program of watching, greatly satisfies the demand of user to the online multimedia QoS.
In method of the present invention, for being connected between maintain customer end and the P2P server, in case client is landed the P2P server, will the timed sending heartbeat signal to the P2P server, the P2P server also can regularly detect the heartbeat signal from all clients of having landed simultaneously, as the overtime heartbeat signal that do not receive, then kicks out of clients corresponding, be released to the resource that this client is distributed, and from relevant file grouping tabulation, delete this client-side information.
In addition, after the online multimedia service ending, for example after the user had listened to music or watched video frequency program, client can send to the P2P server and publish (Logout) request, initiatively withdraws from then.After the Logout request of receiving client, the P2P server is released to the resource that client is distributed immediately, and deletes this client-side information from relevant file grouping tabulation.