2015-06-25 08:15:48 +08:00
# Runtime and Lifecycle
2015-06-06 08:39:27 +08:00
2015-07-30 05:09:30 +08:00
## State
The runtime state for a container is persisted on disk so that external tools can consume and act on this information.
The runtime state is stored in a JSON encoded file.
It is recommended that this file is stored in a temporary filesystem so that it can be removed on a system reboot.
2015-09-04 09:31:38 +08:00
On Linux based systems the state information should be stored in `/run/opencontainer/containers` .
The directory structure for a container is `/run/opencontainer/containers/<containerID>/state.json` .
2015-07-30 05:09:30 +08:00
By providing a default location that container state is stored external applications can find all containers running on a system.
2015-09-29 22:19:26 +08:00
* **`version`** (string) Version of the OCI specification used when creating the container.
* **`id`** (string) ID is the container's ID.
* **`pid`** (int) Pid is the ID of the main process within the container.
2015-09-30 01:37:47 +08:00
* **`bundlePath`** (string) BundlePath is the path to the container's bundle directory.
2015-07-30 05:09:30 +08:00
The ID is provided in the state because hooks will be executed with the state as the payload.
This allows the hook to perform clean and teardown logic after the runtime destroys its own state.
The root directory to the bundle is provided in the state so that consumers can find the container's configuration and rootfs where it is located on the host's filesystem.
*Example*
```json
{
2015-09-04 09:31:38 +08:00
"id": "oc-container",
2015-07-30 05:09:30 +08:00
"pid": 4422,
"root": "/containers/redis"
}
```
2015-06-25 08:15:48 +08:00
## Lifecycle
2015-06-06 08:39:27 +08:00
2015-06-25 08:15:48 +08:00
### Create
2015-06-17 09:08:14 +08:00
Creates the container: file system, namespaces, cgroups, capabilities.
2015-06-25 08:15:48 +08:00
### Start (process)
2015-06-17 09:08:14 +08:00
2015-09-09 22:17:06 +08:00
Runs a process in a container.
Can be invoked several times.
2015-06-17 09:08:14 +08:00
2015-06-25 08:15:48 +08:00
### Stop (process)
2015-06-17 09:08:14 +08:00
2015-09-09 22:17:06 +08:00
Not sure we need that from runc cli.
Process is killed from the outside.
2015-06-17 09:08:14 +08:00
2015-07-26 14:52:23 +08:00
This event needs to be captured by runc to run onstop event handlers.
2015-08-04 01:52:52 +08:00
## Hooks
2015-09-09 22:17:06 +08:00
2015-09-25 23:04:11 +08:00
See [runtime configuration for hooks ](./runtime-config.md )