Your first BGP session, a comprehensive beginners guide to BGP.
Finding a VPS that can provide BGP session
You can find VPS providers here that provides BGP session.
For this tutorial, I use a BGP IPv6 only VPS from iFog GmbH since it is very cheap.
Since this is an IPv6 only VPS and I don’t have native IPv6, I use Cloudflare WARP to SSH to my IPv6 only VPS.
Tell your VPS provider to set up BGP on their side
This can either be done using your VPS provider’s panel, or by opening a support ticket.
When the VPS provider has set up their BGP on their side, they will provide you their ASN and their peer IPv6 address.
They will also verify if you own your ASN by telling you to add import and export statement on your ASN routing policy.
|
|
Prerequisites
- A BGP VPS preferably with Debian installed.
- Your own ASN.
<Your ASN>
- VPS provider’s ASN.
<VPS provider's ASN>
- VPS provider’s peering IPv6 address.
<VPS provider's IPv6 address>
- Your IPv6 prefix.
<Your IPv6 prefix>
- Your BGP router ID.
<Your router ID>
- A route6 object at the RIPE IRR database.
- A routing policy statement on your ASN.
Creating your own BGP router ID
The BGP router ID is a 4-byte unique identifier of a BGP router in an AS. It is formatted like an IPv4 address. (0.0.0.0
to 255.255.255.255
)
If your VPS already has an IPv4 address, you can use your VPS’s IPv4 address as a router ID. If your VPS does not have an IPv4 address, you can use my own conventions:
Use 0, 10, 127, or 240-255 as the 1st octet, since those are reserved IPv4 address, and use your ASN number for the 2nd and 3rd octet, and choose your own number for the 4th octet.
Example: My ASN is AS215150, the 2nd and 3rd octet is215.150
, then I choose a number for the 4th octet like this10.215.150.0
or generate a random number like this10.215.150.247
.
If your ASN’s 1st or 2nd octet is higher than 256 like AS200879, you can limit the big number to 256 like this10.200.256.0
or just generate a random number for the big number like this10.200.247.0
.Generate a random number. Use 0, 10, 127, or 240-255 as the 1st octet, and generate a random number for the 2nd, 3rd and 4th octet like this
10.215.150.247
.
Set up BGP on your VPS
- Install BIRD2. This will become our BGP daemon so that we can export our prefixes to the internet.
|
|
- Install Pathvector. This is an abstraction to BIRD2’s config, which makes it easier to configure BIRD2.
|
|
- Create the Pathvector config.
sudo nano /etc/pathvector.yml
For our first BGP session, here is an example config for a single upstream provider.
This is also a default route config by not exporting the routes to the kernel. Default route config is easier to understand for beginners and for understanding the theory.
We will move to full table config later on when we will join an IXP and have 2 or more peers.
|
|
Here is an example config with my ASN using iFog as the upstream.
|
|
- Generate BIRD2 config from Pathvector.
sudo pathvector generate
- Check BGP session. If you see “Established”, then BGP session is working.
sudo birdc show protocol
Example output:
|
|
- Check BGP session on a specific session. Replace
<BGP session name>
with name from step 5.sudo birdc show protocol all <BGP session name>
Example:sudo birdc show protocol all IFOG_AS34927_v6
- Check the status of your prefix if it is being exported/announced. If your prefix is there, it means it is currently exported/announced to the internet. It is normal for it to be unreachable as we haven’t assigned the IPv6 address to an interface yet.
sudo birdc show route export <BGP session name> all
Example:sudo birdc show route export IFOG_AS34927_v6 all
Example output:
|
|
Set up your IPv6 prefix on your VPS
Now that we have successfully told the internet that your prefix is accessible to your VPS, the next step is to assign an IPv6 address to your VPS from your IPv6 prefix.
We can’t just set the source IP of an IP packet without the source IP being assigned to an interface.
Set up a dummy interface
We need to create a dummy interface in order for us to have an interface where we assign the IP address. We can’t just assign our IP address to eth0
since your IPv6 prefix technically does not exist within the eth0
interface. A dummy interface works like a loopback interface.
Create a dummy interface configuration.
sudo nano /etc/network/interfaces.d/dummy1
Paste this configuration and edit.
|
|
Here is an example config that assigns the first IPv6 address from my IPv6 prefix.
|
|
Now let’s bring the dummy interface up.
sudo ifup dummy1
Check the status of your prefix to see if it is now reachable. If it says unicast, it means that your IPv6 address is now reachable over the internet.
sudo birdc show route export <BGP session name> all
Example:sudo birdc show route export IFOG_AS34927_v6 all
Example output:
|
|
- Since your IPv6 address is now reachable, you can now ping your IPv6 address at home or even connect to your VPS via SSH using that announced prefix after the prefix has propagated over the internet.
Manual configuration
This does not persist after a reboot.
Create a dummy interface.
sudo ip link add dummy1 type dummy
Assign an IPv6 address to the dummy1 interface.
sudo ip -6 addr add <IPv6 address to assign from your IPv6 prefix> dev dummy1
Example: sudo ip -6 addr add 2a0a:6044:accd::/48 dev dummy1
BGP route propagation
Just like DNS (It’s Always DNS!), it takes time for the route that tells your IPv6 prefix where it is, to be propagated across the routers. It can take up to 72 hours for the whole internet to accept your prefixes.
During the period where the route has not yet propagated, you can’t ping or use your IPv6 address as a source IP in the meantime.
You can use NLNOG Looking Glass to check the status of your route propagation by entering your IPv6 prefix there.
If after 72 hours and your prefix is still not reachable, you can use NLNOG IRR Explorer to check if you have a valid route6 object, and if you don’t have any RPKI invalids.
Use your IPv6 address as a source IP
Now that we can now ping our announced IPv6 prefix over the internet, we can now eyeball contents on the internet using your IPv6 prefix.
Programs that support setting source IP on itself
Some programs like ping and curl can bind to specific address on itself.
Ping a server using your announced IPv6 address.
ping -I <Your IPv6 address assigned to your dummy1> <IPv6 address to ping>
Example:ping -I 2a0a:6044:accd:: 2001:4860:4860::8888
Get the IPv6 address of your server using curl.
curl --interface <Your IPv6 address assigned to your dummy1> api.myip.com
Example:curl --interface 2a0a:6044:accd:: api.myip.com
Setting the source IP via the routing table
What if you don’t want to specify the IP address and you want curl api.myip.com
to return the announced IPv6 address every time?
- Check the routing table.
ip -6 route
At the very end of the routing table, we can see the default route, just like this:
|
|
Example with my gateway IPv6 address:
|
|
We can add a new default route with a lower metric than that default route but with a source IP set to your announced IPv6 address.
Create a new default route with a lower metric and a source IP address.
sudo ip -6 route add default via <Gateway IPv6 address> dev eth0 src <Your IPv6 address assigned to your dummy1> metric 512
Example with my gateway and announced IPv6 address:sudo ip -6 route add default via 2a0c:9a40:2510:1001::1 dev eth0 src 2a0a:6044:accd:: metric 512
Check the routing table again. Take note that there are 2 default routes, but 1 default route with a source IP is higher.
ip -6 route
|
|
- Check using curl without a specified address if the source IP is correct.
curl api.myip.com
Using a different IPv6 address from your prefix.
One of the benefits of IPv6 is you have huge number of IP address to use from.
What if I wanted to use 2a0a:6044:accd::1:5ee:900d:c0de
(I see good code) as my IPv6 address?
- Assign your chosen IPv6 address to the dummy1 interface.
Automatic: Add your chosen IPv6 address to /etc/network/interfaces.d/dummy1
.
|
|
Then reload the interface. sudo ifdown dummy1 && sudo ifup dummy1
Manual: sudo ip -6 addr add 2a0a:6044:accd::1:5ee:900d:c0de/48 dev dummy1
- Use curl to check if you are getting the right IPv6 address.
curl --interface 2a0a:6044:accd::1:5ee:900d:c0de api.myip.com
Now that we have your own IPv6 prefix working on your VPS, it is time to bring home the IPv6 using SOCKS5 or WireGuard.
Shell cheat sheets
BIRD Internet Routing Daemon systemd service
|
|
Dummy interface
|
|
IPv6 address
|
|
Routing table
|
|