/restart-object

restart-object can restart Kubernetes' Deployment / DaemonSet / StatefulSet.

Primary LanguageGoApache License 2.0Apache-2.0

restart-object

CircleCI Go Report Card

About restart-object

restart-object can restart Kubernetes' Deployment / DaemonSet / StatefulSet. It is intended to be run as a Kubernetes Job or CronJob and to restart Deployment. Please add "imagePullPolicy: Always" to Pod.

Assumed to be used to restart the Pod running in the development environment with the latest image tags.

Note: Do not use the latest image tag in a production environment.

restart-object was created referring to the kubectl rollout restart command. Realize restart by giving annotation kubectl.kubernetes.io/restartedAt for podTemplateSpec.

Why restart Pod with CronJob ?

I have a motivation to periodically Deploy latest image the development environment application. In GitOps, Git is a single source of truth. So to deploy a new image you have to rewrite the manifests image tag and commit it to Git. But the logic to monitor the image registry and commit it to Git is complicated. I developed restart-object as a mechanism to realize this task easily.

Build and Run

Build restart-object:

$ make build

and run restart-object:

$ ./dist/restart-object --tag latest --namespace nginx

For more information about available options run:

$ ./dist/restart-object --help
Restart Kubernetes Object

Usage:
  restart-object [flags]
  restart-object [command]

Available Commands:
  help        Help about any command
  version     Show version

Flags:
      --disable strings    Disable objects names
      --disable-all        Disable all objects
      --enable strings     Enable objects names
      --enable-all         Enable all objects
  -h, --help               help for restart-object
      --in-cluster         Execute for in Kubernetes cluster
      --namespace string   Namespace (default "default")
      --objects string     Restart objects (default "deployment")
      --tag string         Target to restart image tag name (default "latest")

Use "restart-object [command] --help" for more information about a command.

Running restart-object as a Job Inside of a Pod

restart-object can be run as a Job inside of a Pod.

Run the restart-object as a Job in a Pod:

$ kubectl apply -f ./examples/manifests/restart-object.yaml

Manifests examples

apiVersion: batch/v1
kind: Job
metadata:
  name: restart-object-job
spec:
  completions: 1
  parallelism: 1
  template:
    spec:
      serviceAccountName: restart-object
      containers:
        - name: restart-object-job
          image: daikurosawa/restart-object:v0.0.2
          command:
            - ./restart-object
            - --in-cluster=true
            - --tag=latest
      restartPolicy: Never
---
apiVersion: v1
kind: ServiceAccount
metadata:
  name: restart-object
  namespace: default
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: restart-object
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: restart-object
subjects:
  - kind: ServiceAccount
    name: restart-object
    namespace: default
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  name: restart-object
rules:
  - apiGroups: ["apps"]
    resources: ["deployments", "daemonsets"]
    verbs: ["list", "patch"]
  - apiGroups: ["extensions"]
    resources: ["deployments", "daemonsets"]
    verbs: ["list", "patch"]

TODO

  • Support StatefulSet restart
  • Add tests
  • Support server side apply