The manager service for monitoring solution. Responsible for:
- Model registration
- Model data discovery (training and inference)
- Plugin registration
- Plugin reports aggregation
- Proxying HTTP requests to plugins
A plugin is a web service that MUST use GRPC API for plugin management
Plugins can expose their own web UI as a module that will be attached to our UI. The HTTP requests sent from the web UI are to be proxied by manager.
Lifecycle of a plugin:
- (Optional) Internal initialization of a plugin.
- (If plugin provides web UI) Start HTTP server.
- Call
PluginManagementService.RegisterPlugin
GRPC method with plugin info. - Call
ModelCatalogService.GetModelUpdates
to get endless stream of models to work with. - (Optional) Process training data of models.
- Call
DataStorageService.GetInferenceDataUpdates
to get endless stream of inference files of a model. - (Optional) Process inference data of models.
The documentation is in progress, and you can find everything related to this service in docs folder.
This project also keeps track of major decisions using ADRs. You can find them in docs/adr folder.
sbt build
- builds docs, jars, and a docker image with this service.
sbt testAll
- runs unit and integration tests. Integration tests require docker.