Databricks Python Wheel dev tasks in a namespaced collection of tasks to enrich the Invoke CLI task runner.
Project description
Invoke Databricks Wheel Tasks
Databricks Python Wheel dev tasks in a namespaced collection of tasks to enrich the Invoke CLI task runner.
Getting Started
pip install invoke-databricks-wheel-tasks
This will also install invoke
and databricks-cli
.
Databricks CLI Config
It is assumed you will follow the documentation provided to setup databricks-cli
.
https://docs.databricks.com/dev-tools/cli/index.html
You'll need to setup a Personal Access Token. Then run the following command:
databricks configure --profile yourprofilename --token
Databricks Host (should begin with https://): https://myorganisation.cloud.databricks.com/
Token:
Which will create a configuration file in your home directory at ~/.databrickscfg
like:
cat ~/.databrickscfg
[yourprofilename]
host = https://myorganisation.cloud.databricks.com/
token = dapi0123456789abcdef0123456789abcdef
jobs-api-version = 2.1
Invoke Setup
tasks.py
from invoke import task, Collection, Tasks
import invoke_databricks_wheel_tasks as db
@task
def format(c):
"""Autoformat code for code style."""
c.run("black .")
c.run("isort .")
@task
def build(c):
"""Build wheel."""
c.run("rm -rfv dist/")
c.run("poetry build -f wheel")
# TODO: Find a neater way to capture root tasks as well as setting namespaces
ns = Collection(*[v for v in globals().values() if type(v) == Task])
ns.add_collection(db, name="db")
Once your tasks.py
is setup like this invoke
will have the extra commands:
λ invoke --list
Available tasks:
format Autoformat code for code style.
build Build wheel.
db.runjob Trigger default job associated for this project.
db.reinstall Reinstall version of wheel on cluster with a restart.
db.upload Upload wheel artifact to DBFS.
db.clean Clean wheel artifact from DBFS.
Invoke Configuration
Each of the tasks will require some combination of profile
, cluster-id
, job-id
etc.
You can create an invoke.yaml
file which will get loaded into the invoke
Context
Configuration
.
This will greatly simplify your typing by setting workspace specific flags for your dev iteration loop.
# https://docs.pyinvoke.org/en/latest/concepts/configuration.html
databricks:
profile: yourprofilename
cluster-id: your-cluster-id-here
job-id: 9999
artifact-path: "dbfs:/FileStore/wheels/"
wheel: "dbfs:/FileStore/wheels/projectname-0.1.0-py3-none-any.whl"
The Tasks
db.upload
This task will use dbfs
to empty the upload path and then copy the built wheel from dist/
.
This project assumes you're using poetry
or your wheel build output is located in dist/
.
If you have other requirements then pull requests welcome.
db.clean
This tasks will clean up all items on the target --artifact-path
.
db.reinstall
After some trial and error, creating a job which creates a job cluster everytime is roughly 7 minutes.
However if you create an all purpose cluster that you:
- Mark the old wheel for uninstall
- restart cluster
- install updated wheel from dbfs location
This takes roughly 2 minutes which is a much tighter development loop. So these three steps are what db.reinstall
performs.
db.runjob
Assuming you have defined a job, that uses a pre-existing cluster, that has your latest wheel installed, this will create a manual trigger of your job with job-id
.
The triggering returns a run-id
, where this run-id
gets polled until the state gets to an end state.
Then a call to databricks runs get-output --run-id
happens to retrieve and error
, error_trace
and/or logs
to be emitted to console.
All Together
Assuming, you created your cluster and job definition you may want to create a root level @task
like:
@task(pre=[build, db.upload, db.reinstall, db.runjob], default=True)
def dev(c):
"""Default development loop."""
...
You will notice a few things here:
- The method has no implementation
...
- We are chaining a series of
@task
s in thepre=[...]
argument - The
default=True
on this root tasks means we could run eitherinvoke dev
or simplyinvoke
.
How cool is that?
Contributing
At all times, you have the power to fork this project, make changes as you see fit and then:
pip install https://github.com/user/repository/archive/branch.zip
Stackoverflow: pip install from github branch
That way you can run from your own custom fork in the interim or even in-house your work and simply use this project as a starting point. That is totally ok.
However if you would like to contribute your changes back, then open a Pull Request "across forks".
Once your changes are merged and published you can revert to the canonical version of pip install
ing this package.
If you're not sure how to make changes or if you should sink the time and effort, then open an Issue instead and we can have a chat to triage the issue.
Resources
Prior Art
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file invoke-databricks-wheel-tasks-0.5.6.tar.gz
.
File metadata
- Download URL: invoke-databricks-wheel-tasks-0.5.6.tar.gz
- Upload date:
- Size: 8.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.10.4 Linux/5.13.0-1021-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8290c6f9c9815b795f6ab91e3c126a753dc29b921b8961f9d2c7454c8bbb1084 |
|
MD5 | 354461612f1c3d59db45c9d01c193984 |
|
BLAKE2b-256 | 2c76708bb2528ff02f5c0adbb1a7ccd892b6506a1c5bf51f249f7ec05cc75810 |
File details
Details for the file invoke_databricks_wheel_tasks-0.5.6-py3-none-any.whl
.
File metadata
- Download URL: invoke_databricks_wheel_tasks-0.5.6-py3-none-any.whl
- Upload date:
- Size: 8.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.10.4 Linux/5.13.0-1021-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3a4248e62bcb9f23377b80194c60c9de3f1a522d5033471ed0335d8b22d794dd |
|
MD5 | cb41a12076c0baa94be66feced4058ec |
|
BLAKE2b-256 | a0e59702385c1d6b7dbe33acafeb4c53d26a72f5311e57cf39b2f1c71f9a29b3 |