HowTo¶
How to Use¶
1 - Create an Image
resource:
apiVersion: kimup.cloudavenue.io/v1alpha1
kind: Image
metadata:
labels:
app.kubernetes.io/name: kube-image-updater
app.kubernetes.io/managed-by: kustomize
name: demo
namespace: default
spec:
image: traefik/whoami
baseTag: v1.9.0
triggers:
- type: crontab
value: "00 00 */12 * * *"
rules:
- name: Automatic update semver minor
type: semver-minor
actions:
- type: apply
In this example the image traefik/whoami
will be updated every 12 hours with the latest minor version.
2 - Apply the Image
resource:
kubectl apply -f image.yaml
3 - Check the Image TAG:
kubectl get image demo
NAME IMAGE TAG LAST-RESULT LAST-SYNC
demo traefik/whoami
But you can force the update by running the following command:
kubectl annotate image demo kimup.cloudavenue.io/action=refresh
The Image TAG is now updated:
kubectl get image demo
NAME IMAGE TAG LAST-RESULT LAST-SYNC
demo traefik/whoami v1.10.0 Success 15s
4 - Make a deployment with the image:
apiVersion: apps/v1
kind: Deployment
metadata:
name: whoami
namespace: default
spec:
replicas: 1
selector:
matchLabels:
app: whoami
template:
metadata:
annotations:
kimup.cloudavenue.io/enabled: "true"
labels:
app: whoami
spec:
containers:
- name: whoami
image: traefik/whoami
5 - Apply the deployment:
kubectl apply -f deployment.yaml
Now the deployment is running with the image traefik/whoami:v1.10.0
define by your rules in the CRD Image
.