A command line tool for deploying services and applications using git.
Unfurl is a command line tool for deploying services and applications.
Describe your application architecture at a high-level using the OASIS TOSCA standard and Unfurl creates a plan adapted to your deployment environment (e.g. your cloud provider, Kubernetes, or self-hosted machines), using artifacts such as shell scripts, Terraform modules or Ansible playbooks.
After deployment, Unfurl records in git all the information needed for a reproducible deployment: the configuration, the artifacts and source repositories used in deployment, as well the state of the deployed resources. This enables intelligent updates as your configuration, dependencies, or environment changes.
The best way to manage your Unfurl project is to use Unfurl Cloud, our open-source platform for collaboratively developing cloud applications.
You are developing an application consisting of several interconnected services. Even a relatively simple web application has many dependencies that cut across its stack and development and deployment processes. Unfurl can help manage that complexity without complicated DevOps processes.
You have users that want to deploy your application on a variety of different cloud providers and self-hosted configurations. Support them by adding an adaptable blueprint to your source repository or publish it in a Cloud Map or on Unfurl Cloud, our open-source deployment platform.
You want to manage configuration and live resources just like code, using the same development processes – like pull requests and CI pipelines – without costly server infrastructure or having to rely on manual and proprietary admin UI.
Unfurl projects provide an easy way to track and organize all that goes into deploying an application, including configuration, secrets, and artifacts – and track them in git. The goal is to provide isolation and reproducibility while maintaining human-scale, application-centric view of your resources.
Avoid tedious and error prone low-level configuration by creating a cloud blueprint that describes your cloud application’s architecture at a high-level in Python or YAML using the OASIS TOSCA (Topology and Orchestration Specification for Cloud Applications) standard. Blueprints includes the resources (e.g. compute instances), the services (e.g. a database) and the artifacts (e.g. a Docker container image or a software package).
Unfurl instantiates your blueprint by building a deployment plan using implementations appropriate for the environment you are deploying into. For predefined types you can use our Unfurl Cloud Standard library for common cloud providers, kubernetes, and self-hosted instances. Or your can easily use your own implementations – Unfurl integrates with tools like Terraform, Ansible, and Helm or you can encapsulate the scripts you already have.
Run unfurl deploy
to deploy the infrastructure. It will commit to git the latest configuration and a history of changes to your cloud accounts.
After the initial deployment, subsequent deployment plans take into account the current state of its resources. This way you can reduce errors by automatically reconfiguring as dependencies and environments change. You can also create custom operations or run ad-hoc commands in the ensemble’s environment.
Unfurl stores everything in git so git is all you need to share projects and collaboratively manage deployments. Unfurl can use git lfs to provide locking during deployment and can automatically encrypts secrets. Or for ease of use and more advanced needs you can use unfurl cloud to host and deploy.
For complex applications and to enable open-source development and the integration of 3rd-party providers, Unfurl supports design patterns for integrating components and services that can be developed and deployed independently, such as encapsulation, composition, loosely-coupled components, dependency injection, semantic versioning, and component catalogs.
The ultimate goal of Unfurl is enable anyone to clone, fork, and deploy live cloud services as easily as cloning and building code from git. So that we can have:
Simple, stand-alone CLI that can be used both in your local development environment or in an automated CI/CD pipeline.
secrets
folders.unfurl
is available on PyPI. You can install using pipx
or pip
:
pipx install unfurl
By default, Unfurl creates an Unfurl home project with a virtual Python environment for deployments so Unfurl only installs the minimal requirements needed to run the command line. If you want to deploy in the same environment, install it with the “full” option:
pipx install unfurl[full]
You can also install unfurl
directly from this repository to get the latest code:
pipx install "git+https://github.com/onecommons/unfurl.git#egg=unfurl"
Alternatively, you can get the Unfurl container image from GitHub or Docker Hub and run Unfurl from the image:
docker run --rm -it -v $(pwd):/data -w /data onecommons/unfurl:stable unfurl ...
The stable
tag matches the version published to PyPi; latest
is the latest code from the repository.
Optional: Docker or Podman
Use the table below to activate shell autocompletion for the unfurl
:
Shell | Instructions |
---|---|
Bash | Add this to ~/.bashrc : |
eval "$(_UNFURL_COMPLETE=bash_source unfurl)" |
|
Zsh | Add this to ~/.zshrc : |
eval "$(_UNFURL_COMPLETE=zsh_source unfurl)" |
|
Fish | Add this to ~/.config/fish/completions/unfurl.fish : |
eval (env _UNFURL_COMPLETE=fish_source unfurl) |
To hack on Unfurl:
git clone --recurse-submodules https://github.com/onecommons/unfurl /path/to/unfurl/
pip install -U -e /path/to/unfurl
pip install setuptools-rust>=1.7.0
python setup.py build_rust --debug --inplace
Requires Rust >= 1.70.
To build documentation: Install tox (see below). Run tox -e docs
.
To build a distribution package run:
pip install build
python -m build /path/to/unfurl/
You can now install this package with pip or pipx, for example:
pipx install ./dist/unfurl-1.1.1.dev219-cp38-abi3-macosx_12_0_arm64.whl
You can use tox
to run the unit tests inside the supported python environments with the latest source installed.
Install tox pip install tox==3.28.0
and then run tox
in source root. To install the dependencies you may need header files installed by the following OS packages: python-dev
, libcrypt-dev
, openssl-dev
. (Note: if installation of a dependency fails, reinvoke tox
with -r
to recreate the test environment.)
If you use asdf
to manage multiple versions of Python, also install tox-asdf
: pip install tox-asdf
.
Arguments after --
are passed to the test runner, e.g. to run an individual test: tox -- tests/test_runtime.py
.
When running unit tests, tox
it will try to build the Rust extension first. To skip building and running associated tests, set the UNFURL_TEST_SKIP_BUILD_RUST=1 environment variable.
Be mindful of these limitations:
--force
and --instance
command line options.The best way to manage your Unfurl project is to use Unfurl Cloud, our open-source platform for collaboratively developing cloud applications.
Check out the rest of Unfurl’s documentation here. Release notes can be found here.