kubernetes/storage/fio-testing/k8s/gcs/gcs-testing.yaml (60 lines of code) (raw):
# Copyright 2024 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
apiVersion: batch/v1
kind: Job
metadata:
name: fio-test-gcs
labels:
app: fio-test
spec:
completions: 1
parallelism: 1
ttlSecondsAfterFinished: 120
template:
metadata:
annotations:
gke-gcsfuse/volumes: "true"
gke-gcsfuse/cpu-limit: "200m"
gke-gcsfuse/memory-limit: "256Mi"
gke-gcsfuse/ephemeral-storage-limit: "5Gi"
gke-gcsfuse/cpu-request: "50m"
gke-gcsfuse/memory-request: "64Mi"
gke-gcsfuse/ephemeral-storage-request: "200Mi"
labels:
app: fio-test-gcs
spec:
priorityClassName: default-priority
nodeSelector:
cloud.google.com/compute-class: spot-capacity
restartPolicy: Never
containers:
- name: fio
image: fio
resources:
limits:
cpu: "1"
memory: 4Gi
requests:
cpu: "1"
memory: 4Gi
env:
- name: MOUNT_PATH
value: "/data"
- name: POD_NAME
valueFrom:
fieldRef:
fieldPath: metadata.name
volumeMounts:
- name: gcs-fuse-csi-ephemeral
mountPath: /data
- name: fio-config
mountPath: /etc/fio
volumes:
- name: gcs-fuse-csi-ephemeral
csi:
driver: gcsfuse.csi.storage.gke.io
volumeAttributes:
bucketName: fsi-research-5-fio-dual
mountOptions: "implicit-dirs"
gcsfuseLoggingSeverity: warning
- name: fio-config
configMap:
name: fio-config-gcs