Signed-off-by: Jess Frazelle <acidburn@microsoft.com> add attributes Signed-off-by: Jess Frazelle <acidburn@microsoft.com>
53 lines
1.8 KiB
Markdown
53 lines
1.8 KiB
Markdown
# binctr
|
|
|
|
[data:image/s3,"s3://crabby-images/7b615/7b615f0c61907f18105574f98b2506216e01d736" alt="Build Status"](https://travis-ci.org/genuinetools/binctr)
|
|
[data:image/s3,"s3://crabby-images/e002f/e002fea969cbf4fcfb5cca82e5a7e38fb0dc2611" alt="Go Report Card"](https://goreportcard.com/report/github.com/genuinetools/binctr)
|
|
[data:image/s3,"s3://crabby-images/e96c8/e96c854a6b33e6f491071cc429ec8489c67b622b" alt="GoDoc"](https://godoc.org/github.com/genuinetools/binctr)
|
|
|
|
Create fully static, including rootfs embedded, binaries that pop you directly
|
|
into a container. **Can be run by an unprivileged user.**
|
|
|
|
Check out the blog post: [blog.jessfraz.com/post/getting-towards-real-sandbox-containers](https://blog.jessfraz.com/post/getting-towards-real-sandbox-containers/).
|
|
|
|
This is based off a crazy idea from [@crosbymichael](https://github.com/crosbymichael)
|
|
who first embedded an image in a binary :D
|
|
|
|
**HISTORY:** This project used to use a POC fork of libcontainer until [@cyphar](https://github.com/cyphar)
|
|
got rootless containers into upstream! Woohoo!
|
|
Check out the original thread on the
|
|
[mailing list](https://groups.google.com/a/opencontainers.org/forum/#!topic/dev/yutVaSLcqWI).
|
|
|
|
### Building
|
|
|
|
You will need `libapparmor-dev` and `libseccomp-dev`.
|
|
|
|
Most importantly you need userns in your kernel (`CONFIG_USER_NS=y`)
|
|
or else this won't even work.
|
|
|
|
```console
|
|
# building the alpine example
|
|
$ make alpine
|
|
Static container created at: ./alpine
|
|
|
|
# building the busybox example
|
|
$ make busybox
|
|
Static container created at: ./busybox
|
|
|
|
# building the cl-k8s example
|
|
$ make cl-k8s
|
|
Static container created at: ./cl-k8s
|
|
```
|
|
|
|
### Running
|
|
|
|
```console
|
|
$ ./alpine
|
|
$ ./busybox
|
|
$ ./cl-k8s
|
|
```
|
|
|
|
## Cool things
|
|
|
|
The binary spawned does NOT need to oversee the container process if you
|
|
run in detached mode with a PID file. You can have it watched by the user mode
|
|
systemd so that this binary is really just the launcher :)
|