The DCOS package repository for packages that have been certified by Mesosphere.
The latest DCOS comes pre-configured to use the Universe repository.
If you would like to add this to your DCOS manually:
dcos package repo add Universe https://universe.mesosphere.com/repo
The default branch for this repository is version-2.x
, which reflects the current schema for the
Universe. In the future, if the format changes significantly, there will be additional branches.
The cli-tests-*
branches are used for integration testing by the DCOS CLI and provides a fixed and well known set of packages to write tests against.
Interested in making your package or service available to the world? The instructions below will help you set up a local copy of the Universe for development.
- Clone the repo (or you may wish to fork it first):
git clone https://github.com/mesosphere/universe.git /path/to/universe
- You may need to install the
jsonschema
Python package if you don't have it:
sudo pip install jsonschema
- Install pre-commit hook:
bash /path/to/universe/scripts/install-git-hooks.sh
- To test in DCOS we need to make the packages available to your cluster. We can do this using topic or feature branches. Once you have committed your changes and pushed them to a topic branch. We can use them within DCOS with:
dcos package repo add Development http://github/path/to/branch/zip
E.g. assuming the topic branch is named topic-branch
and residing on https://github.com/mesosphere/universe/tree/topic-branch
(note that the zip representation resides under archive/topic-branch
):
dcos package repo add Development https://github.com/mesosphere/universe/archive/topic-branch.zip
The pre-commit hook will run build.sh before allowing you to commit. This
script validates your package definitions and regenerates the index file. You may need to
git add repo/meta/index.json
after running it once before you are able to pass validation and
commit your changes.
Before merging to Universe, you must run build.sh to regenerate the package index. If you have installed the pre-commit hook as above, this will be done automatically on commit.
Once complete, please submit a pull request against the version-2.x
branch with your changes.
Every pull request opened on this repo will have a set of automated verifications ran against it. These automated verification are reported against the pull request using the GitHub status API. All verifcations must pass in order for a pull request to be eligible for merge.
Packages are encapsulated in their own directory, with one subdirectory for each package version.
└── foo
├── 0
│ ├── command.json
│ ├── config.json
│ ├── marathon.json.mustache
│ ├── resource.json
│ └── package.json
├── 1
│ ├── command.json
│ ├── config.json
│ ├── marathon.json.mustache
│ ├── resource.json
│ └── package.json
└── ...
Sample package directory layout.
{
"packagingVersion": "2.0",
"name": "foo",
"version": "1.2.3",
"tags": ["mesosphere", "framework"],
"maintainer": "[email protected]",
"description": "Does baz.",
"scm": "https://github.com/bar/foo.git",
"website": "http://bar.io/foo",
"postInstallNotes": "Have fun foo-ing and baz-ing!"
}
Sample package.json
.
The required fields are:
- packagingVersion
- name
- version
- tags
- maintainer
- description
This file describes the configuration properties supported by the package. Each property can specify whether or not it is required, a default value, as well as some basic validation.
Users can then override specific values at installation time by passing an options file to the DCOS CLI.
{
"type": "object",
"properties": {
"foo": {
"type": "object",
"properties": {
"baz": {
"type": "integer",
"description": "How many times to do baz.",
"minimum": 0,
"maximum": 16,
"required": false,
"default": 4
}
},
"required": ["baz"]
}
},
"required": ["foo"]
}
Sample config.json
.
config.json
must be a valid JSON Schema file. Check out the
JSON Schema examples.
This file describes how to run the package as a Marathon app.
User-supplied metadata (as described in config.json
), the defaults from config.json
and the
resource information in resource.json
will be injected to the template using
mustache template syntax.
{
"id": "foo",
"cpus": "1.0",
"mem": "1024",
"instances": "1",
"args": ["{{{foo.baz}}}"],
"container": {
"type": "DOCKER",
"docker": {
"image": "{{resource.assets.container.docker.foo23b1cfe8e04a}}",
"network": "BRIDGE",
"portMappings": [
{
"containerPort": 8080,
"hostPort": 0,
"servicePort": 0,
"protocol": "tcp"
}
]
}
}
}
Sample marathon.json.mustache
.
See the Marathon API Documentation for more detailed instruction on app definitions.
This file is optional. Describes how to install the package's CLI. Currently the only supported format is a Pip requirements file where each element in the array is a line in the requirements file.
{
"pip": [
"https://pypi.python.org/packages/source/f/foo/foo-1.2.3.tar.gz"
]
}
Sample command.json
.
See the Command Schema for a detailed description of the schema.
This file contains all of the externally hosted resources (E.g. Docker images, HTTP objects and images) needed to install the application.
{
"images": {
"icon-small": "http://some.org/foo/small.png",
"icon-medium": "http://some.org/foo/medium.png",
"icon-large": "http://some.org/foo/large.png",
"screenshots": [
"http://some.org/foo/screen-1.png",
"http://some.org/foo/screen-2.png"
]
},
"assets": {
"uris": {
"log4j-properties": "http://some.org/foo/log4j.properties"
},
"container": {
"docker": {
"23b1cfe8e04a": "some-org/foo:1.0.0"
}
}
}
}
Sample resource.json
.
For the Docker image, please use the image ID for the referenced image. You can find this by
pulling the image locally and running docker images some-org/foo:1.0.0
.
While images
is an optional field, it is highly recommended you include icons and screenshots
in your package and update the path definitions accordingly. Specifications are as follows:
icon-small
: 48px (w) x 48px (h)icon-medium
: 96px (w) x 96px (h)icon-large
: 256px (w) x 256px (h)screenshots[...]
: 1200px (w) x 675px (h)
NOTE: To ensure your service icons look beautiful on retina-ready displays,
please supply 2x versions of all icons. No changes are needed to
package.json
- simply supply an additional icon file with the text @2x
in
the name before the file extension.
For example, the icon icon-cassandra-small.png
would have a retina-ready
alternate image named [email protected]
.
The registry specification is versioned separately in the file /repo/meta/version.json
.
{
"version": "2.0.0-rc2"
}
Sample repo/meta/version.json
.
This version is updated with any change to the required file content
(typically validated using JSON schema) or expected file organization in the
repo
directory.
NOTE: The current version is 2.0.0-rc2
to facilitate rapid
iteration. This version will be fixed and incremented as
described above as programs that consume the format reach maturity.
The packaging version should also be included in the package.json
for each package using the
packagingVersion
property.
Package content is validated using JSON Schema.
The schema definitions live in /repo/meta/schema
.
├── LICENSE
├── README.md
├── docs
│ ├── best-practices.md
│ └── contributing.md
├── hooks
│ └── pre-commit
├── repo
│ ├── meta
│ │ ├── index.json
│ │ ├── schema
│ │ │ ├── command-schema.json
│ │ │ ├── config-schema.json
│ │ │ ├── index-schema.json
│ │ │ ├── resource-schema.json
│ │ │ └── package-schema.json
│ │ └── version.json
│ └── packages
│ ├── B
│ │ ├── bar
│ │ │ ├── 0
│ │ │ │ ├── command.json
│ │ │ │ ├── config.json
│ │ │ │ ├── marathon.json.mustache
│ │ │ │ ├── resource.json
│ │ │ │ └── package.json
│ │ │ └── ...
│ │ └── ...
│ ├── F
│ │ ├── foo
│ │ │ ├── 0
│ │ │ │ ├── config.json
│ │ │ │ ├── marathon.json.mustache
│ │ │ │ ├── resource.json
│ │ │ │ └── package.json
│ │ │ └── ...
│ │ └── ...
│ └── ...
└── scripts
├── 1-validate-packages.sh
├── 2-build-index.sh
├── 3-validate-index.sh
├── 4-detect-dependency-cycles.sh
├── build.sh
└── install-git-hooks.sh
This section describes transfer of package metadata from a universe source to a client program.
┌───────────────┐ ┌────────────────┐
│public universe│ │private universe│
└───────────────┘ └────────────────┘
http \ / http
\ /
\ /
┌────┐ ┌────────┐
│DCOS│-----------│Marathon│
└────┘ http └────────┘
Sample (simplified) architecture for a universe client program.
Package sources are described as URLs.
Source URLs encode the transfer protocol. Recommendations for several transfer protocols follow.
HTTP and HTTPS
A URL that designates a
zip file
accessible over HTTP or HTTPS with media type application/zip
.
Example: http://my.org/files/universe/packages.zip