Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Daily Reboot Cronjob (K8s) #206

Merged
merged 22 commits into from
Jan 31, 2024
Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
40 changes: 39 additions & 1 deletion charts/palworld/templates/configmaps.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -48,4 +48,42 @@ data:
{{- with .Values.server.config.world_parameters }}
{{- toYaml . | nindent 2 }}
{{- end }}
{{ end }}
{{ if .Values.server.config.daily_reboot.enable }}
restart-deployment.sh: |
#!/bin/bash
cont=$(kubectl -n {{ .Values.namespace }} get pods -o=jsonpath='{.items[?(@.metadata.labels.app.kubernetes.io/name=="{{ .Release.Name }}-server")].metadata.name}')
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Saving_Server_Data..."
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli save
sleep 30
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Backing_up_Server_Data..."
kubectl exec -n {{ .Values.namespace }} -i pod/$cont backup
sleep 30
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Backup_Complete!_Rebooting_in_30_seconds..."
sleep 15
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_15_seconds..."
sleep 5
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_10_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_9_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_8_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_7_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_6_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_5_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_4_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_3_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_2_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Broadcast Rebooting_in_1_seconds..."
sleep 1
kubectl exec -n {{ .Values.namespace }} -i pod/$cont rcon-cli "Shutdown 1"
sleep 30
kubectl -n {{ .Values.namespace }} rollout restart deployment/{{ .Release.Name }}-server
{{ end }}
{{ end }}
37 changes: 37 additions & 0 deletions charts/palworld/templates/cronjob.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
{{ if .Values.server.config.daily_reboot.enable }}
apiVersion: batch/v1
kind: CronJob
metadata:
name: "{{ .Values.server.config.daily_reboot.serviceAccount }}"
namespace: {{ .Values.namespace }}
spec:
concurrencyPolicy: Forbid
schedule: "{{ .Values.server.config.daily_reboot.time }}"
jobTemplate:
spec:
backoffLimit: 1
activeDeadlineSeconds: 600
template:
spec:
serviceAccountName: "{{ .Values.server.config.daily_reboot.serviceAccount }}"
restartPolicy: Never
containers:
- name: kubectl
image: bitnami/kubectl
command:
- /bin/sh
- -c
- /restart-script/restart-deployment.sh
volumeMounts:
- name: restart-script
mountPath: "/restart-script"
readOnly: true
volumes:
- name: restart-script
configMap:
name: "{{ .Release.Name }}-env-config"
defaultMode: 0777
items:
- key: "restart-deployment.sh"
path: "restart-deployment.sh"
{{ end }}
14 changes: 14 additions & 0 deletions charts/palworld/templates/role.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{{ if .Values.server.config.daily_reboot.enable }}
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: "{{ .Values.server.config.daily_reboot.role }}"
namespace: {{ .Values.namespace }}
rules:
- apiGroups: ["apps", "extensions"]
resources: ["deployments", "pods"]
verbs: ["get", "patch", "list", "watch"]
- apiGroups: [""]
resources: ["pods/exec", "pods"]
verbs: ["get", "list", "create"]
{{ end }}
15 changes: 15 additions & 0 deletions charts/palworld/templates/rolebinding.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
{{ if .Values.server.config.daily_reboot.enable }}
apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
name: "{{ .Values.server.config.daily_reboot.role }}-binding"
namespace: {{ .Values.namespace }}
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: Role
name: "{{ .Values.server.config.daily_reboot.role }}"
subjects:
- kind: ServiceAccount
name: {{ .Values.server.config.daily_reboot.serviceAccount }}
namespace: {{ .Values.namespace }}
{{ end }}
7 changes: 7 additions & 0 deletions charts/palworld/templates/serviceaccount.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{{ if .Values.server.config.daily_reboot.enable }}
apiVersion: v1
kind: ServiceAccount
metadata:
name: {{ .Values.server.config.daily_reboot.serviceAccount }}
namespace: {{ .Values.namespace }}
{{ end }}
11 changes: 11 additions & 0 deletions charts/palworld/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -151,6 +151,17 @@ server:
# -- (string) Update/Install the server when the container starts.
# THIS HAS TO BE ENABLED THE FIRST TIME YOU RUN THE CONTAINER
update_on_boot: true
daily_reboot:
# -- (bool) Enable daily reboot.
# Disabled by default
enable: false
# -- (string) The time (UTC) the server will perform the reboot.
# By default, this schedules the restart at 9:30am UTC. Please note, this is using cron syntax.
time: "30 9 * * *"
# -- (string) The name of the role performing the daily reboot.
role: "daily-reboot"
# -- (string) The name of the Service Account used to perform the reboot.
serviceAccount: "daily-reboot"
# -- (object) Configures the game world settings.
# The key:values here should represent in game accepted values.
# Wrap all values with quotes here to avoid validation issues.
Expand Down
42 changes: 42 additions & 0 deletions k8s/cronjob-reboot/cm.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
apiVersion: v1
kind: ConfigMap
metadata:
name: restart-deployment-configmap
data:
restart-deployment.sh: |
#!/bin/bash
cont=$(kubectl -n palworld get pods -o=jsonpath='{.items[?(@.metadata.labels.app=="palworld-server")].metadata.name}')
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Saving_Server_Data..."
kubectl exec -n palworld -i pod/$cont rcon-cli save
sleep 30
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Backing_up_Server_Data..."
kubectl exec -n palworld -i pod/$cont backup
sleep 30
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Backup_Complete!_Rebooting_in_30_seconds..."
sleep 15
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_15_seconds..."
sleep 5
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_10_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_9_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_8_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_7_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_6_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_5_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_4_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_3_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_2_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Rebooting_in_1_seconds..."
sleep 1
kubectl exec -n palworld -i pod/$cont rcon-cli "Shutdown 1"
sleep 30
kubectl -n palworld rollout restart deployment/palworld-server
NotaSF marked this conversation as resolved.
Show resolved Hide resolved

34 changes: 34 additions & 0 deletions k8s/cronjob-reboot/cronjob.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
apiVersion: batch/v1
kind: CronJob
metadata:
name: restart-deployment
spec:
concurrencyPolicy: Forbid
schedule: '30 9 * * *'
jobTemplate:
spec:
backoffLimit: 1
activeDeadlineSeconds: 600
template:
spec:
serviceAccountName: restart-deploy
restartPolicy: Never
containers:
- name: kubectl
image: bitnami/kubectl
command:
- /bin/sh
- -c
- /restart-script/restart-deployment.sh
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

do you even need a CM with the shell script? what about inline?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That is a good point, I'm not sure actually. Pardon my ignorance, I'm a little new to this - when you say inline, do you mean taking the contents of the shell script and making it a one-liner instead of using a CM and mounting it as a volume?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi sorry for the confusion. What i mean is instead of having a configmap mounted you could also put that script in that command as an arg like

command:
  - /bin/sh
  - -c
args:
  - |
    cont=$(kubectl -n palworld get pods -o=jsonpath='{.items[?(@.metadata.labels.app=="palworld-server")].metadata.name}')
    kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Saving_Server_Data..."
    kubectl exec -n palworld -i pod/$cont rcon-cli save
    sleep 30
    kubectl exec -n palworld -i pod/$cont rcon-cli "Broadcast Backing_up_Server_Data..."
    kubectl exec -n palworld -i pod/$cont backup
 ...

volumeMounts:
- name: restart-script
mountPath: "/restart-script"
readOnly: true
volumes:
- name: restart-script
configMap:
name: restart-deployment-configmap
defaultMode: 0777
items:
- key: "restart-deployment.sh"
path: "restart-deployment.sh"
11 changes: 11 additions & 0 deletions k8s/cronjob-reboot/role.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: restart-deployment
rules:
- apiGroups: ["apps", "extensions"]
resources: ["deployments", "pods"]
verbs: ["get", "patch", "list", "watch"]
- apiGroups: [""]
resources: ["pods/exec", "pods"]
verbs: ["get", "list", "create"]
12 changes: 12 additions & 0 deletions k8s/cronjob-reboot/rolebinding.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
name: restart-deployment
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: Role
name: restart-deployment
subjects:
- kind: ServiceAccount
name: restart-deploy
namespace: palworld
4 changes: 4 additions & 0 deletions k8s/cronjob-reboot/serviceaccount.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
apiVersion: v1
kind: ServiceAccount
metadata:
name: restart-deploy