Skip to content

Latest commit

 

History

History
105 lines (72 loc) · 4.38 KB

README.md

File metadata and controls

105 lines (72 loc) · 4.38 KB

pyMc server - cli deployment tool

what does it do

The Tool will be used to deploy on skypilot. It aims to simplify the deployment process. In the end, the application needs to merge different .yaml files (pyMc-/user Files) together.

The library can be used and configured in 3 forms

  • via a Python API and by passing configuration as parameters
  • via the CLI and YAML files for configuration
  • via the CLI and command line parameters for configuration.

Quickstart

Installation

Start a new virtual environment with pixi. To get a shell in the default environment run

pixi shell

Install this library from PiPy pip3 install pymc-server

If you want to install this library from source:

git clone https://github.com/pymc-labs/pymc-server
cd PyMC-Server

pip3 install . # run `pip3 install -e .` if you want to be able to edit the code

Setting up a cloud: Google Cloud

  1. Run pymcs check to see if you already have credentials setup. If you see a green checkmark for GCP (Google Cloud Platform), skip to the next section
  2. Install the google cloud SDK and authenticate.
# inside your activated environment
micromamba install -c conda-forge google-cloud-sdk
gcloud init

# Run this if you don't have a credentials file.
# This will generate ~/.config/gcloud/application_default_credentials.json.
gcloud auth application-default login

Tip: If you are using multiple GCP projects, list all the projects by gcloud projects list and activate one by gcloud config set project <PROJECT_ID> (see GCP docs).

  1. Follow the link to Google and authorize the Google Cloud SDK. This will create and persist credentials on your local computer. Running pymc-server commands via Google Cloud will introduce cost to your Google Cloud bill according to the VMs provisioned by your configuration (see next section).

Gcloud SDK Auth

Follow through the rest of the GCP configuration in your terminal.

  1. In Order to let PyMC-Server manage cloud resources for you, you need to grant your Google IAM account the permissions to execute all actions neccessary.

Go to Google IAM Console to access and edit your IAM permissions.

Next, create a new role and name it e.g. pymcs-server-role.

Note: we will be granting overly permissive rules for convenience of your setup. For production usage it is strictly neccessary that you review the permissions given. Please refer to GCP: Minimal Permissions for more information on how to setup secure and fine grained permissions.

Add the following permissions to your newly created role. At the time of writing this document Google offers a search bar where each permission needs to be entered. The table below the search bar will display the roles under this name, and you can select them all together with the first checkbox in the table (header).

roles/browser
roles/compute.admin
roles/iam.serviceAccountAdmin
roles/iam.serviceAccountUser
roles/serviceusage.serviceUsageConsumer
roles/storage.admin
roles/iam.securityAdmin

Note: If you use PyMC-Server as part of an organization, your GCP admin might have setup a role already (e.g. pymc-server-role ) and you can easily attach your user to it.

Yaml configuration

Command Line Usage

Start a new single or multi-node cluster (with YAML configuration)

Setup a configuration file (see #Yaml-configuration)

Start a new single or multi-node cluster (with CLI parameter configuration)

Status of your deployments

To check the status of all your deployments run pymcs status. A table is printed to your terminal.

❯ pymcs status
Clusters
NAME  LAUNCHED      RESOURCES                 STATUS  AUTOSTOP  COMMAND
tc    5 months ago  1x Kubernetes(2CPU--2GB)  UP      -         pymcs launch -c tc hello_sk...

Managed jobs
No in-progress managed jobs. (See: pymcs jobs -h)

Services
No live services. (See: pymcs serve -h)

Using pymcs to deploy custom software.

Using configuration files allows you to install custom software on your cloud nodes. Due to ssh agent forwarding, you are able to git clone even private repositories on remote infrastructure without sharing any credentials as text with the machine. This assumes your laptop has SSH access to the private repo.