Skip to content

Flannel init container to install a CNI config and CNI plugins

License

Notifications You must be signed in to change notification settings

poseidon/flannel-cni

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

44 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

flannel-cni

Quay Workflow Sponsors Mastodon

flannel-cni provides a container image that installs a CNI config and CNI binaries on Kubernetes nodes. Ideal for container-optimized OSes like Fedora CoreOS and Flatcar Linux.

  • Install CNI_NETWORK_CONFIG to /etc/cni/net.d
  • Install CNI plugin binaries to /opt/cni/bin

Usage

Add flannel-cni as an init container to a flannel DaemonSet. See Typhoon for an active example.

initContainers:
  - name: install-cni
    image: quay.io/poseidon/flannel-cni:v0.4.2
    command: ["/install-cni.sh"]
    env:
      - name: CNI_NETWORK_CONFIG
        valueFrom:
          configMapKeyRef:
            name: flannel-config
            key: cni-conf.json
    volumeMounts:
      - name: cni-bin-dir
        mountPath: /host/opt/cni/bin/
      - name: cni-conf-dir
        mountPath: /host/etc/cni/net.d
containers:
  ...
volumes:
  ...
  # Used by install-cni
  - name: cni-bin-dir
    hostPath:
      path: /opt/cni/bin
  - name: cni-conf-dir
    hostPath:
      path: /etc/kubernetes/cni/net.d
apiVersion: v1
kind: ConfigMap
metadata:
  name: flannel-config
  namespace: kube-system
  labels:
    tier: node
    k8s-app: flannel
data:
  cni-conf.json: |
    {
      "name": "cbr0",
      "cniVersion": "0.3.1",
      "plugins": [
        {
          "type": "flannel",
          "delegate": {
            "hairpinMode": true,
            "isDefaultGateway": true
          }
        },
        {
          "type": "portmap",
          "capabilities": {
            "portMappings": true
          }
        }
      ]
    }

Publish

Container images are published according to Typhoon policy.