Custom firewall/router¶
Sometimes its preferred to use a network stack that is familiar to an admin or that provides a function that is desired and not included in the router stack. There are several open source (or proprietary) systems that can run as a router or firewall with very good performance and with rich feature-sets. These systems are normally installed as instances in a cloud and Binero cloud supports this approach.
Tip
We do not recommend mixing a custom router/firewall with router. While its possible to do so, this will cause to make the network more difficult to understand. As such, rather give the instance running as a router a leg (a connection) to each of the private subnets that you want to reach and manage everything within the router.
Concepts¶
When working with a custom router, the main difference from the platform perspective is the port configuration, particularly the port security setting. Since the platform is (normally) aware of what IPs are existing behind each port, it filters traffic based on what it knows. This enables it to protect from various spoofing attempts and its also a prerequisite for using security groups.
When using a custom firewall/router, the port security feature does not work as destination traffic is no longer meant for the instance (a router receives traffic and forwards it - the destination is usually something other than the router).
Aside from the above its important to note that the usual manner of IP-assignments on the platform is DHCP which is included on a private subnet. It might be tempting to run a DHCP server on the custom routing solution instead or to simply disregard it and use manual networking. While this works, this will remove cloud-init support, resulting in instances no longer being correctly provisioned.
Setting up a custom router/firewall¶
Below is a guide on how to setup a router with a public (internet facing) outside network and a private subnet (which will work the same as with a router) for hosting instances on the inside of the router.
Note
Since some features below are only available using OpenStack Horizon (or OpenStack terminal client), we will use Horizon below.
Create your private networks and private subnet for the internal network(s) unless you have already done so.
Create a network port on the subnet. - Select fixed IP and add input the same ip as you selected as default route on the private subnet in the previous step. - Under security groups, add the “all-open” group (as the traffic will not be destined to the instance because of routing). Any firewalling to the router/firewall-instance will have to be setup on the instance. - Edit the new port and select the “Allowed address pairs” tab - Add “0.0.0.0/0” under the “IP Address or CIDR” field.
Launch the instance using an image or install it via console. - Add a directly attached IP as the outside network. - Connect to the port(s). Do not connect to the inside subnet, just the port(s) that you already created. - Select the “all-open” security group unless you want to filter traffic to the router in the platform (its recommended to use this feature in the router/firewall as that will simplify working with it.
When the instance is launched, follow these steps:
The outside (external) interface should use DHCP and get a statically directly assigned IP-address.
The internal interface could use either a static address (use the same as is assigned on the port(s)) or a DHCP provided adress, we recommend using a static address here.
Setup SNAT (see NAT for more info) on the instance. This is done in different manners depending on distribution and is out of scope for this article.
Your instances located behind this instance, and that use an IP on this instance as default route, should now be able to access the internet through it and you should be able to redirect (DNAT) traffic into the instances. If its not working, the following are some tips to check connectivity:
Verify that the router can reach the instances directly and vice versa.
Verify the security groups on all instances. The firewall/router should have “all-open” on all ports and “default” (as well) on the internal ports). If the firewall does not have default, other instances will not accept traffic from it and if it does not have the all-open group, it will not access traffic from the other instances.
Note
The platform uses a smaller MTU (1450) than is customary. There might be need to change this.