Skip to content

Commit

Permalink
README: Add a deploy example with raw image-spec layouts
Browse files Browse the repository at this point in the history
For folks who want to diverge as little as possible from things
already in image-spec.  Downsides to this approach include:

* Non-sharded blobs [1], although it's not clear to me that modern
  filesystems suffer from having many entries in one directory [2].

* Possible duplicate blobs between two layouts.  You can address this
  with symlinks or similar, but you'd need extra tooling to do that.
  With a single CAS bucket, there's only one place that the blob could
  be, so deduping is free (but garbage collection becomes more
  complicated).

[1]: opencontainers/image-spec#449
[2]: opencontainers/image-spec#94 (comment)
  • Loading branch information
wking committed Sep 8, 2017
1 parent 92091a8 commit 47bf65c
Showing 1 changed file with 37 additions and 0 deletions.
37 changes: 37 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -154,6 +154,43 @@ To publish additional images matching the `example.com/app#…` family of [host-
To publish additional images matching new families (e.g. `example.com/other-app#…`), add their entries to new `/srv/example.com/oci-index/` indexes (e.g. `/srv/example.com/oci-index/other-app`).
All the CAS blobs can go in the same bucket under `/srv/example.com/oci-cas`, although if you want you can adjust the `casEngines` entries and keep CAS blobs in different buckets.

## Example: Serving OCI layouts from Nginx

As an alternative to the [previous example](#example-serving-everything-from-one-nginx-server), you can bucket your CAS blobs by serving [OCI layouts][layout] directly.
If your layout `index.json` are not setting `casEngines` and you are unwilling to update them to do so, you can [set `casEngines` in you ref-engines object](ref-engine-discovery.md#ref-engines-objects) at `/srv/example.com/.well-known/oci-host-ref-engines`:

```json
{
"refEngines": [
{
"protocol": "oci-index-template-v1",
"uri": "https://{host}/oci-image/{path}/index.json"
}
],
"casEngines": [
{
"protocol": "oci-cas-template-v1",
"uri": "https://example.com/oci-image/{path}/blobs/{algorithm}/{encoded}"
}
]
}
```

Then copy your [layout directories][layout] under `/srv/example.com/oci-image/{path}` to deploy them.

The Nginx config from the [previous example](#example-serving-everything-from-one-nginx-server) would need an adjusted [`location`][location] for the index media type:

```
location ~ ^/oci-image/.*/index.json$ {
types {}
default_type application/vnd.oci.image.index.v1+json;
charset utf-8;
charset_types *;
}
```

[image-spec]: /~https://github.com/opencontainers/image-spec
[image-spec-canonical-json]: /~https://github.com/opencontainers/image-spec/blob/v1.0.0/considerations.md#json
[layout]: /~https://github.com/opencontainers/image-spec/blob/v1.0.0/image-layout.md
[location]: http://nginx.org/en/docs/http/ngx_http_core_module.html#location
[Nginx]: https://nginx.org/

0 comments on commit 47bf65c

Please sign in to comment.