runc/config.md

6.2 KiB
Raw Blame History

Configuration file

The containers top-level directory MUST contain a configuration file called config.json. For now the canonical schema is defined in spec.go and spec_linux.go, but this will be moved to a formal JSON schema over time.

The configuration file contains metadata necessary to implement standard operations against the container. This includes the process to run, environment variables to inject, sandboxing features to use, etc.

Below is a detailed description of each field defined in the configuration format.

Manifest version

  • version (string, required) must be in SemVer v2.0.0 format and specifies the version of the OCF specification with which the container bundle complies. The Open Container spec follows semantic versioning and retains forward and backward compatibility within major versions. For example, if an implementation is compliant with version 1.0.1 of the spec, it is compatible with the complete 1.x series.

Example

    "version": "0.1.0"

Root Configuration

Each container has exactly one root filesystem, specified in the root object:

  • path (string, required) Specifies the path to the root filesystem for the container, relative to the path where the manifest is. A directory MUST exist at the relative path declared by the field.
  • readonly (bool, optional) If true then the root filesystem MUST be read-only inside the container. Defaults to false.

Example

"root": {
    "path": "rootfs",
    "readonly": true
}

Mount Configuration

Additional filesystems can be declared as "mounts", specified in the mounts array. The parameters are similar to the ones in Linux mount system call. http://linux.die.net/man/2/mount

  • type (string, required) Linux, filesystemtype argument supported by the kernel are listed in /proc/filesystems (e.g., "minix", "ext2", "ext3", "jfs", "xfs", "reiserfs", "msdos", "proc", "nfs", "iso9660"). Windows: ntfs
  • source (string, required) a device name, but can also be a directory name or a dummy. Windows, the volume name that is the target of the mount point. \?\Volume{GUID}\ (on Windows source is called target)
  • destination (string, required) where the source filesystem is mounted relative to the container rootfs.
  • options (string, optional) in the fstab format https://wiki.archlinux.org/index.php/Fstab.

Example (Linux)

"mounts": [
    {
        "type": "proc",
        "source": "proc",
        "destination": "/proc",
        "options": ""
    },
    {
        "type": "tmpfs",
        "source": "tmpfs",
        "destination": "/dev",
        "options": "nosuid,strictatime,mode=755,size=65536k"
    },
    {
        "type": "devpts",
        "source": "devpts",
        "destination": "/dev/pts",
        "options": "nosuid,noexec,newinstance,ptmxmode=0666,mode=0620,gid=5"
    },
    {
        "type": "bind",
        "source": "/volumes/testing",
        "destination": "/data",
        "options": "rbind,rw"
    }
]

Example (Windows)

"mounts": [
    {
        "type": "ntfs",
        "source": "\\\\?\\Volume\\{2eca078d-5cbc-43d3-aff8-7e8511f60d0e}\\",
        "destination": "C:\\Users\\crosbymichael\\My Fancy Mount Point\\",
        "options": ""
    }
]

See links for details about mountvol and SetVolumeMountPoint in Windows.

Process configuration

  • terminal (bool, optional) specifies whether you want a terminal attached to that process. Defaults to false.
  • cwd (string, optional) is the working directory that will be set for the executable.
  • env (array of strings, optional) contains a list of variables that will be set in the process's environment prior to execution. Elements in the array are specified as Strings in the form "KEY=value". The left hand side must consist solely of letters, digits, and underscores _ as outlined in IEEE Std 1003.1-2001.
  • args (string, required) executable to launch and any flags as an array. The executable is the first element and must be available at the given path inside of the rootfs. If the executable path is not an absolute path then the search $PATH is interpreted to find the executable.

The user for the process is a platform-specific structure that allows specific control over which user the process runs as. For Linux-based systems the user structure has the following fields:

  • uid (int, required) specifies the user id.
  • gid (int, required) specifies the group id.
  • additionalGids (array of ints, optional) specifies additional group ids to be added to the process.

Example (Linux)

"process": {
    "terminal": true,
    "user": {
        "uid": 1,
        "gid": 1,
        "additionalGids": []
    },
    "env": [
        "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
        "TERM=xterm"
    ],
    "cwd": "",
    "args": [
        "sh"
    ]
}

Hostname

  • hostname (string, optional) as it is accessible to processes running inside.

Example

"hostname": "mrsdalloway"

Platform-specific configuration

  • os (string, required) specifies the operating system family this image must run on. Values for os must be in the list specified by the Go Language document for $GOOS.
  • arch (string, required) specifies the instruction set for which the binaries in the image have been compiled. Values for arch must be in the list specified by the Go Language document for $GOARCH.
"platform": {
    "os": "linux",
    "arch": "amd64"
}

Interpretation of the platform section of the JSON file is used to find which platform-specific sections may be available in the document. For example, if os is set to linux, then a JSON object conforming to the Linux-specific schema SHOULD be found at the key linux in the config.json.