Ouroboros Model: Difference between revisions
No edit summary |
(→Flows) |
||
Line 18: | Line 18: | ||
== Flows == | == Flows == | ||
Flows are between two flow endpoints. They are very broad and generalized | Flows are between two flow endpoints. They are very broad and generalized | ||
* Data is sent as a packet at the source endpoint and arrives as a packet at the destination endpoint. | * Data is sent as a packet at the source flow endpoint and arrives as a packet at the destination flow endpoint. | ||
* Flows are established over a Layer, which may consist of any number of forwarding processes called IPCPs. | * Flows are established over a Layer, which may consist of any number of forwarding processes called IPCPs. | ||
* Packets transmitted by the source have a non-zero probability to arrive at least once at the destination. | * Packets transmitted by the source have a non-zero probability to arrive at least once at the destination. | ||
Line 25: | Line 25: | ||
* Packet fragmentation can be subject to coding techniques such as erasure codes or forward error correcting codes | * Packet fragmentation can be subject to coding techniques such as erasure codes or forward error correcting codes | ||
* There is no implied correlation between the path taken by different packets or different fragments in the same flow | * There is no implied correlation between the path taken by different packets or different fragments in the same flow | ||
* Packets or fragments can be duplicated | * Packets or fragments can be duplicated | ||
== Layers == | == Layers == |
Revision as of 13:48, 21 July 2024
This page is under construction
This pages provides an overview of the Ouroboros model, which summarizes our proposed organization of packet networking functionality.
Elements of the model
The Ouroboros packet network model for unicast works as follows: To be able to communicate processes request flows to one another: server processes bind' to (service) names, the client process requests a flow to such a name.
The model for multicast works differently.
Processes
Processes are running software. No need for fancy buzzwords. A microservice component, a (monolithic) OS kernel, an open spreadsheet, a running background script, ... they are all nothing but processes.
Names
Names in Ouroboros are tied to processes. Multiple processes can bind to the same name, and multiple names can be bound to the same process.
Flows
Flows are between two flow endpoints. They are very broad and generalized
- Data is sent as a packet at the source flow endpoint and arrives as a packet at the destination flow endpoint.
- Flows are established over a Layer, which may consist of any number of forwarding processes called IPCPs.
- Packets transmitted by the source have a non-zero probability to arrive at least once at the destination.
- Packets can follow any path in the Layer
- Packets may or may not be fragmented at any point along the flow.
- Packet fragmentation can be subject to coding techniques such as erasure codes or forward error correcting codes
- There is no implied correlation between the path taken by different packets or different fragments in the same flow
- Packets or fragments can be duplicated
Layers
To improve effiency of flows, Layers may try to
Connections
IRMd
IPCPs
Functional layering
Main page: Ouroboros Functional Layering
The model's functional layering underpinning Ouroboros has some distinct properties.
- A clear distinction between unicast and broadcast (see the multicast conjecture).
- Unicast
- The application end-to-end layer performs functionalities that require knowledge at the endpoint applications, but are not of concern to the network. These are automated repeat-request (ARQ), fragmentation and flow control. In addition, this layer also performs encryption, authentication and packet integrity (CRC). The data protocol associated with this layer is called the Flow and Retransmission control protocol (FRCP). It is considered an application protocol rather than a network protocol.
- The network end-to-end layer performs flow allocation/multiplexing, name-to-address resolution, and congestion avoidance.
- The network forwarding layer performs routing and hop-by-hop forwarding functions.
- The Unicast Layer is a distributed application that implements the network end-to-end layer and network forwarding layer functionalities. Since the elements of a Unicast Layer are also applications, they inherit the application end-to-end layer on a hop-by-hop basis.
- Broadcast
- The network flooding layer is completely stateless.
- The Broadcast Layer is a distributed application that implements the network flooding layer. Since the elements of a Broadcast Layer are also applications, they inherit the application end-to-end layer on a hop-by-hop basis.
- Unicast
- At the bottom of this network model, is the transmission layer. It is always accompanied by a (devolved) network end-to-end layer.
Network Layering and Recursion
Main Page: Network Layering