Why
Because I want to analyze the traffic across my LAN, and optimize accordingly.
Quick start via Docker
On my Linux router, make a folder for this service:
mkdir /opt/ntopng
cd /opt/ntopng
mkdir -p data/ntopng
mkdir -p data/redis
chmod 777 data/ntopng # to make sure mounted folder is accessible
chmod 777 data/redis # same as above
Note above I've given 777 permissions to data folders. This is because docker
-v
command mounts the files/folders with the host ownership PID:GID attached, in this case root:root
. However in the ntop/ntopng
docker image, the two data folders are originally owned by the redis
and ntopng
users only.Next we create a
docker-compose.yml
file under /opt/ntopng
:version: "3"
services:
ntopng:
image: ntop/ntopng:stable
command: --community -w 192.168.1.1:3000
volumes:
- ./data/ntopng:/var/lib/ntopng
- ./data/redis:/var/lib/redis
network_mode: host
restart: unless-stopped
network_mode: host
makes it monitor the bare-metal host interfaces directly instead of a docker default virtual network. We may no longer specify the exposed port in this way, the original readme ofntop/ntopng
with-p 3000:3000
is probably wrong.
--community
prevents it from starting as a pro trial version first, I'm using the community version anyway.
-w 192.168.1.1:3000
ensures the web service is only accessible from the LAN IP. I don't want to expose to the WAN IP yet.
volumes
are for persistent config/data between restarts. The ntopng RRD data are written to/var/lib/ntopng
, while some other configs like the admin passwords are saved under/var/lib/redis
.
Now we run
docker-compose up
in the folder, it should be up and running.Open the web portal http://192.168.1.1:3000/ and you should be greeted with a password reset guide. After this you can start monitoring your network data
data:image/s3,"s3://crabby-images/95447/9544787c2ffe1a6d217dc0aa47e880f19a25bd6d" alt="notion image"
Adding notifications to Telegram
Let's navigate to notifications/endpoints
data:image/s3,"s3://crabby-images/06553/0655358e43164864e5fea3d0f16aba5d6eb9c012" alt="notion image"
Click "+" on the top right
data:image/s3,"s3://crabby-images/48737/4873705e19d5cd16b5dd3c24a646690083ceee9e" alt="notion image"
Get a bot via the provided steps and fill in the token here.
data:image/s3,"s3://crabby-images/98a8a/98a8af1416e9681edb403f5fc8045599744b6045" alt="notion image"
Create a new channel/group on Telegram and add your bot as an admin.
data:image/s3,"s3://crabby-images/ae506/ae506fa9089f0292631a82426913400c58a23aba" alt="notion image"
Send any message in the channel and forward it to a bot (say @getidsbot) to get your channel id, in the form of
-1002155432156
.data:image/s3,"s3://crabby-images/08fab/08fabb51ff60a7928114fcd4b88823dd486c119b" alt="notion image"
Let's go back to ntopng/notifications/recipients, add the channel id above as the recipient. Click "Test Recipient" and you should get a test message:
data:image/s3,"s3://crabby-images/38432/38432e57708556d8900c4080e5b721b4752e074d" alt="notion image"
Finally, navigate to ntopng/pools/pools and add your monitor as a recipient for each categories.
data:image/s3,"s3://crabby-images/049e9/049e910b4e4440f8385e571e6e07d6ac31d7e222" alt="notion image"
You should be able to get the alerts in the Telegram channel from now on.
data:image/s3,"s3://crabby-images/96ac9/96ac922a9207c08f941c19e50588759205089681" alt="notion image"
What next?
- Optimize gaming experience by identifying the game server IP on ntopng and channel the traffic to a custom VPN (more on that next time)
- Identify suspicious network behavior
- You tell me?
See also
- ntopng official docker https://hub.docker.com/r/ntop/ntopng
- another ntopng docker image https://hub.docker.com/r/vimagick/ntopng
Loading Comments...