 
 
 

vscode-clearml-session-manager
The easiest way to connect to ClearML Sessions--one of the best remote workstation offerings in the MLOps space. (comparison of ClearML vs others here)
💬 We're looking for contributors! See the contributing section below.
ClearML is self-hostable without kubernetes and has a free SaaS-hosted plan, meaning you can get a world-class data science development environment for free.
Watch and learn
- 2-minute explainer video of why DS should develop on remote workstations
- 60-second demo video of how it works, so far here

How this extension fits into a Cloud or on-prem Architecture
 
 
 
Contributing
Roadmap
Items marked with ✨ are high-impact, and important for our first release
Features:
Exploring sessions
- [ ] Query the ClearML API to display the most useful data about each session
- [ ] Total CPU cores
- [ ] Public IP address of the worker
- [ ] Private IP address of the worker
- [ ] Total RAM
- [ ] Queue name
- [ ] Username/email of creator
- [ ] Human-readable format of how long it's been alive, e.g. 1d 2h 5m
 
- [ ] Display a different-colored icon in the tree view, depending on whether the session is queued,stopped,in_progress, etc.
- [ ] Query the ClearML API for the the clearml-sessionargs used to create the session including
- [ ] --queue default
- [ ] --docker python3.9
- [ ] --init-script(the contents)
- [ ] --user
- [ ] --password(we should think about how to treat this)
 
- [ ] Create an intuitive means of displaying these ^^^
Connecting to sessions
- [x] ✨ Add support for connecting to existing ClearML Sessions
- [x] ✨ Provide a way to collect the connection details (host, port, username, password)
- [x] ✨ Provide a way to open the connection
 
- [ ] Add support for settings.jsonsettings including
- [x] clearml-session-manager.clearmlConfigFilePath(string), defaults to~/clearml.conf
- [x] if clearml-session-manager.clearmlConfigFilePathis not set, and~/clearml.confdoes not exist, prompt the user with instructions to start their own ClearML backend server and runclearml-init
 
- [ ] clearml.sessionPresets(array of objects), lets you your favorite sets of arguments to theclearml-sessionCLI
 
Low priority it may be of interest to support connecting to sessions by starting an "interactive session" via clearml-session --attach <task id> which creates an SSH tunnel to localhost. This is a different way of connecting to
sessions, so this is redundant with the above.
- [ ] Start the clearml-sessionas a subprocess
- [ ] Log the exact clearml-sessioncommand somewhere that the user can see (useful for debugging and learning)
- [ ] Pop a message with a button allowing the user to follow along with the clearml-sessionlogs
- [ ] Parse the logs of the subprocess to detect
- [ ] Failure: When the process is stuck in a retry loop because of SSH connectivity issues
- [ ] React to failure by killing the subprocess (maybe after 3 retries) and alerting the user, offering to show them the logs
 
- [ ] Success: Capture the connection host info, e.g. ssh root@localhost -p 8022and the password, e.g.[password: pass]
- [ ] Success: the process hangs because the SSH tunnel has been left open
- [ ] React to success by automatically opening a new VS Code window
 
 
 
Creating sessions
- [ ] Add a +button that allows you to create a ClearML session
- [ ] Implement a way for users to define and select presets for clearml-sessions. Ideas:
- [ ] Use something like launch.json, basically, have users define presets in a JSON file at.vscode/clearml.json
- [ ] Have a UI form to collect user input for the clearml-sessionarguments, e.g. by using aWebview. Do API calls to provide the user with autocompletion on anything we can, e.g. for which queues are available
 
 
DevOps
- [x] ✨ Add a docker-compose.yamland instructions for hosting ClearML locally for development. Here's their official reference compose file.
- [ ] Add automated tests
- [x] ✨ unit tests: establish pattern of unit tests, e.g. folder structure and example test
- [ ] ✨ integration tests: establish pattern, e.g. run ClearML in CI via docker-compose.yamland make API calls to it
 
- [ ] Suggestion from ClearML: shutdown idle instances. Determine which are idle by querying for the host metrics, e.g. CPU utilization.
- [x] ✨ Add a CI pipeline
- [x] formatting, so all contributed code is uniform
- [x] linting
- [x] testing
- [x] tagging with the semantic version in package.json, pushing tags on merge
- [x] repo shields / badges
- [x] measure test code coverage and display as badge on repo
- [x] show build status, e.g. "failing"
- [x] change license to Apache 2.0, display as badge
 
 
- [x] ✨ Add a CD pipeline
- [x] learn how to publish a VS Code extension on the marketplace
 
Running the extension locally
VS Code makes it really easy to run extensions and try out code changes:
- be sure you have NodeJS installed, some had issues because they had the wrong Node version
- go to the src/extension.tsfile and pressF5to start a debugging session
Getting up to speed on ClearML and writing VS Code Extensions
Here are a few videos with progress updates. Watching these will step you through how we learned about authoring VS Code extensions and how we got to where we are now.
- ~30 min - Announcing the hackathon project
- ~30 min - How we got the extension to work with the Python interpreteer by forking the vscode-black-formatterextension
- ~45 min - Everything we created/learned during the all-nighter hackathon
- how to hit the ClearML API
- how to read the ~/clearml.conffile with TypeScript
- how we decided to hit the ClearML API from TypeScript rather than Python
- how we got the list items to show up in the sidebar
 
- Pull request: giving ClearML it's own "View Container" i.e. item
in the leftmost sidebar. And how we got our icons to show up
in all the right places.
- ~5 min - How we got VS Code to open a new window SSH'ed into an already-attached-to ClearML session
Running the extension and ClearML remotely
📌 Note: As a first contribution, it'd be great if you submitted a PR to this README if you get stuck during setup.
Step 1 - set up your own machine, i.e. your laptop
- Sign up for the free, SaaS-hosted ClearML at app.clearml.ml
- Follow the instructions in their UI to make a set of API keys and put them into a local ~/clearml.conffile by running theclearml-initcommand and pasting them in.
- In case you mess up when doing the initialization, you can go to Settings>Workspace>+ Create new credentialsin the UI to create a key pair. But it should automataically do this for you when you first log in. 
 
 
Step 2 - set up a remote machine, e.g. a VM in the cloud
If you choose an EC2 instance or Amazon Lightsail (cheaper than EC2), you can
do something like this to install and start up the clearml-agent daemon which
will allow you to run ClearML Session on it:
First, connect to it via SSH
ssh ec2-user@<public ip of instance>
Then install and start the clearml-agent daemon
sudo su
yum update -y && yum install -y docker docker-compose python3-pip
service docker start
python -m pip install clearml clearml-agent
clearml-agent init  # paste in your API keys (you can also make a new pair for this)
# exapmle daemon command, you can set these however you like
clearml-agent daemon --queue default --docker --cpu-only --log-level debug
Step 3 - start a ClearML Session on your instance
On your laptop, you'd run something like
clearml-session --queue default --docker python:3.9
Note that this will open an SSH tunnel to your instance, so your instance needs
to accept incoming traffic on port 22 and probably others like 10022.
If this is an EC2 instance, this means adjusting your security group. Other clouds
have a similar concept. They often call this a "firewall".
Step 4 - run the extension locally
Follow steps 1, 2, 3, and 6 below.
Running the extension and ClearML completely locally
⚠️ Disclaimer: while getting this running locally is a good onboarding exercise,
the last step currently fails (For Eric, at least) mid-way through creating the session.
If you want to pursue troubleshooting this, by all means!
Unfortunately, for the sake of continuing development, the most reliable course
is to provision your own VM in the cloud e.g. an EC2 instance, Digital Ocean droplet,
Linode server, etc.
⚠️ Disclaimer: expect problems if you try to run this project directly on Windows.
Install the Windows Subsystem for Linux 2 (WSL2) and develop from there if
you are running windows.
The free videos in the Environment Setup section of this
course walk you through how to do this, as well as most of step [1] below.
- install the prerequisites - 
- docker, on MacOS and Windows (including WSL2), get Docker Desktop
- docker-compose, e.g.- brew install docker-compose
- NodeJS, e.g. with brew install nodejs
- Python. pyenvis a good way to install Python.
- VS Code
 
- clone the repo 
- install the NodeJS dependencies - # cd into the cloned repo and install the NodeJS dependencies
cd ./vscode-clearml-session-manager/
npm install
 
- generate a set of ClearML API keys, these get placed at - ./dev-utils/volumes/opt/clearml/config/clearml.conf
 - npm run create-clearml-credentials
 
- start the ClearML server - npm run start-clearml-server
 
- start the VS Code extension by opening - ./src/extension.tsand pressing- F5on your keyboard
 
- The extension should load successfully, but it won't have any sessions. To start a session, run - # install the clearml-session CLI into a Python virtual environment
python -m venv ./venv/
source ./venv/bin/activate
npm run install-python-deps
# execute the clearml-session CLI to start a session
npm run start-clearml-session
 - This will take some time to run. While it loads, you should be able to visit
http://localhost:8080 and visit the - DevOpsfolder in Clearml after logging in
with- username: test,- password: test.
 
Architecture of ClearML
ClearML Server with MinIO - Service Architecture
graph LR
    subgraph backend_network["Backend Network"]
        redis[("Redis<br>Port: N/A")]
        mongo[("MongoDB<br>Port: N/A")]
        elasticsearch[("Elasticsearch<br>Port: N/A")]
        fileserver[("Fileserver<br>Port: 8081")]
        minio[("MinIO<br>Port: 9000")]
        apiserver[("API Server<br>Port: 8008")]
        async_delete[("Async Delete<br>Port: N/A")]
        agent_services[("Agent Services<br>Port: N/A")]
    end
    subgraph frontend_network["Frontend Network"]
        webserver[("Webserver<br>Port: 80<br>URL: app.clearml.localhost:8080")]
    end
    user -->|HTTP:8080| webserver
    webserver -->|HTTP:8008| apiserver
    apiserver -->|Internal| mongo
    apiserver -->|Internal| redis
    apiserver -->|Internal| elasticsearch
    apiserver -->|HTTP:8081| fileserver
    apiserver -->|HTTP:9000| minio
    fileserver -->|HTTP:9000| minio
    async_delete -->|Internal| apiserver
    agent_services -->|Internal| apiserver
    style webserver fill:#f9f,stroke:#333,stroke-width:2px
Notes
- API Server (apiserver):api.clearml.localhost:8008Interacts with MongoDB, Redis, Elasticsearch, Fileserver, and MinIO. It can be accessed internally by other services within thebackend_network.
- Webserver (webserver):app.clearml.localhost:8080The main entry point for users in the browser. It can be visited at .
- Fileserver (fileserver):files.clearml.localhost:8081Serves files and communicates with MinIO on port9000. It's reachable internally by the API server at port8081.
- MinIO (minio): The file storage server replacing the built-in fileserver. It listens on port9000and can be accessed internally by both the Fileserver and the API server.
- Elasticsearch (elasticsearch), MongoDB (mongo), and Redis (redis): These services do not have ports exposed outside but can be accessed by the API server and other services within thebackend_network.
- Async Delete (async_delete): It's an internal service that connects to the API server and depends on MongoDB, Redis, and Elasticsearch.
- Agent Services (agent_services): Interacts with the API server and does not expose any ports outside.
Ports mentioned as "N/A" are not directly exposed to the host machine but are used internally within the Docker network for service communication.
Remember to replace the example URL with the actual domain and port you will use in your production or development environment. The above diagram assumes that services like MongoDB, Redis, and Elasticsearch do not need to be accessed directly through a browser and therefore do not have a URL associated with them for external access.