Find a file
Toni Uhlig c152e41cfb
README.md ascii update
Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
2021-09-14 18:54:33 +02:00
cmake Switched to CMake build system. 2021-03-17 17:41:19 +01:00
dependencies Improved nDPIsrvd buffer bloat handling using caching. 2021-08-04 17:19:15 +02:00
examples bump libnDPI to 6b7e5fa8d251f11c1bae16ea892a43a92b098480 2021-08-03 12:37:59 +02:00
libnDPI@0eb7a0388c bump libnDPI to 0eb7a0388c4549ebbf8cd7a10d398088005cc2de 2021-09-14 18:19:47 +02:00
schema Reworked layer 4 flow length naming/calculation. 2021-05-20 14:55:05 +02:00
scripts Improved nDPIsrvd buffer bloat handling using caching. 2021-08-04 17:19:15 +02:00
test bump libnDPI to 0eb7a0388c4549ebbf8cd7a10d398088005cc2de 2021-09-14 18:19:47 +02:00
.clang-format clang-format and set BreakBeforeBraces to Allmanz 2020-07-10 20:48:23 +02:00
.gitignore Build system cleanup / cosmetics. 2021-06-07 16:22:49 +02:00
.gitlab-ci.yml Gitlab-CI 2021-08-03 13:06:12 +02:00
.gitmodules Git submodule libnDPI update. 2021-05-12 12:46:49 +02:00
.travis.yml Updated CMake nDPId-test target; 2021-06-18 14:34:09 +02:00
CMakeLists.txt fixed Warnings / build error / cosmetics 2021-09-14 18:38:37 +02:00
config.h Improved nDPIsrvd buffer bloat handling using caching. 2021-08-04 17:19:15 +02:00
COPYING Added GPL-3 License. 2021-05-11 16:33:34 +02:00
nDPId-test.c Improved nDPIsrvd buffer bloat handling using caching. 2021-08-04 17:19:15 +02:00
nDPId.c fixed Warnings / build error / cosmetics 2021-09-14 18:38:37 +02:00
nDPIsrvd.c fixed Warnings / build error / cosmetics 2021-09-14 18:38:37 +02:00
README.md README.md ascii update 2021-09-14 18:54:33 +02:00
TODO.md Improved nDPIsrvd buffer bloat handling using caching. 2021-08-04 17:19:15 +02:00
utils.c Improved and Fixed another buffering issue caused by removing an outgoing fd too early from epoll queue (EPOLLOUT). 2021-08-05 02:02:51 +02:00
utils.h Git tag/commit version printing for nDPId/nDPIsrvd. Reduces confusion. 2021-06-08 15:23:33 +02:00

Travis-CI Gitlab-CI

abstract

nDPId is a set of daemons and tools to capture, process and classify network flows. It's only dependencies (besides a half-way modern c library and POSIX threads) are libnDPI (>= 3.5.0 or current github dev branch) and libpcap.

The core daemon nDPId uses pthread but does use mutexes for performance reasons. Instead synchronization is achieved by a packet distribution mechanism. To balance all workload to all threads (more or less) equally a hash value is calculated using the 5-tuple. This value serves as unique identifier for the processing thread. Multithreaded packet processing has to be flow-stable.

nDPId uses libnDPI's JSON serialization to produce meaningful JSON output which it then sends to the nDPIsrvd for distribution. High level applications can connect to nDPIsrvd to get the latest flow/packet events from nDPId.

Unfortunately nDPIsrvd does currently not support any encryption/authentication for TCP connections.

architecture

This project uses some kind of microservice architecture.

                connect to UNIX socket          connect to UNIX/TCP socket                
_______________________   |                                 |   __________________________
|     "producer"      |___|                                 |___|       "consumer"       |
|---------------------|      _____________________________      |------------------------|
|                     |      |        nDPIsrvd           |      |                        |
| nDPId --- Thread 1 >| ---> |>           |             <| ---> |< example/c-json-stdout |
| (eth0) `- Thread 2 >| ---> |> collector | distributor <| ---> |________________________|
|        `- Thread N >| ---> |>    >>> forward >>>      <| ---> |                        |
|_____________________|  ^   |____________|______________|   ^  |< example/py-flow-info  |
|                     |  |                                   |  |________________________|
| nDPId --- Thread 1 >|  `- send serialized data             |  |                        |
| (eth1) `- Thread 2 >|                                      |  |< example/...           |
|        `- Thread N >|             receive serialized data -'  |________________________|
|_____________________|                                                                   

It doesn't use a producer/consumer design pattern, so the wording is not precise.

JSON TCP protocol

All JSON strings sent need to be in the following format:

[5-digit-number][JSON string]

Example:

00015{"key":"value"}

where 00015 describes the length of a complete JSON string.

build (CMake)

mkdir build
cd build
cmake ..

or

mkdir build
cd build
ccmake ..

or to build with a staticially linked libnDPI:

mkdir build
cd build
cmake .. -DSTATIC_LIBNDPI_INSTALLDIR=[path/to/your/libnDPI/installdir]

If you're using the latter one, make sure that you've configured libnDPI with ./configure --prefix=[path/to/your/libnDPI/installdir] and do not forget to set the all necessary CMake variables to link against shared libraries used by your nDPI build.

e.g.:

mkdir build
cd build
cmake .. -DSTATIC_LIBNDPI_INSTALLDIR=[path/to/your/libnDPI/installdir] -DNDPI_WITH_GCRYPT=ON -DNDPI_WITH_PCRE=OFF -DNDPI_WITH_MAXMINDDB=OFF

Or if this is all too much for you, let CMake do it for you:

mkdir build
cd build
cmake .. -DBUILD_NDPI=ON

run

Generate a nDPId compatible JSON dump:

./nDPId-test [path-to-a-PCAP-file]

Daemons:

./nDPIsrvd -d
sudo ./nDPId -d

or for a usage printout:

./nDPIsrvd -h
./nDPId -h

And why not a flow-info example?

./examples/py-flow-info/flow-info.py

or

./nDPIsrvd-json-dump

or anything below ./examples.

test

The recommended way to run integration / diff tests:

mkdir build
cd build
cmake .. -DBUILD_NDPI=ON
make nDPId-test test

Alternatively you can run some integration tests manually:

./test/run_tests.sh [/path/to/libnDPI/root/directory] [/path/to/nDPId-test]

e.g.:

./test/run_tests.sh [${HOME}/git/nDPI] [${HOME}/git/nDPId/build/nDPId-test]

Remember that all test results are tied to a specific libnDPI commit hash as part of the git submodule. Using test/run_tests.s for other commit hashes will most likely result in PCAP diff's.