kubespray/docs/CRI/cri-o.md

91 lines
2.1 KiB
Markdown
Raw Normal View History

2019-12-04 23:22:57 +08:00
# CRI-O
2018-07-30 23:47:13 +08:00
2018-12-26 14:55:17 +08:00
[CRI-O] is a lightweight container runtime for Kubernetes.
Kubespray supports basic functionality for using CRI-O as the default container runtime in a cluster.
2018-07-30 23:47:13 +08:00
2018-12-26 14:55:17 +08:00
* Kubernetes supports CRI-O on v1.11.1 or later.
* etcd: configure either kubeadm managed etcd or host deployment
2018-07-30 23:47:13 +08:00
_To use the CRI-O container runtime set the following variables:_
2018-07-30 23:47:13 +08:00
## all/all.yml
2018-07-30 23:47:13 +08:00
2018-12-26 14:55:17 +08:00
```yaml
2018-07-30 23:47:13 +08:00
download_container: false
skip_downloads: false
etcd_deployment_type: host # optionally kubeadm
2018-07-30 23:47:13 +08:00
```
## k8s_cluster/k8s_cluster.yml
2018-07-30 23:47:13 +08:00
2018-12-26 14:55:17 +08:00
```yaml
container_manager: crio
2018-07-30 23:47:13 +08:00
```
2018-12-26 14:55:17 +08:00
## all/crio.yml
Enable docker hub registry mirrors
```yaml
crio_registries:
- prefix: docker.io
insecure: false
blocked: false
location: registry-1.docker.io
unqualified: false
mirrors:
- location: 192.168.100.100:5000
insecure: true
- location: mirror.gcr.io
insecure: false
```
2018-12-26 14:55:17 +08:00
[CRI-O]: https://cri-o.io/
2024-01-16 12:23:09 +08:00
The following is a method to enable insecure registries.
```yaml
crio_insecure_registries:
- 10.0.0.2:5000
```
And you can config authentication for these registries after `crio_insecure_registries`.
```yaml
crio_registry_auth:
- registry: 10.0.0.2:5000
username: user
password: pass
```
## Note about user namespaces
CRI-O has support for user namespaces. This feature is optional and can be enabled by setting the following two variables.
```yaml
crio_runtimes:
- name: runc
path: /usr/bin/runc
type: oci
root: /run/runc
allowed_annotations:
- "io.kubernetes.cri-o.userns-mode"
crio_remap_enable: true
```
The `allowed_annotations` configures `crio.conf` accordingly.
The `crio_remap_enable` configures the `/etc/subuid` and `/etc/subgid` files to add an entry for the **containers** user.
By default, 16M uids and gids are reserved for user namespaces (256 pods * 65536 uids/gids) at the end of the uid/gid space.
## Optional : NRI
[Node Resource Interface](https://github.com/containerd/nri) (NRI) is disabled by default for the CRI-O. If you
are using CRI-O version v1.26.0 or above, then you can enable it with the
following configuration:
```yaml
nri_enabled: true
```