2019-06-26 16:31:43 -05:00
# zot [![Build Status](https://travis-ci.org/anuvu/zot.svg?branch=master)](https://travis-ci.org/anuvu/zot) [![codecov.io](http://codecov.io/github/anuvu/zot/coverage.svg?branch=master)](http://codecov.io/github/anuvu/zot?branch=master)
2019-06-20 18:36:40 -05:00
**zot** is a single-purpose OCI image repository server based on the
[OCI distribution spec ](https://github.com/opencontainers/distribution-spec ).
* Conforms to [OCI distribution spec ](https://github.com/opencontainers/distribution-spec ) APIs
* Uses [OCI storage layout ](https://github.com/opencontainers/image-spec/blob/master/image-layout.md ) for storage layout
* TLS support
* *Basic* and TLS mutual authentication
* Swagger based documentation
2019-08-28 17:16:11 -05:00
* Doesn't require _root_ privileges
2019-06-26 16:28:34 -05:00
2019-08-14 14:35:51 -05:00
# Building
* Build inside a container (preferred)
```
make binary-container
```
2019-08-14 18:26:25 -05:00
* Alternatively, build inside a container using [stacker ](https://github.com/anuvu/stacker ) (preferred)
```
make binary-stacker
```
2019-08-14 14:35:51 -05:00
* Build using host's toolchain
```
make
```
Build artifacts are in bin/
# Running
2019-08-28 17:16:11 -05:00
bin/zot serve _config-file_
Examples of config files are available in [examples/ ](examples/ ) dir.
# Ecosystem
## skopeo
[skopeo ](https://github.com/containers/skopeo ) is a tool to work with remote
image repositories.
We have a [patched version ](https://github.com/anuvu/skopeo ) available that
works with _zot_ .
```
git clone https://github.com/anuvu/skopeo
cd skopeo
make GO111MODULE=on binary-local
```
## cri-o
[cri-o ](https://github.com/cri-o/cri-o ) is a OCI-based Kubernetes container
runtime interface.
We have a [patched version ](https://github.com/anuvu/image ) of containers/image
available that works with _zot_ which must be linked with cri-o.
```
git clone https://github.com/cri-o/cri-o
cd cri-o
echo 'replace github.com/containers/image => github.com/anuvu/image v1.5.2-0.20190827234748-f71edca6153a' >> go.mod
make bin/crio crio.conf GO111MODULE=on
```
2019-08-14 14:35:51 -05:00
2019-06-26 16:28:34 -05:00
# Caveats
* go 1.12+
* The OCI distribution spec is still WIP, and we try to keep up