keenetic-pbr is not an official product of the Keenetic company and is in no way affiliated with it. This package is created by an independent developer and is provided "as is" without any warranty. Any questions and suggestions regarding the package can be submitted to the GitHub Issues page or the Telegram chat: https://t.me/keenetic_pbr.
- Make sure you've updated to at least version
v-1.3.0-2
- Disable lists auto-update after package installation/update
This will help prevent excessive wear of the router's NAND-flash memory.
keenetic-pbr is a policy-based routing package for Keenetic routers.
Project Telegram chat (in Russian): https://t.me/keenetic_pbr
With this package, you can set up selective routing for specified IP addresses, subnets, and domains. This is useful if you need to organize secure access to certain resources or selectively distribute traffic across multiple providers (e.g., traffic to site A goes through one provider, while other traffic goes through another).
The package uses ipset
to store a large number of addresses in the router's memory without significantly increasing load and dnsmasq
to populate this ipset
with IP addresses resolved by local network clients.
To configure routing, the package creates scripts in the directories /opt/etc/ndm/netfilter.d
and /opt/etc/ndm/ifstatechanged.d
.
- Domain-based routing via
dnsmasq
- IP address-based routing via
ipset
- Configurable routing tables and priorities
- Automatic configuration for
dnsmasq
lists
This package contains the following scripts and utilities:
/opt
├── /usr
│ └── /bin
│ └── keenetic-pbr # Utility for downloading and processing lists, importing them to ipset, and generating configuration files for dnsmasq
└── /etc
├── /keenetic-pbr
│ ├── /keenetic-pbr.conf # keenetic-pbr configuration file
│ └── /lists.d # keenetic-pbr will place downloaded and local lists in this folder. Don't put anything here yourself, as files from this folder are deleted after each "keenetic-pbr download" command.
├── /ndm
│ ├── /netfilter.d
│ │ └── 50-keenetic-pbr-fwmarks.sh # Script adds iptables rule for marking packets in ipset with a specific fwmark
│ └── /ifstatechanged.d
│ └── 50-keenetic-pbr-routing.sh # Script adds ip rule to direct packets with fwmark to the required routing table and creates it with the needed default gateway
├── /cron.daily
│ └── 50-keenetic-pbr-lists-update.sh # Script for automatic daily list updates
└── /dnsmasq.d
└── (config files) # Folder with generated configurations for dnsmasq, making it put IP addresses of domains from lists into the required ipset
keenetic-pbr automatically loads IP addresses and subnets from lists into the required ipset
. Then packets to IP addresses that were added into this ipset
are marked with a specific fwmark
and based on routing rules are redirected to a specific interface.
For domain-based routing, dnsmasq
is used. Each time local network clients make a DNS request, dnsmasq
checks if the domain is in the lists, and if it is, adds its IP addresses to ipset
.
Note
For domain routing to work, client devices must not use their own DNS servers. Their DNS server should be the router's IP, otherwise dnsmasq
won't see these packets and won't add IP addresses to the required ipset
.
Important
Some applications and games use their own methods to obtain IP addresses for their servers. For such applications, domain routing won't work because these applications don't make DNS requests. You'll have to find out the IP addresses/subnets of these applications' servers and add them to the lists manually.
- Package functionality has been tested on Keenetic OS version 4.2.1. Functionality on version 3.x.x is possible but not guaranteed.
- You need to install additional components on your router in the Management -> System settings section:
- Network Functions / IPv6 Protocol
- This component is required to install the "Netfilter Subsystem Kernel Modules" component.
- OPKG Packages / Open Package System Support
- OPKG Packages / Netfilter Subsystem Kernel Modules
- OPKG Packages / Xtables-addons Extension Package for Netfilter
- Currently, this package is not mandatory as its capabilities are not used by keenetic-pbr, but its features may be useful in the future. Module instructions are available here.
- Network Functions / IPv6 Protocol
- You need to install Entware environment on Keenetic (instructions), for this you'll need a USB drive that will be permanently plugged into the router
- You also need to configure a second (third, fourth, ...) connection through which you want to direct traffic that falls under the lists. This can be a VPN connection or a second provider (multi-WAN).
- Your devices must be in the Default Internet Access Policy (Connection Priorities -> Policy Bindings section). Otherwise, the device may ignore all rules applied by keenetic-pbr.
Connect to your EntWare using SSH and run the following command:
opkg install curl jq && curl -sOfL https://raw.githubusercontent.com/maksimkurb/keenetic-pbr/refs/heads/main/install.sh && sh install.sh
Caution
If Entware is installed on the router's internal memory, be sure to disable lists auto-update to prevent NAND-flash memory wear!
-
Go to releases page and copy URL for the latest
.ipk
file for your architecture. -
Download the
.ipk
file on your router:curl -LO <URL-to-latest-ipk-file-for-your-architecture>
-
Install it using OPKG:
opkg install keenetic-pbr-*-entware.ipk
During installation, the keenetic-pbr
package replaces the original dnsmasq configuration file.
A backup of your original file is saved as /opt/etc/dnsmasq.conf.orig
.
Caution
If Entware is installed on the router's internal memory, be sure to disable lists auto-update to prevent NAND-flash memory wear!
Adjust the following configuration files according to your needs:
- (required) Keenetic-PBR configuration:
/opt/etc/keenetic-pbr/keenetic-pbr.conf
- In this file, you must configure the required ipsets, lists, and output interfaces
- (optional) Disable lists auto-update:
/opt/etc/cron.daily/50-keenetic-pbr-lists-update.sh
- If Entware is installed on internal memory, it is strongly recommended to disable lists auto-update to prevent NAND-flash memory wear
- (optional) dnsmasq configuration:
/opt/etc/dnsmasq.conf
- This file can be reconfigured for your needs, e.g. you can replace the upstream DNS server with your own
- It is recommended to install and configure the
dnscrypt-proxy2
package, and then specify the settingserver=127.0.0.1#9153
indnsmasq.conf
so that DNS requests are protected by DNS-over-HTTPS (DoH)
Open /opt/etc/keenetic-pbr/keenetic-pbr.conf
and edit as needed:
- You need to adjust the
interface
field, specifying the interface through which outgoing traffic that matches the list criteria will go. - You also need to add lists (local or remote via URL)
Configuration example: (you don't need to copy this example, you can just edit the file that comes with the package)
#-------------#
# IPSET 1 #
#-------------#
[[ipset]]
ipset_name = "vpn" # Name of the ipset
ip_version = 4 # IPv4 or IPv6
flush_before_applying = true # Clear ipset each time before filling it
[ipset.routing]
interfaces = ["nwg1", "nwg2"] # Where the traffic for IPs in this ipset will be directed
# keenetic-pbr will use first interface that is administratively up.
# If use_keenetic_api is enabled, keenetic-pbr will also check if there is an active connection on this interface.
kill_switch = false # If kill-switch is turned on and all interfaces all down, traffic to the hosts from ipset will be dropped
fwmark = 1001 # This fwmark will be applied to packets matching the list criteria
table = 1001 # Routing table number (ip route table); a default gateway to the specified interface above will be added there
priority = 1001 # Routing rule priority (ip rule priority); the lower the number, the higher the priority
# Advanced settings: you can specify custom iptables rules that will be applied for the ipset.
# Available variables:
# {{ipset_name}} - name of the ipset
# {{fwmark}} - fwmark
# {{table}} - number of the routing table
# {{priority}} - priority of the routing rule
#
#[[ipset.iptables_rule]]
#chain = "PREROUTING"
#table = "mangle"
#rule = ["-m", "set", "--match-set", "{{ipset_name}}", "dst,src", "-j", "MARK", "--set-mark", "{{fwmark}}"]
# List 1 (manual address entry)
[[ipset.list]]
name = "local"
hosts = [
"ifconfig.co",
"myip2.ru",
"1.2.3.4",
"141.201.11.0/24",
]
# List 2 (from local file)
[[ipset.list]]
name = "local-file"
file = "/opt/etc/keenetic-pbr/my-list.lst"
# List 3 (download via URL)
[[ipset.list]]
name = "remote-list-1"
url = "https://some-url/list1.lst" # The file should contain domains, IP addresses, and CIDR, one per line
# List 4 (download via URL)
[[ipset.list]]
name = "remote-list-2"
url = "https://some-url/list2.lst"
# You can add as many ipsets as you want:
# [[ipset]]
# ipset_name = "direct"
# ...
After editing the configuration file, enter this command to download list files:
keenetic-pbr download
Caution
If Entware is installed on the router's internal memory, you must disable daily automatic list updates to prevent NAND memory wear.
This command needs to be executed after each keenetic-pbr package update!
To disable list auto-updates, delete the file /opt/etc/cron.daily/50-keenetic-pbr-lists-update.sh
:
rm /opt/etc/cron.daily/50-keenetic-pbr-lists-update.sh
You can always update lists manually.
Tip
The regular DNS protocol is not secure as all requests are transmitted in plain text. This means that ISPs or attackers can intercept and modify your DNS requests (DNS spoofing), directing you to a fake website.
To protect from this, it is recommended to configure the dnscrypt-proxy2
package, which will use the DNS-over-HTTPS (DoH) protocol to encrypt DNS requests.
You can read more about DoH here.
To configure DoH on the router, follow these steps:
-
Download
dnscrypt-proxy2
opkg install dnscrypt-proxy2
-
Edit the file
/opt/etc/dnscrypt-proxy.toml
# ... (other config lines here, don't delete them) # Specify upstream servers (need to remove the hash before server_names) server_names = ['adguard-dns-doh', 'cloudflare-security', 'google'] # Specify port 9153 for listening to DNS requests listen_addresses = ['[::]:9153'] # ... (other config lines here, don't delete them)
-
Edit the file
/opt/etc/dnsmasq.conf
# ... (other config lines here, don't delete them) # Change default server 8.8.8.8 to our dnscrypt-proxy2 server=127.0.0.1#9153 # ... (other config lines here, don't delete them)
-
Restart
dnscrypt-proxy2
anddnsmasq
/opt/etc/init.d/S09dnscrypt-proxy2 restart /opt/etc/init.d/S56dnsmasq restart
To make dnsmasq
as the main DNS server on the router, you need to enable DNS Override.
Note
This step is not required if your lists contain only IP addresses or CIDRs and do not specify domain names.
- Open the following URL in the browser:
http://<router-ip-address>/a
- Enter the following commands one by one:
opkg dns-override
system configuration save
Tip
If you ever decide to disable DNS Override in the future, execute the following commands: no opkg dns-override
and system configuration save
.
Restart OPKG and ensure policy-based routing is functioning as expected.
To do this, open an address that is not in your lists (e.g., https://2ip.ru) and an address that is in your lists (e.g., https://ifconfig.co) and compare the IP addresses, they should be different.
- Lists are updated daily by cron automatically.
- If you have installed Entware on internal memory, please disable lists auto-update to prevent NAND memory wear.
If you edited the keenetic-pbr.conf
settings and want to update lists manually, run the following commands via SSH:
keenetic-pbr download
/opt/etc/init.d/S80keenetic-pbr restart
For any issues, verify your configuration files and logs.
Ensure lists are downloaded correctly, and dnsmasq
is running with the updated configuration.
Before checking the workability on the client machine, you need to clear the DNS cache.
To do this, run the command in the console (for Windows): ipconfig /flushdns
.
You can also run the following command to check if Keenetic-PBR is working correctly (output of this command will be very helpful if you ask for help in the Telegram chat):
keenetic-pbr self-check
You can ask questions in the Telegram chat of the project: https://t.me/keenetic_pbr
Enjoy seamless policy-based routing with Keenetic-PBR!