From dffb1d232b8ca6876dc8785ed3430f2656cc8e40 Mon Sep 17 00:00:00 2001 From: Mrunal Patel Date: Wed, 2 Mar 2016 16:18:17 -0800 Subject: [PATCH 1/4] Add man pages in markdown format Signed-off-by: Mrunal Patel --- man/runc-checkpoint.8.md | 22 +++++++++++++++++ man/runc-delete.8.md | 14 +++++++++++ man/runc-events.8.md | 16 +++++++++++++ man/runc-exec.8.md | 28 ++++++++++++++++++++++ man/runc-kill.8.md | 15 ++++++++++++ man/runc-list.8.md | 14 +++++++++++ man/runc-pause.8.md | 12 ++++++++++ man/runc-restore.8.md | 24 +++++++++++++++++++ man/runc-resume.8.md | 12 ++++++++++ man/runc-spec.8.md | 11 +++++++++ man/runc-start.8.md | 19 +++++++++++++++ man/runc-state.8.md | 11 +++++++++ man/runc.8.md | 52 ++++++++++++++++++++++++++++++++++++++++ 13 files changed, 250 insertions(+) create mode 100644 man/runc-checkpoint.8.md create mode 100644 man/runc-delete.8.md create mode 100644 man/runc-events.8.md create mode 100644 man/runc-exec.8.md create mode 100644 man/runc-kill.8.md create mode 100644 man/runc-list.8.md create mode 100644 man/runc-pause.8.md create mode 100644 man/runc-restore.8.md create mode 100644 man/runc-resume.8.md create mode 100644 man/runc-spec.8.md create mode 100644 man/runc-start.8.md create mode 100644 man/runc-state.8.md create mode 100644 man/runc.8.md diff --git a/man/runc-checkpoint.8.md b/man/runc-checkpoint.8.md new file mode 100644 index 00000000..6dc7b889 --- /dev/null +++ b/man/runc-checkpoint.8.md @@ -0,0 +1,22 @@ +# NAME + runc checkpoint - checkpoint a running container + +# USAGE + runc checkpoint [command options] + +Where "" is the name for the instance of the container to be +checkpointed. + +# DESCRIPTION + The checkpoint command saves the state of the container instance. + +# OPTIONS + --image-path path for saving criu image files + --work-path path for saving work files and logs + --leave-running leave the process running after checkpointing + --tcp-established allow open tcp connections + --ext-unix-sk allow external unix sockets + --shell-job allow shell jobs + --page-server ADDRESS:PORT of the page server + --file-locks handle file locks, for safety + --manage-cgroups-mode cgroups mode: 'soft' (default), 'full' and 'strict'. diff --git a/man/runc-delete.8.md b/man/runc-delete.8.md new file mode 100644 index 00000000..1ea021e1 --- /dev/null +++ b/man/runc-delete.8.md @@ -0,0 +1,14 @@ +# NAME + runc delete - delete any resources held by the container often used with detached containers + +# SYNOPSIS + runc delete + +Where "" is the name for the instance of the container. + +# EXAMPLE +For example, if the container id is "ubuntu01" and runc list currently shows the +status of "ubuntu01" as "destroyed" the following will delete resources held for +"ubuntu01" removing "ubuntu01" from the runc list of containers: + + # runc delete ubuntu01 diff --git a/man/runc-events.8.md b/man/runc-events.8.md new file mode 100644 index 00000000..10385e9b --- /dev/null +++ b/man/runc-events.8.md @@ -0,0 +1,16 @@ +# NAME + runc events - display container events such as OOM notifications, cpu, memory, IO and network stats + +# SYNOPSIS + runc events [command options] + +Where "" is the name for the instance of the container. + +# DESCRIPTION + The events command displays information about the container. By default the +information is displayed once every 5 seconds. + +# OPTIONS + --interval "5s" set the stats collection interval + --stats display the container's stats then exit + diff --git a/man/runc-exec.8.md b/man/runc-exec.8.md new file mode 100644 index 00000000..d75db78b --- /dev/null +++ b/man/runc-exec.8.md @@ -0,0 +1,28 @@ +# NAME + runc exec - execute new process inside the container + +# SYNOPSIS + runc exec [command options] + +Where "" is the name for the instance of the container and +"" is the command to be executed in the container. + +# EXAMPLE +For example, if the container is configured to run the linux ps command the +following will output a list of processes running in the container: + + # runc exec ps + +# OPTIONS + --console specify the pty slave path for use with the container + --cwd current working directory in the container + --env, -e [--env option --env option] set environment variables + --tty, -t allocate a pseudo-TTY + --user, -u UID (format: [:]) + --process, -p path to the process.json + --detach, -d detach from the container's process + --pid-file specify the file to write the process id to + --process-label set the asm process label for the process commonly used with selinux + --apparmor set the apparmor profile for the process + --no-new-privs set the no new privileges value for the process + --cap, -c [--cap option --cap option] add a capability to the bounding set for the process diff --git a/man/runc-kill.8.md b/man/runc-kill.8.md new file mode 100644 index 00000000..65642d64 --- /dev/null +++ b/man/runc-kill.8.md @@ -0,0 +1,15 @@ +# NAME + runc kill - kill sends the specified signal (default: SIGTERM) to the container's init process + +# SYNOPSIS + runc kill + +Where "" is the name for the instance of the container and +"" is the signal to be sent to the init process. + +# EXAMPLE + +For example, if the container id is "ubuntu01" the following will send a "KILL" +signal to the init process of the "ubuntu01" container: + + # runc kill ubuntu01 KILL diff --git a/man/runc-list.8.md b/man/runc-list.8.md new file mode 100644 index 00000000..c7ab0f60 --- /dev/null +++ b/man/runc-list.8.md @@ -0,0 +1,14 @@ +# NAME + runc list - lists containers started by runc with the given root + +# SYNOPSIS + runc list [command options] [arguments...] + +# DESCRIPTION + The default format is table. The following will output the list of containers +in json format: + + # runc list -f json + +# OPTIONS + --format, -f select one of: table or json. diff --git a/man/runc-pause.8.md b/man/runc-pause.8.md new file mode 100644 index 00000000..4a4265e8 --- /dev/null +++ b/man/runc-pause.8.md @@ -0,0 +1,12 @@ +# NAME + runc pause - pause suspends all processes inside the container + +# SYNOPSIS + runc pause + +Where "" is the name for the instance of the container to be +paused. + +# DESCRIPTION + The pause command suspends all processes in the instance of the container. +Use runc list to identiy instances of containers and their current status. diff --git a/man/runc-restore.8.md b/man/runc-restore.8.md new file mode 100644 index 00000000..b0dec455 --- /dev/null +++ b/man/runc-restore.8.md @@ -0,0 +1,24 @@ +# NAME + runc restore - restore a container from a previous checkpoint + +# SYNOPSIS + runc restore [command options] + +Where "" is the name for the instance of the container to be +restored. + +# DESCRIPTION + Restores the saved state of the container instance that was previously saved +using the runc checkpoint command. + +# OPTIONS + --image-path path to criu image files for restoring + --work-path path for saving work files and logs + --tcp-established allow open tcp connections + --ext-unix-sk allow external unix sockets + --shell-job allow shell jobs + --file-locks handle file locks, for safety + --manage-cgroups-mode cgroups mode: 'soft' (default), 'full' and 'strict'. + --bundle, -b path to the root of the bundle directory + --detach, -d detach from the container's process + --pid-file specify the file to write the process id to diff --git a/man/runc-resume.8.md b/man/runc-resume.8.md new file mode 100644 index 00000000..627885f1 --- /dev/null +++ b/man/runc-resume.8.md @@ -0,0 +1,12 @@ +# NAME + runc resume - resumes all processes that have been previously paused + +# SYNOPSIS + runc resume + +Where "" is the name for the instance of the container to be +resumed. + +# DESCRIPTION + The resume command resumes all processes in the instance of the container. +Use runc list to identiy instances of containers and their current status. diff --git a/man/runc-spec.8.md b/man/runc-spec.8.md new file mode 100644 index 00000000..3a2e5da8 --- /dev/null +++ b/man/runc-spec.8.md @@ -0,0 +1,11 @@ +# NAME + runc spec - create a new specification file + +# SYNOPSIS + runc spec [command options] [arguments...] + +# DESCRIPTION + The spec command creates the new specification file named "config.json" for the bundle." + +# OPTIONS + --bundle, -b path to the root of the bundle directory diff --git a/man/runc-start.8.md b/man/runc-start.8.md new file mode 100644 index 00000000..07c42ffd --- /dev/null +++ b/man/runc-start.8.md @@ -0,0 +1,19 @@ +# NAME + runc start - create and run a container + +# SYNOPSIS + runc start [command options] + +Where "" is your name for the instance of the container that you +are starting. The name you provide for the container instance must be unique on +your host. + +# DESCRIPTION + The start command creates an instance of a container for a bundle. The bundle +is a directory with a specification file and a root filesystem. + +# OPTIONS + --bundle, -b path to the root of the bundle directory, defaults to the current directory + --console specify the pty slave path for use with the container + --detach, -d detach from the container's process + --pid-file specify the file to write the process id to diff --git a/man/runc-state.8.md b/man/runc-state.8.md new file mode 100644 index 00000000..80f43426 --- /dev/null +++ b/man/runc-state.8.md @@ -0,0 +1,11 @@ +# NAME + runc state - output the state of a container + +# SYNOPSIS + runc state + +Where "" is your name for the instance of the container. + +# DESCRIPTION + The state command outputs current state information for the +instance of a container. diff --git a/man/runc.8.md b/man/runc.8.md new file mode 100644 index 00000000..ccfc5332 --- /dev/null +++ b/man/runc.8.md @@ -0,0 +1,52 @@ +# NAME + runc - Open Container Initiative runtime + +# SYNOPSIS + runc [global options] command [command options] [arguments...] + +# DESCRIPTION +runc is a command line client for running applications packaged according to +the Open Container Format (OCF) and is a compliant implementation of the +Open Container Initiative specification. + +runc integrates well with existing process supervisors to provide a production +container runtime environment for applications. It can be used with your +existing process monitoring tools and the container will be spawned as a +direct child of the process supervisor. + +Containers are configured using bundles. A bundle for a container is a directory +that includes a specification file named "config.json" and a root filesystem. +The root filesystem contains the contents of the container. + +To start a new instance of a container: + + # runc start [ -b bundle ] + +Where "" is your name for the instance of the container that you +are starting. The name you provide for the container instance must be unique on +your host. Providing the bundle directory using "-b" is optional. The default +value for "bundle" is the current directory. + +# COMMANDS + checkpoint checkpoint a running container + delete delete any resources held by the container often used with detached containers + events display container events such as OOM notifications, cpu, memory, IO and network stats + exec execute new process inside the container + kill kill sends the specified signal (default: SIGTERM) to the container's init process + list lists containers started by runc with the given root + pause pause suspends all processes inside the container + restore restore a container from a previous checkpoint + resume resumes all processes that have been previously paused + spec create a new specification file + start create and run a container + state output the state of a container + help, h Shows a list of commands or help for one command + +# GLOBAL OPTIONS + --debug enable debug output for logging + --log set the log file path where internal debug information is written + --log-format "text" set the format used by logs ('text' (default), or 'json') + --root "/run/opencontainer/containers" root directory for storage of container state (this should be located in tmpfs) + --criu "criu" path to the criu binary used for checkpoint and restore + --help, -h show help + --version, -v print the version From d8482f35776c597fc5d6925457d8f1959551a80b Mon Sep 17 00:00:00 2001 From: Mrunal Patel Date: Wed, 2 Mar 2016 16:18:52 -0800 Subject: [PATCH 2/4] Add script to generate man pages from markdown This is copied from docker Signed-off-by: Mrunal Patel --- man/md2man-all.sh | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100755 man/md2man-all.sh diff --git a/man/md2man-all.sh b/man/md2man-all.sh new file mode 100755 index 00000000..97c65c93 --- /dev/null +++ b/man/md2man-all.sh @@ -0,0 +1,22 @@ +#!/bin/bash +set -e + +# get into this script's directory +cd "$(dirname "$(readlink -f "$BASH_SOURCE")")" + +[ "$1" = '-q' ] || { + set -x + pwd +} + +for FILE in *.md; do + base="$(basename "$FILE")" + name="${base%.md}" + num="${name##*.}" + if [ -z "$num" -o "$name" = "$num" ]; then + # skip files that aren't of the format xxxx.N.md (like README.md) + continue + fi + mkdir -p "./man${num}" + go-md2man -in "$FILE" -out "./man${num}/${name}" +done From b41affd7b44f8fc13f4073a516401d872f6edb52 Mon Sep 17 00:00:00 2001 From: Mrunal Patel Date: Wed, 2 Mar 2016 16:19:49 -0800 Subject: [PATCH 3/4] Update .gitignore for generate man pages Signed-off-by: Mrunal Patel --- .gitignore | 1 + 1 file changed, 1 insertion(+) diff --git a/.gitignore b/.gitignore index 266ee084..76c04941 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ vendor/pkg /runc Godeps/_workspace/src/github.com/opencontainers/runc +man/man8 From 208870ce1813a45c28facacb3bdbd247edc2024c Mon Sep 17 00:00:00 2001 From: Mrunal Patel Date: Thu, 3 Mar 2016 14:48:22 -0800 Subject: [PATCH 4/4] Add README.md for generating man pages Signed-off-by: Mrunal Patel --- man/README.md | 11 +++++++++++ 1 file changed, 11 insertions(+) create mode 100644 man/README.md diff --git a/man/README.md b/man/README.md new file mode 100644 index 00000000..1d7a54fa --- /dev/null +++ b/man/README.md @@ -0,0 +1,11 @@ +runc man pages +==================== + +This directory contains man pages for runc in markdown format. + +To generate man pages from it, use this command + + ./md2man-all.sh + +You will see man pages generated under the man8 directory. +