Repository : ssh://git@open-mesh.org/doc
On branches: backup-redmine/2017-07-13,master
commit bccc6cb3c8d14ba2f56f8bbd2c807173b37f8609 Author: Simon Wunderlich sw@simonwunderlich.de Date: Sat Mar 26 17:40:59 2011 +0000
doc: batman-adv/Gateways
bccc6cb3c8d14ba2f56f8bbd2c807173b37f8609 batman-adv/Gateways.textile | 49 ++++++++++++++++++++++----------------------- 1 file changed, 24 insertions(+), 25 deletions(-)
diff --git a/batman-adv/Gateways.textile b/batman-adv/Gateways.textile index ec6d9408..ab506de1 100644 --- a/batman-adv/Gateways.textile +++ b/batman-adv/Gateways.textile @@ -1,68 +1,67 @@ -= Batman-adv gateways = - -{{{ -#!div style="width: 46em; text-align: justify" +h1. Batman-adv gateways
Often batman-adv is used to cover a bigger area with wireless access to the internet where several nodes have internet access while the other nodes try to find the best route towards one of the gateways. In this case it is desirable that the routing protocol helps with the decision to find the best path since it already knows the topology of the network.
-=== The default route === + +h2. The default route +
The subject of manipulating the IP (layer 3) default route with a layer 2 routing protocol has stirred up controversy between those who believe in a clean network layer separation and those who need this functionality. The former claim that a well-designed protocol should not mess with other layers but instead collaborate with tools made for higher layers. The latter group has pointed out that the rule of network layer separation can be bent in real world applications and to improve usability. To achieve a compromise the gateway mechanism is disabled per default and only operates on top of DHCP (details below). Feel free to contact us in case you want to propose alternative ideas.
+h2. The concept
-=== The concept ===
As the whole gateway functionality is based on DHCP, the protocol assumes each gateway runs its own DHCP server and each client runs a DHCP client. When a DHCP client is started it will issue a DHCP request which is broadcasted in the entire network. Every DHCP server will send a reply via unicast back to the client which then has to choose one of the responding DHCP servers as its gateway.
-[[Image(wiki:batman-adv-gateways:gateway1.png)]] +!gateway1.png!
Which gateway will be selected by the client depends on the number of DHCP servers / packet loss / delay / DHCP client software / etc.
Once the gateway feature has been activated batman-adv floods the networks with gateway information, so that each batman-adv node knows all other gateways (including the link quality). A batman-adv gateway client will choose its gateway (based on user defined criteria) long before DHCP is started. As soon as a DHCP request from a client comes in, batman-adv will not broadcast the packet but only send it to the chosen batman-adv gateway via unicast.
-[[Image(wiki:batman-adv-gateways:gateway2.png)]] +!gateway2.png!
The DHCP client will then select the gateway batman-adv prefers as only this gateway replied to the request.
-=== The configuration ===
-'''gateway server''' +h2. The configuration + + +h3. gateway server
Activate the gateway announcements on a node that has a DHCP server running:
-{{{ +<pre> batctl gw_mode server -}}} +</pre>
Batman-adv always announces the gateway's internet bandwidth, so that clients can base their decision on the link quality towards the gateway as well as on the available bandwidth. Per default a bandwidth of 2048KBit/512KBit is assumed. To configure a download bandwidth of 5Mbit with an upload of 1Mbit run the following command:
-{{{ +<pre> batctl gw_mode server 5mbit/1mbit -}}} +</pre>
-Details regarding the syntax of the bandwidth setting can be found in the [http://downloads.open-mesh.org/batman/manpages/batctl.8.html batctl manpage]. +Details regarding the syntax of the bandwidth setting can be found in the "batctl manpage":http://downloads.open-mesh.org/batman/manpages/batctl.8.html.
-'''gateway client''' +h3. gateway client
The client can be activated with the following command:
-{{{ +<pre> batctl gw_mode client -}}} +</pre>
If multiple gateways are available batman-adv selects its best gateway based on certain criteria such as link quality / bandwidth / etc. The selection algorithm can be changed by appending the appropriate gateway selection class to the aforementioned command. To let batman-adv switch the gateway as soon as any gateway becomes 20TQ points better than the currently selected gateway:
-{{{ +<pre> batctl gw_mode client 20 -}}} +</pre>
-All available gateway selection classes are thoroughly explained in the [http://downloads.open-mesh.org/batman/manpages/batctl.8.html batctl manpage]. +All available gateway selection classes are thoroughly explained in the "batctl manpage":http://downloads.open-mesh.org/batman/manpages/batctl.8.html.
To see all available gateways and their announced throughput run:
-{{{ +<pre> batctl gwl -}}} - -}}} \ No newline at end of file +</pre>