Redundant Internet connections on consumer hardware with OpenWrt and Mwan3

Uplink 1

The first uplink uses the router's WAN port. It makes sense to combine the WAN port with the faster uplink of the available lines. Plug one end of the RJ45 cable into the cable modem and the other end into the WAN port of the AC1750 on the other. The DSL connection delivers 65 MBit/s downstream and 20 MBit/s upstream; the coaxial cable connection is more powerful at 500/50 and thus the standard connection.

It may be necessary to restart the cable modem after connecting to the AC1750. Using Luci, log into OpenWrt and configure the LAN port for DHCP. OpenWrt automatically enables IPv6 in parallel if a genuine dual stack is available from the Internet provider.

If everything works out, the WAN connection will have an IPv4 and an IPv6 address at the end of the process. In preparation for the dual WAN setup, it makes sense to click on Edit for the WAN interface in Luci and to type 10 in the Router Metric box. OpenWrt needs this metric later to prioritize the uplinks.

Uplink 2

Uplink 2 is a bit trickier, because OpenWrt doesn't have a port for it yet. To correct this problem, click on Network | Switch in Luci to display the configuration of the built-in switch.

In the case of the AC1750, two VLANs are configured, with ports 1 to 4 on VLAN 0 and the WAN port on VLAN 1. After pressing Add, you can add a VLAN 3. Then ensure that the port named Port 3 is only untagged on VLAN 3; for all other VLANs, however, the value in the table must be off. Finally, click on Save & Apply.

The other half of the configuration for uplink 2 consists of defining an interface in OpenWrt that uses the new VLAN. If you connect port 4 of the Archer C7 to your other uplink – such as the DSL modem, an Ethernet connection is established. But PPPoE is still missing for logging in on the provider side and thus establishing the connection.

Select Network | Interfaces. Add New Interface calls the required dialog. In Protocol of the new interface, select PPPoE or another suitable protocol. When it comes to selecting the interface, eth0.3 is the right choice for the VLAN 3 you just created. You have now created a logical connection between the VLAN and a PPPoE connection on the router. The name for the interface is WAN2 (Figure 3).

Figure 3: The additional WAN interface in OpenWrt must be connected to a physical interface (eth2 on the Omnia Turris).

Next, select Network | Interfaces and choose WAN2 Edit in the interface. In the following dialog, define the PPPoE connection parameters. Important: A routing metric must also be defined for WAN2, say, 20 in this example.

After you save the settings, OpenWrt establishes the connection automatically.

Setting Up Mwan3

Now that the connections are configured, the next step is to configure Mwan3 to switch between the two active connections. All in all, this arrangement works very well for IPv4, but IPv6 can cause complications (see the box entitled "Trouble with IPv6").

Trouble with IPv6

Mwan3 uses NAT and Iptables rules to implement load balancing. For IPv4, this approach works very well, but if you use Mwan3 with IPv6, it is less effective.

The main reason Mwan3 doesn't work well with IPv6 is because it uses NAT. IPv6 has a totally different way of defining private local networks, and the support for IPv6 in Mwan3 appears to have problems with address assignment using the RADVD protocol, which is a kind of like DHCP for IPv6.

To configure Mwan3 on OpenWrt, log into your router and run the opkg update command, which updates the OpenWrt package lists. Then run opkg install luci-app-mwan3, which installs both the GUI part of Mwan3 and the main Mwan3 application.

Once Mwan3 is set up, you can check its status and configuration via the web interface (Figure 4). Most admins, however, prefer editing the configuration file.

Figure 4: Once Mwan3 is configured, your can edit the configuration using the web interface.

The /etc/config/mwan3 file is the center for Mwan3 configuration. See the OpenWrt website [5] for more on editing the Mwan3 configuration file. The first block in the file specifies the source address for packets generated on the router. This section is followed by four definitions for the interfaces present in the system: two for IPv4 and two for IPv6. Using the list track_ip directive, the admin can determine which hosts Mwan3 pings to find out whether the line is online or offline. The other values are default parameters and can be adopted without changes.

The member paragraphs in the Mwan3 configuration assign metric values and weights to the NICs. However, these entries only become meaningful in the context of the following policy definitions. You need these policies to bundle several interfaces and the associated metrics and weights to create a complete package.

At the bottom are the rule paragraphs, which define concrete rules for certain types of traffic from certain sources or with certain destinations. The https rule in the example specifies that the same connection must always be used for HTTPS connections. sticky specifies that connections must not switch between interfaces.

See the Mwan3 documentation for more on configuring Mwan3 settings.

Buy this article as PDF

Express-Checkout as PDF
Price $2.95
(incl. VAT)

Buy Linux Magazine

SINGLE ISSUES
 
SUBSCRIPTIONS
 
TABLET & SMARTPHONE APPS
Get it on Google Play

US / Canada

Get it on Google Play

UK / Australia

Related content

  • Tuning WLAN Routers

    Learn how to take control of your home routing device with OpenWrt.

  • Free Software Projects

    OpenWRT puts Linux on WLAN routers and helps users set up large-scale WLANs at home, and the FreeWRT derivative adds a professional touch. If you don’t have your own compile farm, the OpenSUSE build service may be just what you need. And we investigate the obstacles to new packages for Debian.

  • Gargoyle: Web Interface for Router Configuration

    The Gargoyle project is working on an alternative web interface for better router configuration. The project has now reached its first stable version 1.0.

  • Repurposed Router Projects

    If you have an old router lying around, you can put it to good use with a few easy projects and learn something along the way.

  • SSH Reverse Tunnels

    We’ll show you a practical project for monitoring home energy usage with SSH and OpenWrt.

comments powered by Disqus
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters

Support Our Work

Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.

Learn More

News