User Tools

Site Tools



vnStat is a console-based network traffic monitor for Linux and BSD that keeps a log of network traffic for the selected interface(s). It uses the network interface statistics provided by the kernel as information source. This means that vnStat won't actually be sniffing any traffic and also ensures light use of system resources. As it says on their website



opkg update
opkg install vnstat

LuCI Webgui Integration (optional)

opkg update
opkg install vnstati luci-app-vnstat

If you want language translation for the LuCI Webgui Integration then install the following:

opkg update
opkg install luci-i18n-vnstat-(YOUR_COUNTRY_CODE)

If you dont know which language codes are available you can search it with the following command:

opkg list | grep luci-i18n-vnstat-*

An example to Install German Translation for LuCI Webgui:

opkg update
opkg install luci-i18n-vnstat-de


The only configuring it really needs is to tell it what interface(s) to monitor, and some method of updating the database such as a cronjob. You might want to backup your database file. The vnstati package comes with a 'restore' and init.d script that downloads the backup from a webserver upon reboot. Its up to you to chose how to backup/restore the data( via HTTP/FTP/SSH/ETC)


This step is required for vnStat to function.

The common choice for monitoring is your WAN interface.

First, you have to find out which is your WAN Interface:

. /lib/functions/; if network_get_device if_wan wan; then
echo "Your WAN Interface is: $if_wan"; else echo "Cant find a active WAN Connection, please activate it"; fi

:!: The interface must be active for the above command to work. See ticket 19116.

If you have an already activated WAN connection, you will get the following output, for example:

Your WAN Interface is: pppoe-wan

Now edit /etc/vnstat.conf with your favourite editor and change the following two Lines:

Interface "pppoe-wan"
MaxBandwidth 1000
"Interface" is your WAN Interface you found out above and "MaxBandwidth" is the max possible bandwidth (in mbit) speed.

:!: MaxBandwidth must have the correct value, otherwise you will get wrong statistics from vnstat.

:!: MaxBandwidth means: How fast is your WAN Interface at most. MaxBandwidth 1000 = 1000 Mbit and MaxBandwidth 100 = 100 Mbit ! It has nothing to do with your Internet speed !

Then edit or create /etc/config/vnstat and change (or add) the following lines:

config vnstat
        list interface 'pppoe-wan'

Please Note: "pppoe-wan" is your WAN Interface you found out above !

Now you have to create the Database with this command:

vnstat -u -i pppoe-wan

Hint: vnStat normally uses "IEC prefixes" (MiB, GiB and so on). If you want old binary prefixes (MB, GB) change the following in /etc/vnstat.conf :

UnitMode 1

Database Updating

This step is required for vnStat to function. The package doesn't setup database updating at all. Its up to you to configure when vnStat will update. Use the daemon or a cron job.

Using included daemon:

Edit /etc/vnstat.conf and search for "UpdateInterval". Change "UpdateInterval" to the following:

UpdateInterval 300

UpdateInterval tells the daemon to update the Database every 300 seconds (5 minutes). If you want another Interval you can change it for your needs.

Run these commands to enable the daemon. This will also auto start the daemon if you reboot your device:

/etc/init.d/vnstat enable
/etc/init.d/vnstat start

/etc/config/vnstat is the database restore config, not the vnstatd config. vnstatd config is also located at /etc/vnstat.conf

This same init.d script will automatically download a database backup if you configured /etc/config/vnstat corrrectly. Useful for recovering db after a router reboot. Down side is that there is no implemented upload method using the uci config. You will need to write a script that cron will run to do all the uploading, so why not use the same protocol for downloading too? I suggest rsync, ftp, or scp.

Using a cronjob:

Add to crontab:

echo "*/5 * * * * vnstat -u" >> /etc/crontabs/root
Restart cron with:
/etc/init.d/cron restart

I don't recommend using crontab to update the vnStat Database.
Because if you update the Database with cron you will get weird statistics like: 16777216.00 TiB in one day.


Image Generation

You can install webif and it will generate images. But thats not lightweight so RealOpty developed scripts based off webif code that will generate the images without webif.

You might want to setup a crontab to execute this script every 15 min.

I always output the images to the tmpfs so it dont always write to flash.

# vnstati image generation script.
# Source:
WWW_D=/tmp/www/vnstat # output images to here
LIB_D=/var/lib/vnstat # db location
BIN=/usr/bin/vnstati  # which vnstati
outputs="s h d t m"   # what images to generate
# Sanity checks
[ -d "$WWW_D" ] || mkdir -p "$WWW_D" # make the folder if it dont exist.
# You might want to setup a link if it dont exist.
# [ -L /www/vnstat ] || ln -sf /www/vnstat /tmp/www/
# End of config changes
interfaces="$(ls -1 $LIB_D)"
if [ -z "$interfaces" ]; then
    echo "No database found, nothing to do."
    echo "A new database can be created with the following command: "
    echo "    vnstat -u -i eth0"
    exit 0
    for interface in $interfaces; do
        for output in $outputs; do
            $BIN -${output} -i $interface -o $WWW_D/vnstat_${interface}_${output}.png
exit 1

Sample HTML

<META HTTP-EQUIV="refresh" CONTENT="300">
    <title>Traffic of Interface eth1</title>
    <h2>Traffic of Interface eth1</h2>
                    <img src="vnstat_eth1_s.png" alt="eth1 Summary" />
                    <img src="vnstat_eth1_h.png" alt="eth1 Hourly" />
                <td valign="top">
                    <img src="vnstat_eth1_d.png" alt="eth1 Daily" />
                <td valign="top">
                    <img src="vnstat_eth1_t.png" alt="eth1 Top 10" />
                    <br />
                    <img src="vnstat_eth1_m.png" alt="eth1 Monthly" />

Persistent stats

vnStat stores stats to /var/lib/vnstat by default, and information may not persist across restarts. This means that one might want to relocate the database directory to other forms of persistent storage like your device's flash or external thumb drives. vnStat is configured to write to the database directory every 30mins by default, and this can be adjusted in vnStat's configuration.

For users considering to use your device's flash, be sure to consider the following points. I recommend the use of an external storage device.

  1. OpenWRT device's flash space is limited in size
  2. Database might not persist across firmware flashes, where your squashfs or jffs partition will be wiped
  3. Consistent writes to flash may 'kill' your flash (even though this may not be a major concern

Method 1

To store the database on the thumb drive, ensure that is working. Then, edit DatabaseDir in /etc/vnstat.conf to point to your flash drive, you may also want to modify SaveInterval to a larger value (the default 30min is still a good value) to minimise writes to flash.

Method 2

This method stores the database to a temporary directory in memory, and uses a cronjob script to backup and restore the database to your USB device. However, script may not be that useful since most of these functions can be done via vnStat's configuration (i.e. backup every 30mins to file), and this is left as an alternative since it has already been written.

Config files

In config files (/etc/vnstat.conf) please edit these lines:

DatabaseDir "/tmp/vnstat"

Don't forget edit vnstati (image output) generator script if you use it (config lines).


Please make this file for /etc/init.d/vnstatbackup

## Please visit
case $1 in
    echo "Please use 'backup' or 'restore' parameter for run";
exit 0


chmod 755 /etc/init.d/vnstatbackup

Add for cron and for init

Do this: (backup every 30 minute, if you want other backup window please read cron section)

echo "*/30 * * * * /etc/init.d/vnstatbackup backup" >> /etc/crontabs/root
/etc/init.d/cron restart

Edit /etc/rc.local, like this: (important: The last line in this file must be 'exit 0')

mount /dev/sda1 /usb
/etc/init.d/vnstatbackup restore
exit 0

Note: Dont use the first line if you haven't USB device.


A video demonstration of how vnStat 1.11-4 in the repositories can be installed on OpenWrt 14.07 Barrier Breaker:

doc/howto/vnstat.txt · Last modified: 2017/02/13 16:29 by MisterT