File: README.views

package info (click to toggle)
ntopng 5.2.1%2Bdfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 121,832 kB
  • sloc: javascript: 143,431; cpp: 71,175; ansic: 11,108; sh: 4,687; makefile: 911; python: 587; sql: 512; pascal: 234; perl: 118; ruby: 52; exp: 4
file content (16 lines) | stat: -rw-r--r-- 868 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Views Architecture
------------------

Vies are used to group interfaces into loginal interfaces.
When using views the sub/real interfaces handle flows only, hosts are allocated in the view interface only.

There is a SPSC queue for each sub/real interface belonging to the view interface.

NetworkInterface::viewEnqueue enqueues flows, from Flow::housekeep (incUses is used to make sure flows are not purged when still in use)
ViewInterface::viewDequeue dequeues flows in the view interface

viewed_flows_walker takes care of hosts allocation/update with the flow information coming from the sub/real interfaces.

Note: 
- in the real interface there is no host allocation, as a consequence of this the Flow contructor allocates IpAddress (cli_ip_addr) instead of Host (cli_host) 
- hosts are "Shared" between sub/real interfaces (pay attention to concurrent access)