DataMate is an enterprise-level data processing platform for model fine-tuning and RAG retrieval, supporting core functions such as data collection, data management, operator marketplace, data cleaning, data synthesis, data annotation, data evaluation, and knowledge generation.
If you like this project, please give it a Starโญ๏ธ!
- Core Modules: Data Collection, Data Management, Operator Marketplace, Data Cleaning, Data Synthesis, Data Annotation, Data Evaluation, Knowledge Generation.
- Visual Orchestration: Drag-and-drop data processing workflow design.
- Operator Ecosystem: Rich built-in operators and support for custom operators.
- Git (for pulling source code)
- Make (for building and installing)
- Docker (for building images and deploying services)
- Docker-Compose (for service deployment - Docker method)
- Kubernetes (for service deployment - k8s method)
- Helm (for service deployment - k8s method)
- K8s deployment additionally requires: Sealed Secrets Controller (for encrypted secret management)
DataMate K8s deployment uses Bitnami Sealed Secrets to manage sensitive configuration such as database passwords and JWT secrets. All secrets are stored in encrypted form in Git (deployment/kubernetes/sealed-secrets/) and automatically decrypted by the Sealed Secrets Controller in the cluster at deploy time.
Online environment - install Sealed Secrets Controller:
# Install via Helm (recommended)
helm repo add sealed-secrets https://bitnami-labs.github.io/sealed-secrets
helm install sealed-secrets sealed-secrets/sealed-secrets -n kube-system
# Verify installation
kubectl get pods -n kube-system | grep sealed-secretsAir-gapped / offline environment:
-
Download the Sealed Secrets image on an internet-connected machine:
# Download controller image (~60MB) docker pull bitnami/sealed-secrets-controller:latest docker save bitnami/sealed-secrets-controller:latest -o sealed-secrets-controller.tar # Download kubeseal CLI (for updating secrets) # macOS: brew install kubeseal # Linux: wget https://github.com/bitnami-labs/sealed-secrets/releases/latest/download/kubeseal-linux-amd64
-
Transfer the image to your offline registry, then install via Helm with the custom image reference.
Updating secrets:
# When passwords change, re-encrypt with kubeseal
echo -n "new-password" | kubeseal --raw --name datamate-conf --namespace datamate --scope namespace-wideNote: Docker deployments do not require Sealed Secrets โ secrets are managed via the
.envfile (excluded from Git via.gitignore).
wget -qO docker-compose.yml https://raw.githubusercontent.com/ModelEngine-Group/DataMate/refs/heads/main/deployment/docker/datamate/docker-compose.yml \
&& REGISTRY=ghcr.io/modelengine-group/ docker compose up -dgit clone git@github.com:ModelEngine-Group/DataMate.git
cd DataMatemake installThis project supports deployment via two methods: docker-compose and helm. After executing the command, please enter the corresponding number for the deployment method. The command echo is as follows:
Choose a deployment method:
1. Docker/Docker-Compose
2. Kubernetes/Helm
Enter choice:If the machine you are using does not have make installed, please run the following command to deploy it:
REGISTRY=ghcr.io/modelengine-group/ docker compose -f deployment/docker/datamate/docker-compose.yml --profile milvus up -dOnce the container is running, access http://localhost:30000 in a browser to view the front-end interface.
To list all available Make targets, flags and help text, run:
make helpIf you are in an offline environment, you can run the following command to download all dependent images:
make downloadmake install-label-studiomake build-mineru
make install-minerumake install-deer-flowAfter modifying the local code, please execute the following commands to build the image and deploy using the local image.
make build
make install dev=truemake uninstallWhen running make uninstall, the installer will prompt once whether to delete volumes; that single choice is applied to all components. The uninstall order is: milvus -> label-studio -> datamate, which ensures the datamate network is removed cleanly after services that use it have stopped.
- DEVELOPMENT.md - Local development environment setup and workflow
- AGENTS.md - AI assistant guidelines and code style
- backend/README.md - Backend architecture, services, and technology stack
- backend/api-gateway/README.md - API Gateway configuration and routing
- backend/services/main-application/README.md - Main application modules
- backend/shared/README.md - Shared libraries (domain-common, security-common)
- runtime/README.md - Runtime architecture and components
- runtime/datamate-python/README.md - FastAPI backend service
- runtime/python-executor/README.md - Ray executor framework
- runtime/ops/README.md - Operator ecosystem
- runtime/datax/README.md - DataX data framework
- runtime/deer-flow/README.md - DeerFlow LLM service
- frontend/README.md - React frontend application
Thank you for your interest in this project! We warmly welcome contributions from the community. Whether it's submitting bug reports, suggesting new features, or directly participating in code development, all forms of help make a project better.
โข ๐ฎ GitHub Issues: Submit bugs or feature suggestions.
โข ๐ง GitHub Pull Requests: Contribute code improvements.
DataMate is open source under the MIT license. You are free to use, modify, and distribute the code of this project in compliance with the license terms.