Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aneoconsulting/armonik.core
Task manager for ArmoniK (submission, scheduling, IO data, monitoring). Implements API located in https://github.com/aneoconsulting/ArmoniK.Api
https://github.com/aneoconsulting/armonik.core
armonik core scheduler
Last synced: about 1 month ago
JSON representation
Task manager for ArmoniK (submission, scheduling, IO data, monitoring). Implements API located in https://github.com/aneoconsulting/ArmoniK.Api
- Host: GitHub
- URL: https://github.com/aneoconsulting/armonik.core
- Owner: aneoconsulting
- License: agpl-3.0
- Created: 2022-01-12T08:48:10.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T22:48:11.000Z (3 months ago)
- Last Synced: 2024-10-30T00:47:27.044Z (3 months ago)
- Topics: armonik, core, scheduler
- Language: C#
- Homepage: https://aneoconsulting.github.io/ArmoniK.Core/
- Size: 14 MB
- Stars: 10
- Watchers: 6
- Forks: 8
- Open Issues: 36
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
[![License: AGPL v3](https://img.shields.io/badge/License-AGPL_v3-green.svg)](https://www.gnu.org/licenses/agpl-3.0)
# ArmoniK.Core
| Stable | Edge |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [![Docker image latest version](https://img.shields.io/docker/v/dockerhubaneo/armonik_pollingagent?color=fe5001&label=armonik_pollingagent&sort=semver)](https://hub.docker.com/r/dockerhubaneo/armonik_pollingagent) | [![Docker image latest version](https://img.shields.io/docker/v/dockerhubaneo/armonik_pollingagent?color=fe5001&label=armonik_pollingagent&sort=date)](https://hub.docker.com/r/dockerhubaneo/armonik_pollingagent) |
| [![Docker image latest version](https://img.shields.io/docker/v/dockerhubaneo/armonik_control_metrics?color=fe5001&label=armonik_control_metrics&sort=semver)](https://hub.docker.com/r/dockerhubaneo/armonik_control_metrics) | [![Docker image latest version](https://img.shields.io/docker/v/dockerhubaneo/armonik_control_metrics?color=fe5001&label=armonik_control_metrics&sort=date)](https://hub.docker.com/r/dockerhubaneo/armonik_control_metrics) |
| [![Docker image latest version](https://img.shields.io/docker/v/dockerhubaneo/armonik_control_partition_metrics?color=fe5001&label=armonik_control_partition_metrics&sort=semver)](https://hub.docker.com/r/dockerhubaneo/armonik_control_partition_metrics) | [![Docker image latest version](https://img.shields.io/docker/v/dockerhubaneo/armonik_control_partition_metrics?color=fe5001&label=armonik_control_partition_metrics&sort=date)](https://hub.docker.com/r/dockerhubaneo/armonik_control_partition_metrics) |
| [![Docker image latest version](https://img.shields.io/docker/v/dockerhubaneo/armonik_control?color=fe5001&label=armonik_control&sort=semver)](https://hub.docker.com/r/dockerhubaneo/armonik_control) | [![Docker image latest version](https://img.shields.io/docker/v/dockerhubaneo/armonik_control?color=fe5001&label=armonik_control&sort=date)](https://hub.docker.com/r/dockerhubaneo/armonik_control) |## What is ArmoniK.Core?
This project is part of the [ArmoniK](https://github.com/aneoconsulting/ArmoniK) project. ArmoniK.Core is responsible for the implementation of the services needed for ArmoniK which are defined in [ArmoniK.Api](https://github.com/aneoconsulting/ArmoniK.Api).
ArmoniK.Core provides services for submitting computational tasks, keeping track of the status of the tasks and retrieving the results of the computations. The tasks are processed by external workers whose interfaces are also defined in ArmoniK.Api. ArmoniK.Core sends tasks to the workers, manages eventual errors during the execution of the tasks and manages also the storage of the task's results.
More detailed information on the inner working of ArmoniK.Core is available [here](https://aneoconsulting.github.io/ArmoniK.Core/).
## Development process
This repository follows trunk based development so all features will be integrated into main, in multiple small steps.
Breaking changes will be limited as much as possible or gated behind feature flags.
If breaking changes should happen, they will be documented in the releases.
Therefore, features in development or testing that cannot fit within a branch and need to be integrated into main will be marked as preview so that users know that these features are still in development and subject to changes.**General availability (GA):** The APIs, plugins and features are thoroughly tested and support is available.
**Preview:** The APIs, plugins and features that are available on main but still in development. Their API should be stable enough for advanced users who want to test them before GA. Breaking changes should be minimal and will be notified in the release notes. Any feedback or issue encountered with these features are welcome !
**Beta (Internal preview):** The APIs, plugins and features in active development. They are not stable enough and breaking changes may occur without any notice. Breaking changes will not always be documented. They can be used by the community for testing purposes. Before being moved to the "Preview" stage, issues might be closed with the minimal messages "Under Active Development".
**Deprecated:** The deprecated APIs, plugins and features. Features are flagged for future removal. Only production critical bug fixes will be considered.
**Work in progress (WIP):** The APIs, plugins and features are not fully implemented and may have some missing parts.| Plugins | Type | Description | Status |
|----------|----------------|-----------------------------------------------|---------|
| RabbitMQ | Queue | RabbitMQ client using AMQP protocol 0.9.2 | GA |
| AMQP | Queue | AMQP client using AMQP protocol 1.0.0 | GA |
| PubSub | Queue | Google PubSub client | GA |
| SQS | Queue | AWS SQS client | Preview |
| Redis | Object Storage | Redis client used to store binary data | GA |
| Local | Object Storage | File system used to store binary data | GA |
| S3 | Object Storage | AWS S3 client used to store binary data | GA |
| MongoDB | Database | MongoDB client to store ArmoniK internal data | GA || APIs | Description | Status |
|-------------------------------|-------------------------------------------------------------------------------------|------------|
| Agent.CreateTask | Streamed RPC to submit payloads and tasks from the worker | Deprecated |
| Agent.Get*Data | RPC to get special Results | WIP |
| Agent.* | Service to submit created results, create new results and new tasks from the worker | GA |
| Applications.ListApplications | RPC to list applications | GA |
| Authentication.GetCurrentUser | RPC to retrieve the current logged-in user | GA |
| Events.GetEvents | Streamed RPC to subscribe to task and result events during execution | GA |
| HealthChecks.CheckHealth | RPC to get an overview of the cluster health | GA |
| Partitions.ListPartitions | RPC to list partitions | GA |
| Partitions.GetPartition | RPC to get partition information | GA |
| Partition metrics exporter | Metrics exporter to expose partition metrics on shared resources | Beta |
| Results.WatchResults | Bi-directionnal RPC to subscribe to events on Results | WIP |
| Results.* | Service to create, download, list and upload results | GA |
| Sessions.* | Service to create, list, cancel, pause, resume, close etc sessions | GA |
| Submitter.* | Deprecated streamed service to create tasks and payloads altogether | Deprecated |
| Tasks.* | Service to submit, list and cancel tasks | GA |
| Versions.* | Service to retrieve versions | GA |
| Worker.* | Service implemented by users that consumes the tasks scheduled by ArmoniK | GA || Docker Image Platform | Status |
|-----------------------|---------|
| linux/amd64 | GA |
| linux/arm64 | Preview |
| windows/amd64 | Beta |## Installation
ArmoniK.Core can be installed only on Linux machines. For Windows users, it is possible to do it on [WSL2](https://learn.microsoft.com/en-us/windows/wsl/about).
### Prerequisites
- [Terraform](https://www.terraform.io/) version >= 1.4.2
- [Just](https://github.com/casey/just) >= 1.8.0
- [Dotnet](https://dotnet.microsoft.com/en-us/) >= 6.0
- [Docker](https://www.docker.com/) >= 20.10.16
- [GitHub CLI](https://cli.github.com/) >= 2.23.0 (optional)### Local deployment
To deploy ArmoniK.Core locally, you need first to clone the repository [ArmoniK.Core](https://github.com/aneoconsulting/armonik.core). Then, to see all the available recipes for deployment, place yourself at the root of the repository ArmoniK.Core where the justfile is located, and type on your command line:
```shell
just
```More about local deployment, see [Local Deployment of ArmoniK.Core](./.docs/content/0.installation/1.local-deployment.md).
### Tests
There are a number of tests that help to verify the successful installation of ArmoniK.Core. Some of them require a full deployment of ArmoniK.Core, for others a partial deployment is enough.
More about tests, see [Tests of ArmoniK.Core](./.docs/content/0.installation/2.tests.md).
## Contribution
Contributions are always welcome!
See [ArmoniK.Community](https://github.com/aneoconsulting/ArmoniK.Community) for ways to get started.