Enhancement #3319
Ntopng: optimize redis memory usage
| Status: | CLOSED | Start date: | ||
|---|---|---|---|---|
| Priority: | Normal | Due date: | ||
| Assignee: | - | % Done: | 100% | |
| Category: | nethserver-ntopng | |||
| Target version: | v6.7 | |||
| Resolution: | NEEDINFO: | No | 
Description
Ntopng heavily uses redis to save temporary data about host network traffic.
In a scenario where there are many hosts involved, ntopng will highly increase redis memory usage.
- use a separated instance of redis only for ntopng
- remove dependency from nethserver-redis
- limit redis memory usage
- avoid useless db dumps on disk
Related issues
Associated revisions
spec: remove nethserver-redis dependency. Refs #3319
Add ntopng-redis instance. Refs #3319
ntopng-redis.conf: change maxmemory-policy. Refs #3319
History
#1
     Updated by Giacomo Sanchietti over 5 years ago
    Updated by Giacomo Sanchietti over 5 years ago
    - Status changed from NEW to TRIAGED
- Target version set to v6.7
- % Done changed from 0 to 20
#2
     Updated by Giacomo Sanchietti over 5 years ago
    Updated by Giacomo Sanchietti over 5 years ago
    - Status changed from TRIAGED to ON_DEV
- Assignee set to Giacomo Sanchietti
- % Done changed from 20 to 30
#3
     Updated by Filippo Carletti over 5 years ago
    Updated by Filippo Carletti over 5 years ago
    ntopng sources now contain this readme file:
$ cat doc/README.redis 
In order to avoid redis fillup all the available memory please set some memory limit in /etc/redis.conf
It is a good idea to setup some upper limits such as:
maxmemory 300mb
maxmemory-policy volatile-lru
#4
     Updated by Giacomo Sanchietti over 5 years ago
    Updated by Giacomo Sanchietti over 5 years ago
    - Status changed from ON_DEV to MODIFIED
- Assignee deleted (Giacomo Sanchietti)
- % Done changed from 30 to 60
#5
     Updated by Giacomo Sanchietti over 5 years ago
    Updated by Giacomo Sanchietti over 5 years ago
    - Related to Task #3304: Update redis from remi added
#6
     Updated by Giacomo Sanchietti over 5 years ago
    Updated by Giacomo Sanchietti over 5 years ago
    - Status changed from MODIFIED to ON_QA
- % Done changed from 60 to 70
- nethserver-ntopng-1.2.3-1.2.gbc55db5.ns6.noarch.rpm
- Update an existing installation where ntopng is enabled
- Ntopng should continue running without problems
- Two instances of redis should be running
- Install on a new machine and enable ntopng
- Ntopng must be running
- Only one instance of redis should be running
Note
The default redis instance is no longer required.
To cleanup the system after an upgrade execute:
service redis stop yum remove nethserver-redis rm -f /var/lib/redis/*
#7
     Updated by Filippo Carletti over 5 years ago
    Updated by Filippo Carletti over 5 years ago
    - Status changed from ON_QA to VERIFIED
- % Done changed from 70 to 90
Test case 1 - update
Before update:
[root@nscom ~]# ps -ef | egrep "redis|ntopng" redis 592 1 0 17:44 ? 00:00:00 /usr/sbin/redis-server /etc/redis.conf nobody 663 1 2 17:45 ? 00:00:01 /usr/bin/ntopng /etc/ntopng/ntopng.conf
After update:
[root@nscom ~]# ps -ef | egrep "redis|ntopng" redis 592 1 0 17:44 ? 00:00:00 /usr/sbin/redis-server /etc/redis.conf root 714 1 0 17:47 ? 00:00:00 /usr/sbin/redis-server /etc/redis-ntopng.conf nobody 721 1 3 17:47 ? 00:00:00 /usr/bin/ntopng /etc/ntopng/ntopng.conf
Test case 2 - new install
Before install:
[root@ns67-ent ~]# ps -ef | grep redis root 7470 6757 0 19:33 pts/0 00:00:00 grep redis
After:
[root@ns67-ent ~]# ps -ef | grep redis root 7514 1 0 09:47 ? 00:00:00 /usr/sbin/redis-server /etc/redis-ntopng.conf [root@ns67-ent ~]# ps -ef | grep ntop root 7514 1 0 09:47 ? 00:00:00 /usr/sbin/redis-server /etc/redis-ntopng.conf nobody 14258 1 3 09:55 ? 00:00:00 /usr/bin/ntopng /etc/ntopng/ntopng.conf
#8
     Updated by Giacomo Sanchietti over 5 years ago
    Updated by Giacomo Sanchietti over 5 years ago
    - Status changed from VERIFIED to CLOSED
- % Done changed from 90 to 100
- nethserver-ntopng-1.3.0-1.ns6.noarch.rpm