Private packages
Private packages can be pre-built wheel files (.whl
) or buildable directories of Python files.
When you upload your private Python packages to Modelbit they become available to be installed by any of your deployments.
Private packages are stored in git. That means you can add new versions of packages while on a branch and test them before merging the changes to main
.
Adding packages
You can add your private packages via the Modelbit Package CLI or Python API:
- Package CLI
- Python API
modelbit package add /path/to/my_package
mb.add_package("/path/to/my_package")
The /path/to/my_package
should be either a .whl
file or a buildable directory containing the setup.py
or pyproject.toml
.
Buildable directories include a config that specifies a name, version and dependencies in a setup.py
or pyproject.toml
. The modelbit
package will build your directory with python -m build
before uploading the package to your workspace.
Using your package
Like any other Python package, you can specify your private packages as dependencies of your deployment.
- Git
- Notebook
When using git, specify your package as a dependency in your deployment's requirements.txt
:
my_package==1.2.3
When deploying from a Python notebook, use the python_packages
parameter to include your package:
mb.deploy(..., python_packages=["my_package==1.2.3"])
Private packages are installed during environment creation.
Overwriting existing versions
To help prevent mistakes, Modelbit will prevent package updates from overwriting existing versions. If you want to overwrite an already-added private package with the same version, use the force
parameter:
- Package CLI
- Python API
modelbit package add --force /path/to/my_package
mb.add_package("/path/to/my_package", force=True)
The next time you deploy, the newly added version of the package will be used during installation. You can automatically update existing deployments by toggling the "Redeploy all deployments" setting within the Common area of Modelbit.
Using uploaded packages
No code changes are needed to use your private packages from within a Modelbit deployment. They get installed into your deployment's environment just like you'd install them locally. That means your existing source code can continue to use the import my_package
and from my_package import foo
import formats with your inference function:
from my_package import foo
def predict(a: int):
return foo(a)