Bird 2.0 and Bird 1.6 documentation added

This commit is contained in:
Tristan B. Velloza Kildaire 2021-05-31 15:14:53 +02:00
parent 7121e64f0b
commit b88115030f
4 changed files with 170 additions and 48 deletions

View File

@ -1,53 +1,10 @@
Configuring Bird
================
Configuring Bird 1.6
====================
This document aims to provide the configuration file template required
for CRXN and along with a description of what parameters need to be set
for your node specifically.
## Bird 1.6 and 2.0 differences
Bird 1.6's bird6 (which is what we will use) doesn't prefix anything
with `ipv6` as they are assumed to all be IPv6. However, in bird 2.0,
it is dual-stack and hence one must provide either an `ipv6` prefix or
`ipv4` (we will of course be using the former).
### Changes
#### Table definitions
So for example in 1.6 bird6 a table definition is as follows:
```bird
table crxn;
```
However in bird 2.0 it is as follows:
```bird
ipv6 table crxn;
```
#### Channels
So for example in 1.6 bird6 a channel definition is as follows:
```bird
import all;
export all;
```
However in bird 2.0 it is as follows:
```bird
ipv6 {
export all;
import all;
};
```
---
## Configuration
The configuration template is constructed out of the following files:
@ -197,4 +154,3 @@ instance and one `ospf` instance):
import "babel.conf";
import "ospf.conf";
```

159
docs/bird2.md Normal file
View File

@ -0,0 +1,159 @@
Configuring Bird 2
==================
This document aims to provide the configuration file template required
for CRXN and along with a description of what parameters need to be set
for your node specifically.
## Configuration
The configuration template is constructed out of the following files:
1. `filters.conf`
* Filter functions and the filter itself
2. `networks.conf` (TODO: Add at a later stage)
3. `tables.conf`
* The table definitions
4. `router.conf`
* This contains the needed protocol definition for discovering
your interface's prefixes and generating routes form them
* It also contains the needed protocol definitions to sync bird
routes into the Linux kernel's routing table (so you cna forward
packets based on the routes from Bird)
5. `protocols.conf`
* Depending on what protocol you want to use this will contains
configurations for each
#### `filters.conf`
This file holds all the required functions for subnet matching and also
filters that match to the specific prefix aggregates (regional subnets)
that CRXN uses.
```
# Given prefix `in` and `check` see whether or not
# the `in` is withint `check`
function rangeCheck (prefix inPrefix; prefix rangePrefix)
int ourNetworkLen;
ip ourNetworkID;
ip inPrefixMasked;
{
# Get the length of our range
ourNetworkLen=rangePrefix.len;
# Get out network ID
ourNetworkID=rangePrefix.ip;
# Mask the inPrefix to that length
inPrefixMasked=inPrefix.ip.mask(ourNetworkLen);
# Check if the masks match
if(inPrefixMasked = ourNetworkID)
then
return true;
else
return false;
}
# CRXN Route filter based
filter crxn6
{
# CRXN v6 range
if (rangeCheck(net, fd00::/8) = true)
then
accept;
# Freeloader's range
if (rangeCheck(net, 2a04:5b81:2050::/44) = true)
then
accept;
# No matches, reject
reject;
}
```
#### `tables.conf`
This file holds all table definitions. There are only two actually.
The table `crxn` is the one we actually use, `master` is optional
and is only present because if one uses `bird-lg-go` (the looking glass
we use) then it, by default, only shows routes in the `master` table.
It is meant to have the same routes as the `crxn` table.
```
# CRXN table
ipv6 table crxn;
# master table
# This is the default table, I only use this as the looking glass defaults to looking at it
ipv6 table master;
```
#### `router.conf`
This contains an instance of the `direct` protocol which reads the address
and prefix assigned to your AF_INET6 interfaces and generates routes from
those that represent routes to directly atrtached networks those interfaces
are on. The reason for this is that the `kernel` protocol never learns routes
in the Linux kernel's routing table that have the `kernel` protocol which
is what you get when you assign interfaces addresses and prefixes. This
doesn't even need those, it gets them from the interface.
```
# The kernel protocol doesn't grab kernel routes that are added by you when you assign an
# address and prefix. So instead of reading this from all routes with `proto kernel` this just
# yeets the routes off of the interface structure itself (even if you didn't have a route for your
# directly attached networks - i.e. nexthop = 0.0.0.0)
protocol direct crxnDirect {
ipv6
{
# Import from direct -> bird into bird's `crxn` table
import filter crxn6;
table crxn;
# Only doing this so it shows by default in looking glass
import filter crxn6;
table master;
}
}
```
The second part is for syncing routes from Bird to the Linux kernels' routing
table such that you can forward traffic then absed on the routes learnt from
Bird.
TODO: Check, defualt `learn` should larn non `kernel` and non-`bird` routes
```
# CRXN Kernel protocol
# We import any routes from the kernel table other than `proto bird` and `proto kernel`,
# could be `proto static` for example. By default it will learn these.
# Of course we also then export all routes from our Bird tables into the kernel so you can actually forward packets
protocol kernel crxnKernel {
ipv6 {
# Export from bird -> kernel from bird's `crxn` table
export filter crxn6;
table crxn;
# Only doing this so it shows by default in looking glass
import filter crxn6;
table master;
}
}
```
#### `protocols.conf`
This file should look like this (as an example of running one `babel`
instance and one `ospf` instance):
```
# Import protocol instances
import "babel.conf";
import "ospf.conf";
```

View File

@ -8,9 +8,11 @@ In a file named `babel.conf` place the following template:
protocol babel crxnBabel
{
# Interfaces to run babel on
interface "interface1", "interface2";
# Interfaces to run babel on
interface "interface1", "interface2";
ipv6
{
import filter crxn6;
export filter crxn6;
table crxn;
@ -18,6 +20,7 @@ protocol babel crxnBabel
# Only doing this so it shows by default in looking glass
import filter crxn6;
table master;
}
}
```
@ -25,6 +28,8 @@ protocol babel crxnBabel
protocol to run on
* It also supports regex in a string so you can do `"interface*"` for example
**Note:** For Bird 1.6 you will want to remove the `ipv6 {}`.
And that is all!
### Additional changes

View File

@ -23,6 +23,8 @@ and configuration details needed to get connected!
* TODO: RPKI?
4. [Setting up routing](routing.md)
1. Setting up Bird
* [Bird 1.6](bird1.6.md)
* [Bird 2.0](bird2.md)
* TODO: Filtering etc
* TODO: Config
* TODO: Scripting