⇤ ← Revision 1 as of 2006-04-30 08:47:45
Size: 2782
Comment:
|
Size: 6901
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 24: | Line 24: |
==== The virtual layer ==== The virtual layer is built upon the Internet or any other existing network. The Netsukuku nodes, in this layer, are linked each other by (encrypted) tunnels. The tunnels will be created automatically. |
|
Line 37: | Line 29: |
==== The virtual layer ==== The virtual layer is built upon the Internet or any other existing network. The Netsukuku nodes, in this layer, are linked each other by tunnels. A node, in order to join in the virtual layer, has to know its physical coordinates. The use of geographical coordinates is required for Viphilama, because it has to map the virtual layer to the physical one and it needs a way to measure the effective distance between two virtual nodes. The coordinates can be retrieved using an online map service like http://maps.google.com or with a GPS. The coordinates are stored in the internal, external and bnode maps. In the internal map there are the coordinates of each single node. In the external maps, the coordinates which locate a gnode are set to its barycenter: it is the average of the coordinates of all its internal nodes. |
|
Line 44: | Line 55: |
==== Virtual to Physical mapper === | === Virtual to Physical mapper === |
Line 84: | Line 96: |
=== TODO === | Let's go into the details. |
Line 86: | Line 98: |
There are a lot of issues which need to be solved for Viphilama. | ==== Virtual hooking ==== |
Line 88: | Line 100: |
* What will be the topology of the virtual layer? * How a node meets another in the virtual layer? * What are the other issues? * What are the other TODOs? * Is a bit a massless particle? |
A node, which hasn't any physical neighbours, resides in a black zone and, for this reason, it can't hook to the physical layer. It will hook directly to a vnode (virtual node), joining the virtual layer. Let this hooking node be X. |
Line 94: | Line 105: |
Feel free to help its development. | The first part of the Virtual Hooking is the creation of the virtual links (ip tunnels). X chooses, at first, a random vnode which can be located anywhere in the globe. If it is its first hook to the virtual layer, it will get the IP of the vnode from a small public list available on the Internet, otherwise it will consult its saved virtual maps. Let the chosen vnode be Y. X sends to Y a packet containing its coordinates. This pkt will be forwarded with a greedy technique: Y looks up its maps and forwards the pkt to the vnode which is the nearest to X. If this latter vnode knows another vnode which is nearer to X, it forwards again the packet. Finally, the pkt will arrive to the node Z, which is a node very near to X. Let d(A, B) be the physical distance between the node A and B. The node Z appends its Internet IP to the received packet and forwards it again to a node T, so that d(X,T) ~= d(X,Z). The node T will do the same (adds its IP and forwards the pkt). When the packet will be forwarded for the 16th time or when it can't be forwarded anymore, it is sent back to the node X. The node X collects this last packet and creates a virtual link (tunnel) to each Internet IP which has been stored in the packet itself. These linked nodes are the new rnodes of the node X. At this point the node X will hook to each linked node. This procedure is called v-linking: Let "L" be the generic linked node. X sends the I_AM_VHOOKING request to L. L analyses its virtual rnodes and compares d(L,vR) to d(X,vR), where vR is a vrnode. If d(X,vR) < d(L,vR), L adds the Internet IP of the vR in the reply packet. This means that if L finds out that X is nearer to one of its vrnodes, it tells X to create a link to it and deletes its link to the vrnode. X receives the reply packet of L and tries to create a virtual link to each vR listed in the same packet. X writes the list of all the vR nodes which has been successfully linked to X itself. This list is sent back to L. L reads this latter list and delete all its links to the vR nodes, which has been successfully linked to X. X repeats this same hooking procedure for each L. In the end, X chooses one of its vrnodes and hooks with the classical method to it. ==== Gate hooking ==== A node can hook to the physical layer as a normal node or as gate node. A normal node is the old plain node of Netsukuku, it doesn't have to specify its coordinates and doesn't need any other prerequisites. The gate-node has an Internet connection that it uses to connect to the virtual layer, it is also connected to physical nodes. There are two cases: * When the node is from the start a gate node * When it is first a vnode and then becomes a gate node In the first case it hooks directly to a physical node. If one of its rnodes is a gate node too, it will start the v-linking procedure with it. In this way, the new gate-node will be linked to its nearer vrnodes. The old gate-node will delete all the links to the vrnodes which have been linked by the new gate-node. In the second case, the node directly v-links to the new gate node which is connected to. When a gate-node can reach one of it vrnodes using both a virtual and a physical link, it will delete the virtual one. == TODO == * Is it possible to avoid using the coordinates? * What does happen when a (v)node dies? ---- Feel free to help the development of Viphilama. |
NTK_RFC 0010
Subject: Viphilama - Virtual to Physical Layer Mapper
This text describes a change to the Npv7. It will be included in the final documentation, so feel free to correct it. But if you want to change the system here described, please contact us first.
Viphilama
Viphilama will permit to Netsukuku to expand itself over the Internet and then switching automatically to the physical layer without interfering with the stability of the Net. The theory of Viphilama isn't complete yet. This document, right now, is just a description of what it would be.
Layer
Netsukuku will be split in two layer: the virtual layer and the physical one.
The physical layer
This is the original Netsukuku layer: every node is linked to other nodes by physical links (wifi, cables, ...). The physical layer is prioritised over the virtual one.
The virtual layer
The virtual layer is built upon the Internet or any other existing network. The Netsukuku nodes, in this layer, are linked each other by tunnels.
A node, in order to join in the virtual layer, has to know its physical coordinates. The use of geographical coordinates is required for Viphilama, because it has to map the virtual layer to the physical one and it needs a way to measure the effective distance between two virtual nodes.
The coordinates can be retrieved using an online map service like http://maps.google.com or with a GPS.
The coordinates are stored in the internal, external and bnode maps. In the internal map there are the coordinates of each single node. In the external maps, the coordinates which locate a gnode are set to its barycenter: it is the average of the coordinates of all its internal nodes.
Gate node
The two layers are joined by the gate nodes. They are nodes which belong to both layers. This means that the two layer form a unique network.
Virtual to Physical mapper
The mapper does a basic job: whenever it finds that a virtual link can be replaced by a physical one, it removes the virtual link.
Assume this scenario:
Tokyo Moscow Rome London | | | | | | | | |__________|Internet tunnel|_________|
Only one link exists, and it is a virtual one. Only Tokyo and London are linked, all the other cities are alone.
When Tokyo and Moscow will be linked by a series of physical nodes, the mapper will change the net in this way:
Tokyo<--ntk nodes-->Moscow Rome London | | | |______ Internet tunnel ___|
When even Moscow and Rome will be linked by physical nodes:
Tokyo<--ntk nodes-->Moscow<--ntk nodes-->Rome London | | |__ Inet tunnel _|
And so on.
Basically when there are two nodes linked physically, one of them can cut its virtual link which connects it to the virtual layer.
Let's go into the details.
Virtual hooking
A node, which hasn't any physical neighbours, resides in a black zone and, for this reason, it can't hook to the physical layer. It will hook directly to a vnode (virtual node), joining the virtual layer. Let this hooking node be X.
The first part of the Virtual Hooking is the creation of the virtual links (ip tunnels).
X chooses, at first, a random vnode which can be located anywhere in the globe. If it is its first hook to the virtual layer, it will get the IP of the vnode from a small public list available on the Internet, otherwise it will consult its saved virtual maps. Let the chosen vnode be Y.
X sends to Y a packet containing its coordinates. This pkt will be forwarded with a greedy technique: Y looks up its maps and forwards the pkt to the vnode which is the nearest to X. If this latter vnode knows another vnode which is nearer to X, it forwards again the packet. Finally, the pkt will arrive to the node Z, which is a node very near to X.
Let d(A, be the physical distance between the node A and B.
The node Z appends its Internet IP to the received packet and forwards it again to a node T, so that d(X,T) ~= d(X,Z). The node T will do the same (adds its IP and forwards the pkt). When the packet will be forwarded for the 16th time or when it can't be forwarded anymore, it is sent back to the node X.
The node X collects this last packet and creates a virtual link (tunnel) to each Internet IP which has been stored in the packet itself. These linked nodes are the new rnodes of the node X.
At this point the node X will hook to each linked node. This procedure is called v-linking:
Let "L" be the generic linked node.
X sends the I_AM_VHOOKING request to L.
L analyses its virtual rnodes and compares d(L,vR) to d(X,vR), where vR is a vrnode. If d(X,vR) < d(L,vR), L adds the Internet IP of the vR in the reply packet. This means that if L finds out that X is nearer to one of its vrnodes, it tells X to create a link to it and deletes its link to the vrnode.
X receives the reply packet of L and tries to create a virtual link to each vR listed in the same packet. X writes the list of all the vR nodes which has been successfully linked to X itself. This list is sent back to L.
L reads this latter list and delete all its links to the vR nodes, which has been successfully linked to X.
X repeats this same hooking procedure for each L.
In the end, X chooses one of its vrnodes and hooks with the classical method to it.
Gate hooking
A node can hook to the physical layer as a normal node or as gate node.
A normal node is the old plain node of Netsukuku, it doesn't have to specify its coordinates and doesn't need any other prerequisites.
The gate-node has an Internet connection that it uses to connect to the virtual layer, it is also connected to physical nodes.
There are two cases:
- When the node is from the start a gate node
- When it is first a vnode and then becomes a gate node
In the first case it hooks directly to a physical node. If one of its rnodes is a gate node too, it will start the v-linking procedure with it. In this way, the new gate-node will be linked to its nearer vrnodes. The old gate-node will delete all the links to the vrnodes which have been linked by the new gate-node.
In the second case, the node directly v-links to the new gate node which is connected to.
When a gate-node can reach one of it vrnodes using both a virtual and a physical link, it will delete the virtual one.
TODO
- Is it possible to avoid using the coordinates?
- What does happen when a (v)node dies?
Feel free to help the development of Viphilama.