Skip to content

Latest commit

 

History

History
134 lines (115 loc) · 3.48 KB

File metadata and controls

134 lines (115 loc) · 3.48 KB

Cleanup VM Task

This task can execute a script, or a command in a Virtual Machine and stop/delete the VM afterwards. Best used together with tekton pipelines finally construct.

Parameters

  • vmName: Name of a VM to execute the action in.
  • vmNamespace: Namespace of a VM to execute the action in. (defaults to active namespace)
  • stop: Stops the VM after executing the commands when set to true.
  • delete: Deletes the VM after executing the commands when set to true.
  • timeout: Timeout for the command/script (includes potential VM start). The VM will be stopped or deleted accordingly once the timout expires. Should be in a 3h2m1s format.
  • secretName: Secret to use when connecting to a VM.
  • command: Command to execute in a VM.
  • args: Arguments of a command.
  • script: Script to execute in a VM.

Secret format

The secret is used for storing credentials and options used in VM authentication.

Specifying a type

The secret should be of one of the following types:

  • kubernetes.io/ssh-auth
  • Opaque: Secret data should include the following key.
    • type: One of: ssh.
SSH section

Following secret data keys are recognized for SSH connections:

  • user: User to log in as.
  • ssh-privatekey: Private key to use for authentication.
  • host-public-key: Public key of known host to connect to.
  • disable-strict-host-key-checking: host-public-key (authorized-key) does not have to be supplied when this value is set to true.
  • additional-ssh-options: Additional arguments to pass to the SSH command.

Please see secret examples.

Usage

Task run using resolver:

apiVersion: tekton.dev/v1
kind: TaskRun
metadata:
    generateName: cleanup-vm-taskrun-resolver-
spec:
    params:
    -   name: vmName
        value: vm-example
    -   name: secretName
        value: ssh-secret
    -   name: stop
        value: 'true'
    -   name: delete
        value: 'false'
    -   name: timeout
        value: 10m
    -   name: command
        value:
        - systemctl
    -   name: args
        value:
        - stop
        - postgresql
    taskRef:
        params:
        -   name: catalog
            value: kubevirt-tekton-tasks
        -   name: type
            value: artifact
        -   name: kind
            value: task
        -   name: name
            value: cleanup-vm
        -   name: version
            value: v0.23.0
        resolver: hub

Usage in different namespaces

You can use task to do actions in different namespace. To do that, tasks requires special permissions. Apply these RBAC objects and permissions and update accordingly task run object with correct serviceAccount:

apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
    name: cleanup-vm-task
rules:
-   apiGroups:
    - kubevirt.io
    resources:
    - virtualmachines
    - virtualmachineinstances
    verbs:
    - get
    - list
    - watch
    - delete
-   apiGroups:
    - subresources.kubevirt.io
    resources:
    - virtualmachines/start
    - virtualmachines/stop
    - virtualmachines/restart
    verbs:
    - update
---
apiVersion: v1
kind: ServiceAccount
metadata:
    name: cleanup-vm-task
---
apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
    name: cleanup-vm-task
roleRef:
    apiGroup: rbac.authorization.k8s.io
    kind: ClusterRole
    name: cleanup-vm-task
subjects:
-   kind: ServiceAccount
    name: cleanup-vm-task
---

Platforms

The Task can be run on linux/amd64 platform.