Skip to content

Latest commit

 

History

History
188 lines (160 loc) · 7.17 KB

ConfigurationFiles.md

File metadata and controls

188 lines (160 loc) · 7.17 KB

Capstan Configuration Files

You must provide two configuration files to run your application using Capstan:

{application-root}
└─── meta
       |- package.yaml
       |- run.yaml
| ... (application files and directories)

Both files must be placed inside directory named meta/ that you create directly inside your project's root directory. The package.yaml file tells Capstan how to properly create unikernel i.e. what precompiled packages to put in it besides your application files. And the run.yaml file gives Capstan all the neccessary information about your application (the runtime, the main file, ...) to run it.

meta/package.yaml

Below please find sample content of meta/package.yaml configuration file:

name: my-super-application
title: DEMO App
author: myname (myname@email.com)
require:
    - osv.cli

The first three parameters are simple metadata and are used later if you decide to publish your application as a package to make it available for everyone. Be careful, though, that you pick unique name for your package to avoid collisions with other users.

The most interesting attribute is the one named require. This is where you list all the packages that you would like to have them included in your final unikernel. In this example we've listed only one, osv.cli. You can omit the whole attribute if you don't need any precompiled packages. A list of all packages in the remote repository can be obtained by executing:

$ capstan package search
Name                Description    Version    Created              Platform
apache.spark-2.1.1  Apache Spark   0.2        2017-08-17 07:36     Ubuntu-14.04
erlang-7.0          Erlang         0.1        2017-08-17 08:23     Ubuntu-14.04
mysql-5.6.21        MySQL 5.6.21.  0.1        2017-08-17 08:02     Ubuntu-14.04
node-4.4.5          NodeJS 4.4.5   0.1        2017-08-17 07:14     Ubuntu-14.04
node-4.8.2          NodeJS 4.8.2   0.1        2017-08-17 07:43     Ubuntu-14.04
...

Then to download desired package into your local repository execute:

$ capstan package pull {package-name}

Alternatively, you can make use of --pull-missing flag when composing unikernel.

Please note that packages are copied to the unikernel in the same order that you specify here in meta/package.yaml file. So if two packages contain file with same name and inside same folder path, then the one that was copied last will remain. Only after all the packages are copied to the unikernel, your application files are copied too. So your application can never get overwritten. To verify the final content one can execute:

$ capstan package collect

A folder mpm-pkg appears containing exact content as it will be baked into unikernel during compose.

meta/run.yaml

Content of run.yaml file depends on runtime that this package is about to use. File is structured as follows:

runtime: {runtime-name}

config_set:
   {configuration-name}:
      {configuration}
   {configuration-name}:
      {configuration}
   ...
config_set_default: {configuration-name}

Key runtime defines what runtime should be used to run our application. Within key config_set we then define one or more named configurations. Configuration name is arbitrary string, while configuration itself is a set of key-value pairs required by selected runtime above. Key config_set_default defines what configuration set should be run by default i.e. if not otherwise specified via command-line parameters of capstan package compose command. It can be omitted when only one configuration set exists (it then becomes the default one).

A list of all runtimes can be obtained by executing:

$ capstan runtime list

RUNTIME    DESCRIPTION                                 DEPENDENCIES
native     Run arbitrary command inside OSv            []
node       Run JavaScript NodeJS 4.4.5 application     [node-4.4.5]
java       Run Java 1.8.0 application                  [openjdk8-zulu-compact1]
python     Run Python application                      [python-2.7]

And then Capstan can tell us what settings are supported for each runtime. For example, for NodeJS one can view expected content of the run.yaml file by executing:

$ capstan runtime preview -r node

--------- meta/run.yaml ---------
runtime: node

config_set:

   ################################################################
   ### This is one configuration set (feel free to rename it).  ###
   ################################################################
   myconfig1:
      # REQUIRED
      # Filepath of the NodeJS entrypoint (where server is defined).
      # Note that package root will correspond to filesystem root (/) in OSv image.
      # Example value: /server.js
      main: <filepath>
      
      # OPTIONAL
      # A list of Node.js args.
      # Example value: node_args:
      #                   - --require module1
      node_args:
         - <list>
      
      # OPTIONAL
      # A list of command line args used by the application.
      # Example value: args:
      #                   - argument1
      #                   - argument2
      args:
         - <list>
      
      # OPTIONAL
      # Set to true to only run node shell. Note that "main" and "args" will then be ignored.
      shell: false
      
      # OPTIONAL
      # Environment variables.
      # A map of environment variables to be set when unikernel is run.
      # Example value:  env:
      #                    PORT: 8000
      #                    HOSTNAME: www.myserver.org
      env:
         <key>: <value>
      
      # OPTIONAL
      # Configuration to contextualize.
      base: "<package-name>:<config_set>" 

   # Add as many named configurations as you need

# OPTIONAL
# What config_set should be used as default.
# This value can be overwritten with --runconfig argument.
config_set_default: myconfig1
---------------------------------

Lets sum up. To prepare appropriate run.yaml file, we must first select one of the supported runtimes. If we are about to be running NodeJS application, then we opt-in to use runtime named node. We get the details on how to prepare run.yaml for node by using Capstan command.

Configuration files per runtime

Below please find example meta/run.yaml configuration file for each supported runtime:

Automatic generation of configuration files

You can create configuration files manually or generate them using Capstan. The latter option does not only create empty files; Capstan pre-fills them with default values and detailed self-description in form of yaml comments. You are therefore advised to use Capstan to initialize configuration files for you.

To initialize meta/package.yaml file, use:

$ capstan package init \
   --name "my-super-application" \
   --title "DEMO App" \
   --author "myname (myname@email.com)" \
   --require osv.cli

This will create a meta subdirectory and meta/package.yaml file with the given content. Then to initialize meta/run.yaml file, use:

$ capstan runtime init -r {runtime-name}

This will create meta/run.yaml file with documentation for the selected runtime.