The goal of this project is to make a single pip-installable package that allows anyone to provision an opinionated ClearML deployment on AWS.
- Create these as
SecureString
parameters in the AWS Systems Manager Parameter/clearml/github_ssh_private_key
, fromcat ~/.ssh/id_rsa | pbcopy
/clearml/github_ssh_public_key
, fromcat ~/.ssh/id_rsa.pub | pbcopy
- Create an SSH key for yourself
just install create-ec2-key-pair-from-personal-ssh-keys
- Python 3.8 or higher
- NodeJS 14 or higher (a dependency of the AWS CDK CLI)
- AWS CDK CLI
- Docker (should be installed and running)
pip install awscdk-clearml
# app.py
import os
from aws_cdk import App, Environment
from cdk_clearml import ClearMLStack
APP = App()
# TBD ...
APP.synth()
Note:
app.py
is an AWS Cloud Development Kit concept. If you are not familiar with AWS CDK and what anapp.py
file is, you can read more about it in the AWS CDK docs.
This project started as a Hackathon on March 24, 2023.
Contributors can expect to come away with an enviable amount of real-world cloud architecture experience :D
💡 Click the images to go to each collaboration tool.
💡 Bookmark this repository so you can get quick access to these links.
Our virtual park (audio/screen sharing) |
Slack, in the #hackathon channel |
Roadmap, tasks |
Architecture |
mlops-club AWS account login page |
Similar project with reference code / resources |
TL;DR, install node
and just
.
# install "just"; it's like "make", but less frustrating
brew install just
# install the project's python packages and pre-commit
just install
Alternatively, without brew
:
curl --proto '=https' --tlsv1.2 -sSf https://just.systems/install.sh | bash -s -- --to <DEST IN YOUR PATH>
where DEST IN YOUR PATH
refers to a directory that is present in your $PATH
environment variable. For example, you might have in your ~/.bashrc
the line PATH=~/bin:$PATH
to look for programs in ~/bin
first, which would be the "DEST" supplied above.
You also need node
to execute any code related to AWS CDK, which you can install with brew install nvm
and nvm install 18
.
We use pull requests. Create new branches based on trunk
for experimentation, then open a PR for it.
You don't have to wait until you want to merge code to open a PR. For this project, the main purpose of doing PRs
is to share knowledge and get early feedback on your ideas.
Passing the pre-commit
checks isn't a huge deal. They are mostly for your own benefit to prevent you
committing things to the repo that you don't want. You can always override pre-commit
by running
# run all of the quality checking tools against your code
just lint
# skip the quality checking tools locally
git commit -m "I really want to commit this large file" --no-verify
📌 Note: you may want to use a different email/username for this repository than you typically use on your development machine. You can set your git settings locally like so:
git config --local user.email my-personal-email@gmail.com
git config --local user.user my-github-username
DON'T COMMIT...
- credentials. Feel free to put them in a
.env
file, but make sure it's gitignored! - large files (large CSV, ML model weights, C binaries, video, etc.) use git LFS rather than committing it directly.
- unformatted code
The pre-commit hooks setup for this repo when you ran just install
will remind you
about these each time you commit :)