IPC분류정보
국가/구분 |
United States(US) Patent
등록
|
국제특허분류(IPC7판) |
|
출원번호 |
UP-0738431
(2003-12-17)
|
등록번호 |
US-7570600
(2009-08-24)
|
발명자
/ 주소 |
- Slaughter, Gregory L.
- Saulpaugh, Thomas E.
- Kwiatkowski, Mark P.
- Jorapurkar, Girish
|
출원인 / 주소 |
- Symantec Operating Corporation
|
대리인 / 주소 |
|
인용정보 |
피인용 횟수 :
3 인용 특허 :
46 |
초록
▼
A network having a plurality of nodes interconnected by links (virtual communication channels) is disclosed. In one embodiment, the nodes may communicate with each other in a decentralized or peer-to-peer manner. A method for establishing the links among the nodes is disclosed. The links may be esta
A network having a plurality of nodes interconnected by links (virtual communication channels) is disclosed. In one embodiment, the nodes may communicate with each other in a decentralized or peer-to-peer manner. A method for establishing the links among the nodes is disclosed. The links may be established such that the system is able to operate efficiently. In particular, the manner in which the nodes are interconnected by links may enable the system to efficiently route messages and efficiently recover from network failures.
대표청구항
▼
What is claimed is: 1. A computer-readable memory medium storing program instructions executable to implement a method comprising: determining an ordering for a plurality of N nodes such that the nodes are circularly ordered as nodes D0, D1, D2, . . . DN-1; each node Di in the plurality of nodes e
What is claimed is: 1. A computer-readable memory medium storing program instructions executable to implement a method comprising: determining an ordering for a plurality of N nodes such that the nodes are circularly ordered as nodes D0, D1, D2, . . . DN-1; each node Di in the plurality of nodes establishing a link to X other nodes chosen as nodes Di+1, Di+2, . . . Di+X, wrapping to D0 if necessary; and each node Dj in at least a subset of the plurality of nodes establishing a link with one or more additional chosen nodes not in the set Dj-X, Dj-X+1, . . . Dj-1, Dj+1, Dj+2, . . . Dj+x; and for each node Dj in the at least the subset, each node in the set Dj-X, Dj-X+1, . . . Dj-1, Dj+1, Dj+2, . . . Dj+x establishing a link with the one or more additional nodes chosen by the node Dj. 2. The computer-readable memory medium of claim 1, wherein said each node Dj in the at least the subset establishing a link: with one or more additional chosen nodes not in the set Dj-X, Dj-X+1, . . . Dj-1, Dj+1, Dj+2 . . . Dj+X comprises each node Dj in the at least the subset establishing a link with one or more randomly chosen nodes not in the set Dj-X, Dj-X+1, . . . Dj-1, Dj+1, Dj+2, . . . Dj+X. 3. The computer-readable memory medium of claim 2, wherein said each node Dj in the at least the subset establishing a link with one or more randomly chosen nodes comprises each node Dj in the at least the subset establishing a link with exactly one randomly chosen node. 4. The computer-readable memory medium of claim 1, wherein the plurality of nodes utilize the established links to communicate in a peer-to-peer manner. 5. The computer-readable memory medium of claim 1, wherein the nodes are circularly ordered so that node DN-1 follows node D0 in the ordering. 6. The computer-readable memory medium of claim 1, wherein the method implemented by the program instructions further comprises: selecting the nodes for the at least the subset of the plurality of nodes such that the at least the subset includes nodes whose position in the ordering is a multiple of 2X. 7. The computer-readable memory medium of claim 1, wherein X is at least eighty percent smaller than N. 8. The computer-readable memory medium of claim 1, wherein each node in the plurality of nodes has a unique node ill; wherein said determining the ordering comprises determining an ordering based on the node IDs. 9. The computer-readable memory medium of claim 8, wherein the node IDs are capable of being ordered; wherein said determining the ordering based on the node IDs comprises ordering the node IDs; wherein the node with the first node ID in the ordering is selected as node D0, wherein the node with the second node ID in the ordering is selected as node D1 and so on, up to the node with the highest node ID in the ordering being selected as node DN-1. 10. The computer-readable memory medium of claim 1, wherein each link between two nodes comprises a virtual communication channel between the two nodes. 11. The computer-readable memory medium of claim 1, wherein the established links comprise one or more TCP links and/or one or more UDP links. 12. The computer-readable memory medium of claim 1, wherein the plurality of nodes are interconnected in a local area network (LAN). 13. The computer-readable memory medium of claim 1, wherein the method implemented by the program instructions further comprises: one or more nodes in the plurality of nodes establishing one or more additional links to one or more other nodes. 14. The computer-readable memory medium of claim 1, wherein the established links enable a message to be routed from any given first node to any given second node with an average efficiency on the order of log(N) message hops. 15. The computer-readable memory medium of claim 1, wherein the established links enable recovery operations to be performed in the event of node failures with an average efficiency on the order of 3 message hops or less. 16. A computer-readable memory medium storing program instructions executable to implement a method comprising: determining an ordering for a plurality of N nodes such that the nodes are circularly ordered as nodes D0, D1, D2 . . . DN-1; each node Di in the plurality of nodes establishing a link to X other nodes chosen as Di+1, Di+2, . . . Di+X, wrapping to D0 if necessary; and for each node Dj in at least a subset of the plurality of nodes: the node Dj establishing a link with one or more randomly chosen nodes not in the set Dj-X, Dj-X+1, . . . Dj-1, Dj+1, Dj+2, . . . Dj+X; each node in the set Dj-x, Dj-X+1 . . . Dj-1, Dj+1, Dj+2, . . . Dj+X establishing a link with the one or more nodes randomly chosen by the node Dj. 17. A computer-readable memory medium storing program instructions executable to implement a method comprising: determining an ordering for a plurality of nodes such that the ordering has a first node, a second node, and so on, up to a last node, wherein the ordering is circular so that the first node follows the last node in the ordering; each node establishing one or more links to one or more nodes immediately following the node in the ordering; and for each respective node of at least a subset of the plurality of nodes, the respective node establishing one or more links to one or more randomly chosen nodes and each of the one or more nodes immediately following the respective node also establishing a link to each of the one or more nodes randomly chosen by the respective node. 18. A system comprising: a plurality of N nodes; wherein each node is operable to determine an ordering for the plurality of N nodes such that the nodes are circularly ordered as nodes D0, D1, D2, . . . DN-1; wherein each node Di in the plurality of nodes is operable to establish a link to X other nodes chosen as nodes Di+1, Di+2, . . . Di+X, wrapping to D0 if necessary; and wherein each node Dj in at least a subset of the plurality of nodes is operable to establish a link with one or more additional chosen nodes not in the set Dj-X, Dj-X+1 . . . Dj-1, Dj+1, Dj+2, . . . Dj+x: and wherein for each node Dj in the at least the subset each node in the set Dj-X, Dj-X+1, . . . Dj-1, Dj+1, Dj+2, . . . Dj+X is operable to establish a link with the one or more additional nodes chosen by the node Dj. 19. The system of claim 18, wherein said each node Dj in the at least the subset establishing a link with one or more additional chosen nodes not in the set Dj-X, Dj-X+1, . . . Dj-X+1, . . . Dj-1, Dj+1, Dj+2, . . . Dj+X comprises each node Dj in the at least the subset establishing a link with one or more randomly chosen nodes not in the set Dj-X, Dj-X+1, . . . Dj-1, Dj+1, Dj+2, . . . Dj+X. 20. The system of claim 19, wherein said each node Dj in the at least the subset establishing a link with one or more randomly chosen nodes comprises each node Dj in the at least the subset establishing a link with exactly one randomly chosen node. 21. The system of claim 18, wherein the plurality of nodes are operable to utilize the established links to communicate in a peer-to-peer manner. 22. The system of claim 18, wherein the at least the subset includes nodes whose position in the ordering is a multiple of 2X. 23. The system of claim 18, wherein X is at least eighty percent smaller than N. 24. The system of claim 18, wherein each node in the plurality of nodes has a unique node ID; wherein said determining the ordering comprises determining an ordering based on the node IDs. 25. The system of claim 18, wherein each link: between two nodes comprises a virtual communication channel between the two nodes. 26. The system of claim 18, wherein the network comprises a local area network (LAN), wherein the LAN interconnects the plurality of nodes. 27. The system of claim 18, wherein one or more nodes in the plurality of nodes are operable to establish one or more additional links to one or more other nodes.
※ AI-Helper는 부적절한 답변을 할 수 있습니다.