2019-02-15 15:36:30 +00:00
|
|
|
# Toolbox — Unprivileged development environment
|
2018-09-13 12:17:34 +00:00
|
|
|
|
2019-02-15 15:36:30 +00:00
|
|
|
[Toolbox](https://github.com/debarshiray/toolbox) is a tool that offers a
|
|
|
|
familiar RPM based environment for developing and debugging software that runs
|
|
|
|
fully unprivileged using [Podman](https://podman.io/).
|
2019-01-26 09:57:26 +00:00
|
|
|
|
|
|
|
The toolbox container is a fully *mutable* container; when you see
|
|
|
|
`yum install ansible` for example, that's something you can do inside your
|
|
|
|
toolbox container, without affecting the base operating system.
|
|
|
|
|
|
|
|
This is particularly useful on
|
|
|
|
[OSTree](https://ostree.readthedocs.io/en/latest/) based Fedora systems like
|
|
|
|
[Silverblue](https://silverblue.fedoraproject.org/). The intention of these
|
|
|
|
systems is to discourage installation of software on the host, and instead
|
|
|
|
install software as (or in) containers.
|
|
|
|
|
2019-02-28 19:34:11 +00:00
|
|
|
However, this tool doesn't *require* using an OSTree based system — it
|
2019-01-26 09:57:26 +00:00
|
|
|
works equally well if you're running e.g. existing Fedora Workstation or
|
|
|
|
Server, and that's a useful way to incrementally adopt containerization.
|
2018-09-13 12:17:34 +00:00
|
|
|
|
2019-02-19 14:16:28 +00:00
|
|
|
The toolbox environment is based on an [OCI](https://www.opencontainers.org/)
|
|
|
|
image. On Fedora this is the `fedora-toolbox` image. This image is then
|
|
|
|
customized for the current user to create a toolbox container that seamlessly
|
|
|
|
integrates with the rest of the operating system.
|
2018-08-31 16:02:49 +00:00
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
2019-02-15 15:36:30 +00:00
|
|
|
### Create your toolbox container:
|
2018-08-31 16:02:49 +00:00
|
|
|
```
|
2019-02-15 15:36:30 +00:00
|
|
|
[user@hostname ~]$ toolbox create
|
2019-01-21 16:07:02 +00:00
|
|
|
[user@hostname ~]$
|
2018-08-31 16:02:49 +00:00
|
|
|
```
|
|
|
|
This will create a container, and an image, called
|
2018-10-19 14:50:59 +00:00
|
|
|
`fedora-toolbox-<your-username>:<version-id>` that's specifically customised
|
|
|
|
for your host user.
|
2018-08-31 16:02:49 +00:00
|
|
|
|
2019-02-15 15:36:30 +00:00
|
|
|
### Enter the toolbox:
|
2018-08-31 16:02:49 +00:00
|
|
|
```
|
2019-02-15 15:36:30 +00:00
|
|
|
[user@hostname ~]$ toolbox enter
|
2018-09-12 14:29:15 +00:00
|
|
|
🔹[user@toolbox ~]$
|
2018-08-31 16:02:49 +00:00
|
|
|
```
|