While in article #001 of the 101 series we learnt how to spawn 2 router instances on the same VM, this use case is only useful for learning/pedagogic purposes. freeRouter can be considered as networking Swiss Army Knife in real networks. We will demonstrate further the freeRouter capability to take control a a full VM and then be able to directly communicate with the external real world via the VM network device interface. i.e Out of the VM scope.
Requirement- Basic Linux/Unix knowledge
- Basic networking knowledge
| |
Overview
Working with freeRouter inside VM is interesting but working and interact with the outside world is way more exciting.
Article objective
In this article we'll explain how to integrate freeRouter in an existing local area network (my home network) and how to inherit from IPv4 DHCP and IPv6 SLAAC. Though this simple example is consumer/end user oriented, if you transpose it to a Internet Service provider environment you can easily imagine how to build a highly BGP route Reflector client, sophisticated rouse server, ROA/RPKI validator or even a BGP BMP server ... (and the list of features set is huge) For example, in one one my project I'm using freeRouter as a BGP route reflector inside a k8s cluster running calico network plugin.
Diagram
![RARE > 2020/06/29 > RARE/FreeRouter-101 [ #002 ] - "Let me get out !" > image2020-6-29_18-31-56.png](/download/attachments/148083914/image2020-6-29_18-31-56.png?version=1&modificationDate=1593448316130&api=v2)
[ #002 ] - Cookbook
In our example we will use a genuine debian stable image (buster) installed as a VirtualBox VM. ![RARE > 2020/06/29 > RARE/FreeRouter-101 [ #002 ] - "Let me get out !" > image2020-6-29_10-22-9.png](/download/attachments/148083914/image2020-6-29_10-22-9.png?version=1&modificationDate=1593449496034&api=v2)
and we add a bridge network interface to or laptop RJ45 conection. ![RARE > 2020/06/29 > RARE/FreeRouter-101 [ #002 ] - "Let me get out !" > image2020-6-29_18-52-39.png](/download/attachments/148083914/image2020-6-29_18-52-39.png?version=1&modificationDate=1593449559231&api=v2)
|
apt-get update
apt-get upgrade
apt-get install build-essential |
apt-get install build-essential |
|
mkdir ~/freeRouter-build
cd ~
git clone https://github.com/mc36/freeRouter
cd freeRouter/misc/native
mkdir ../../binTmp/ |
./c.sh
cd ../../binTmp/
mv *.bin ~/freeRouter/bin |
|
FreeRouter uses 2 configuration files in order to run, let's write these configuration files for R1 in ~/freeRouter/etc int eth1 eth 0000.1111.0001 127.0.0.1 26011 127.0.0.1 26021
tcp2vrf 2323 v1 23 |
freerouter#sh run
hostname freerouter
buggy
!
!
prefix-list p4
sequence 10 permit 0.0.0.0/0 ge 0 le 0
exit
!
prefix-list p6
sequence 10 permit ::/0 ge 0 le 0
exit
!
vrf definition v1
exit
!
interface ethernet1
description freerouter@enp0s9
vrf forwarding v1
ipv4 address dynamic 255.255.255.0
ipv4 gateway-prefix p4
ipv4 dhcp-client enable
ipv4 dhcp-client early
ipv6 address dynamic ffff:ffff:ffff:ffff::
ipv6 slaac
no shutdown
no log-link-change
exit
!
!
!
!
!
!
!
!
!
!
!
!
!
!
server telnet tel
security protocol telnet
no exec authorization
no login authentication
vrf v1
exit
!
!
end
freerouter#
|
|
╭─[6:06:13]floui@debian[3] ~/freeRouter
╰─➤ java -jar lib/rtr.jar routersc etc/freerouter-hw.txt etc/freerouter-sw.txt 3 ↵
info cfg.cfgInit.doInit:cfgInit.java:556 booting
info cfg.cfgInit.doInit:cfgInit.java:680 initializing hardware
info cfg.cfgInit.doInit:cfgInit.java:687 applying defaults
info cfg.cfgInit.doInit:cfgInit.java:695 applying configuration
info cfg.cfgInit.doInit:cfgInit.java:721 done
welcome
line ready
freerouter# |
|
Verification
╭─[7:07:41]floui@debian[1] ~/freeRouter/etc
╰─➤ telnet localhost 2323 1 ↵
Trying ::1...
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
welcome
line ready
freerouter# |
|
freerouter#sh run
hostname freerouter
buggy
!
!
prefix-list p4
sequence 10 permit 0.0.0.0/0 ge 0 le 0
exit
!
prefix-list p6
sequence 10 permit ::/0 ge 0 le 0
exit
!
vrf definition v1
exit
!
interface ethernet1
description freerouter@enp0s9
vrf forwarding v1
ipv4 address dynamic 255.255.255.0
ipv4 gateway-prefix p4
ipv4 dhcp-client enable
ipv4 dhcp-client early
ipv6 address dynamic ffff:ffff:ffff:ffff::
ipv6 slaac
no shutdown
no log-link-change
exit
!
!
!
!
!
!
!
!
!
!
!
!
!
!
server telnet tel
security protocol telnet
no exec authorization
no login authentication
vrf v1
exit
!
!
end
freerouter# |
|
freerouter#ping 192.168.1.1 /vrf v1
pinging 192.168.1.1, src=null, cnt=5, len=64, tim=1000, ttl=255, tos=0, sweep=false
!!!!!
result=100%, recv/sent/lost=5/5/0, rtt min/avg/max/total=1/1/1/5
freerouter# |
freerouter#sh ipv4 arp eth1
mac address time static
34ce.0067.18c2 192.168.1.1 00:00:43 false
9ceb.e8d5.2c51 192.168.1.143 00:00:43 false
freerouter# |
freerouter#ping fd7d:a59c:650b::1 /vrf v1
pinging fd7d:a59c:650b::1, src=null, cnt=5, len=64, tim=1000, ttl=255, tos=0, sweep=false
!!!!!
result=100%, recv/sent/lost=5/5/0, rtt min/avg/max/total=0/0/2/4
freerouter# |
freerouter#show ipv6 neighbors eth1
mac address time static router
34ce.0067.18c2 fd7d:a59c:650b::1 00:01:44 false false
9ceb.e8d5.2c51 fd7d:a59c:650b::8926:98c9:bbde:8ed7 00:01:44 false false
freerouter# |
freerouter#ssh 192.168.1.1 /vrf v1 /user root
- connecting to 192.168.1.1 22
password: ***************
- securing connection
BusyBox v1.28.4 () built-in shell (ash)
_______ ________ __
| |.-----.-----.-----.| | | |.----.| |_
| - || _ | -__| || | | || _|| _|
|_______|| __|_____|__|__||________||__| |____|
|__| W I R E L E S S F R E E D O M
-----------------------------------------------------
OpenWrt 18.06.2, r7676-cddd7b4c77
-----------------------------------------------------
root@OpenWrt:~# |
freerouter#ssh fd7d:a59c:650b::1 /vrf v1 /user root
- connecting to fd7d:a59c:650b::1 22
password: ***************
- securing connection
BusyBox v1.28.4 () built-in shell (ash)
_______ ________ __
| |.-----.-----.-----.| | | |.----.| |_
| - || _ | -__| || | | || _|| _|
|_______|| __|_____|__|__||________||__| |____|
|__| W I R E L E S S F R E E D O M
-----------------------------------------------------
OpenWrt 18.06.2, r7676-cddd7b4c77
-----------------------------------------------------
root@OpenWrt:~ |
|
Conclusion
In this article you:
- had a demonstration of how to integrate freeRouter to a local area network
- learn how to configure an interface in order to act as an IPv4 DCHP client
- learn how to configure an interface using IPv6 SLAAC
- FreeRouter is using UNIX socket in order to forward packet.
After compilation you can use pcapInt binary that will bind freeRouter socket (locathost:26011) to a physical network interface (localhost:26021@enp0s9) It support a huge list of feature with IPv4/IPv6 parity. In this example we demonstrated how an interface can inherit IPv4/IPv6 addresses from IPv4 DHCP server or IPv6 SLAAC - freeRouter can interact with the real network (in various flavors. We will develop this in further articles)
It can be used as a BGP route reflector in Internet Service Provider environment, as ROA/RPKI validator, BMP server, BGP looking glass, route server etc. |