Skip to main content

CLI client tool for deploying workloads to Racetrack

Project description

Racetrack client context

racetrack-client is a CLI client tool for deploying workloads to Racetrack (IKP-RT).

Racetrack system allows to deploy jobs in a one step. It transforms your code to in-operation workloads, e.g. Kubernetes workloads. You write some code according to a set of coventions, you include the manifest file which explains the code, and you submit it to Racetrack. A short while after, the service calling your code is in operation.

Quickstart

  1. Install racetrack client: pip3 install racetrack-client
  2. Configure access token to your git repository: racetrack config credentials set REPO_URL USERNAME TOKEN
  3. Deploy your job to Racetrack: racetrack deploy . https://racetrack.example.com/ikp-rt/lifecycle
  4. You will see the URL of your deployed job in the output.

Installation

Install racetrack-client using pip:

pip3 install racetrack-client

Python 3.8+ is required. So if you have any troubles, try with:

sudo apt install python3.8 python3.8-dev python3.8-venv
python3.8 -m pip install racetrack-client

This will install racetrack CLI tool. Verify installation by running racetrack.

Usage

Run racetrack --help to see usage.

Deploying

To deploy a job, just run in the place where fatman.yaml is located:

racetrack deploy . https://racetrack.example.com/ikp-rt/lifecycle

racetrack deploy [WORKDIR] [RACETRACK_URL] has 2 optional arguments:

  • WORKDIR - a place where the fatman.yaml is, by default it's current directory
  • RACETRACK_URL - URL address to Racetrack server, where a job should be deployed. If not given, it will be deployed to a URL configured in a local client config, by default it's set to a local cluster at http://127.0.0.1:7002.

Showing logs

To see recent logs from your Fatman output, run racetrack logs command:

racetrack logs . https://racetrack.example.com/ikp-rt/lifecycle

racetrack logs [WORKDIR] [RACETRACK_URL] has 2 arguments:

  • WORKDIR - a place where the fatman.yaml is, by default it's current directory
  • RACETRACK_URL - URL address to Racetrack server, where the Fatman is deployed.

Local client configuration

If you want to update client configuration (namely persist some preferences for later use), use the following command:

racetrack config set [CONFIG_NAME] [VALUE]

Local client configuration is stored at ~/.racetrack/config.yaml.

Configuring default Racetrack URL

You can set default Racetrack URL address:

racetrack config racetrack_url https://racetrack.example.com/ikp-rt/lifecycle

Then you can run just racetrack deploy command (without RACETRACK_URL argument), racetrack_url will be inferred from client configuration.

Private Job repositories

Before building & deploying a Job stored in a private git repository, you should make sure that Racetrack has access to it. Add git credentials to access your repository using command:

racetrack config credentials set REPO_URL USERNAME TOKEN

Racetrack URL aliases

You can set up aliases for Racetrack server URL addresses by issuing command:

racetrack config alias set ALIAS RACETRACK_URL

If you operate with many environments, setting short names may come in handy. For instance:

racetrack config alias set dev https://dev.racetrack.example.com/ikp-rt/lifecycle
racetrack config alias set test https://test.racetrack.example.com/ikp-rt/lifecycle
racetrack config alias set prod https://prod.racetrack.example.com/ikp-rt/lifecycle
racetrack config alias set kind http://127.0.0.1:7002
racetrack config alias set compose http://127.0.0.1:7102

and then you can use your short names instead of full RACETRACK_URL address when calling racetrack deploy . dev.

Development setup

Clone IKP-RT repository and run it inside this directory:

make setup

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

racetrack-client-0.0.15.tar.gz (27.6 kB view details)

Uploaded Source

Built Distribution

racetrack_client-0.0.15-py3-none-any.whl (33.0 kB view details)

Uploaded Python 3

File details

Details for the file racetrack-client-0.0.15.tar.gz.

File metadata

  • Download URL: racetrack-client-0.0.15.tar.gz
  • Upload date:
  • Size: 27.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.8.10

File hashes

Hashes for racetrack-client-0.0.15.tar.gz
Algorithm Hash digest
SHA256 56d449afc36a76b58ce7577ca3cc4b2e05d337c04a7679f1b226fbac9793dc60
MD5 3baffffa6ce55cc567436c3aa00e8134
BLAKE2b-256 d049ad1ed1dd7dc8880d1c113df5cc8509a203d5b6ee48cec60b073e946167cc

See more details on using hashes here.

File details

Details for the file racetrack_client-0.0.15-py3-none-any.whl.

File metadata

  • Download URL: racetrack_client-0.0.15-py3-none-any.whl
  • Upload date:
  • Size: 33.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.8.10

File hashes

Hashes for racetrack_client-0.0.15-py3-none-any.whl
Algorithm Hash digest
SHA256 b9ec25ee67da7d7b57509040da1e26ea54508d5e3d2f7e51b94a434c3541030c
MD5 c771abcb15ff62bf4463df1378564b3d
BLAKE2b-256 83dd2a12bec09c5574f7b853d07c941eac7505c5c1f4fbe2f55a03f7065a45c5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page