820 - Oasislink from local to central as TCP server
- logtransfer and federation FastAPI backend mostly finished and tested (see open points below)
- rudimentary class for additional statistics (queries to mongodb) that can be transferred
- currently this is located in
logtransfer.py
(it shouldn't be within the main Nomad API as this can run with multiple workers, which turned out to be problematic in the past) - we agreed that we use reasonable cases from the KPI as well as statistics required for the homepage
- currently this is located in
- Check documentation for data sharing in oasis.md
- The test case that sometimes used failed for remote CI pipeline is (hopefully) fixed
Relates to issues #820 (closed) and #886 (closed) This merge request follows up the closed merge requests !697 (closed), !727 (closed) and !784 (closed).
Here the logtransfer is implemented in a separate service to the Nomad app - a TCP Server (Python native classes). In particular the service runs on a local Nomad Oasis and receives logs on the same address and port than where logstash logs are sent on the central Oasis.
For Nomad Oasis the server running on logtransfer can therefore be interpreted as a logstash proxy. Unless running the logstash instance itself, all logs are submitted to the central Oasis where the logs are then eventually stored in logstash.
Open questions:
-
To identify a local Oasis we read the IP address on the FastAPI receiving end. Do we still need to adapt the field deployment_id
per local instance (we would make sure that this is unique -- maybe taking a hash from some config parameters)?
To clarify:
-
A problem for testing is currently, that when the app is started with nomad app run app
, then there the logs are different set than to the log config in docker. Should this maybe be fixed? (If starting Nomad withnomad app run app
, then no API calls are processed in logstash format). -
Use threading TCP server? If a client does not close the connection to the logstash proxy server, it can block the whole server. ThreadingTCP
server is only supported for UNIX systems. -
Validate IP address that was received in federation/logs? -
Protect against malicious (gzipped) content? - against too large data (load into main memory)
- against gzip bombs (uncompress too much data into main memory)
- too many newlines in the data (long running loop)
Merge request reports
Activity
added 55 commits
-
31eccb4b...2cbf0732 - 54 commits from branch
develop
- b572ac0c - oasislink as a TSCServer
-
31eccb4b...2cbf0732 - 54 commits from branch
added 6 commits
-
e187ce28...951579df - 5 commits from branch
develop
- a0210559 - oasislink as a TSCServer
-
e187ce28...951579df - 5 commits from branch
added 35 commits
-
a0210559...c902a67f - 33 commits from branch
develop
- 9c2e02d2 - oasislink as a TSCServer
- c1455681 - refactor
-
a0210559...c902a67f - 33 commits from branch
added 11 commits
-
c1455681...a3f88509 - 9 commits from branch
develop
- 6b7ece50 - oasislink as a TSCServer
- cb7e1577 - refactor
-
c1455681...a3f88509 - 9 commits from branch
added 31 commits
-
cb7e1577...8502ca0f - 28 commits from branch
develop
- 79f2d3c8 - oasislink as a TSCServer
- 37db3554 - refactor
- 9176d4d8 - update
Toggle commit list-
cb7e1577...8502ca0f - 28 commits from branch
added 13 commits
-
f4db93ca...5ce97564 - 2 commits from branch
develop
- dc62ec7f - oasislink as a TSCServer
- ecdb590d - refactor
- 13020e5a - update
- ec513cb4 - update
- bf1e7b29 - update
- a4e043b9 - WIP (tests are passing)
- 3c0ca0e9 - update
- 91f9a740 - update
- 1198da5f - update
- c31e0d3d - update gui artifacts
- 04efde77 - code cleaning (improve linting)
Toggle commit list-
f4db93ca...5ce97564 - 2 commits from branch