616 lines
20 KiB
YAML
616 lines
20 KiB
YAML
global:
|
|
# -- Set an override for the prefix of the fullname
|
|
nameOverride:
|
|
# -- Set the entire name definition
|
|
fullnameOverride:
|
|
|
|
controller:
|
|
# -- enable the controller.
|
|
enabled: true
|
|
# -- Set the controller type.
|
|
# Valid options are deployment, daemonset or statefulset
|
|
type: deployment
|
|
# -- Set additional annotations on the deployment/statefulset/daemonset
|
|
annotationsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
# -- Set annotations on the deployment/statefulset/daemonset
|
|
annotations: {}
|
|
# -- Set additional labels on the deployment/statefulset/daemonset
|
|
labelsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
# -- Set labels on the deployment/statefulset/daemonset
|
|
labels: {}
|
|
# -- Number of desired pods
|
|
replicas: 1
|
|
# -- Set the controller upgrade strategy
|
|
# For Deployments, valid values are Recreate (default) and RollingUpdate.
|
|
# For StatefulSets, valid values are OnDelete and RollingUpdate (default).
|
|
# DaemonSets ignore this.
|
|
strategy:
|
|
rollingUpdate:
|
|
# -- Set deployment RollingUpdate max unavailable
|
|
unavailable:
|
|
# -- Set deployment RollingUpdate max surge
|
|
surge:
|
|
# -- Set statefulset RollingUpdate partition
|
|
partition:
|
|
# -- ReplicaSet revision history limit
|
|
revisionHistoryLimit: 3
|
|
|
|
image:
|
|
# -- image repository
|
|
repository:
|
|
# -- image tag
|
|
tag:
|
|
# -- image pull policy
|
|
pullPolicy:
|
|
|
|
# -- Override the command(s) for the default container
|
|
command: []
|
|
# -- Override the args for the default container
|
|
args: []
|
|
|
|
# -- Set additional annotations on the pod
|
|
podAnnotationsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
|
|
#
|
|
# -- Set annotations on the pod
|
|
podAnnotations: {}
|
|
|
|
# -- Set additional labels on the pod
|
|
podLabelsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
|
|
# -- Set labels on the pod
|
|
podLabels: {}
|
|
|
|
# -- Add a Horizontal Pod Autoscaler
|
|
# @default -- <disabled>
|
|
autoscaling:
|
|
enabled: false
|
|
target: # deploymentname
|
|
minReplicas: # 1
|
|
maxReplicas: # 100
|
|
targetCPUUtilizationPercentage: # 80
|
|
targetMemoryUtilizationPercentage: # 80
|
|
|
|
# -- Create serviceaccount
|
|
# @default -- See below
|
|
serviceAccount:
|
|
# -- Specifies whether a service account should be created
|
|
create: false
|
|
|
|
# -- Annotations to add to the service account
|
|
annotations: {}
|
|
|
|
# -- The name of the service account to use.
|
|
# If not set and create is true, a name is generated using the fullname template
|
|
name: ""
|
|
|
|
# -- Create a ClusterRole and ClusterRoleBinding
|
|
# @default -- See below
|
|
rbac:
|
|
# -- Enables or disables the ClusterRole and ClusterRoleBinding
|
|
enabled: false
|
|
|
|
# -- Set Annotations on the ClusterRole
|
|
clusterRoleLabels: {}
|
|
|
|
# -- Set labels on the ClusterRole
|
|
clusterRoleAnnotations: {}
|
|
|
|
# -- Set Annotations on the ClusterRoleBinding
|
|
|
|
clusterRoleBindingLabels: {}
|
|
|
|
# -- Set labels on the ClusterRoleBinding
|
|
clusterRoleBindingAnnotations: {}
|
|
|
|
# -- Set Rules on the ClusterRole
|
|
rules: {}
|
|
|
|
# -- Add subjects to the ClusterRoleBinding.
|
|
# includes the above created serviceaccount
|
|
subjects: {}
|
|
|
|
# -- Configure networkPolicy for the chart here.
|
|
# @default -- See below
|
|
networkPolicy:
|
|
# -- Enables or disables the networkPolicy
|
|
enabled: false
|
|
|
|
# customizes the podSelector (defaults to the helm-chart selector-labels
|
|
# podSelector:
|
|
|
|
# -- add or remove Policy types
|
|
policyTypes: []
|
|
|
|
# -- add or remove egress policies
|
|
egress: []
|
|
|
|
# -- add or remove egress policies
|
|
ingress: []
|
|
|
|
# -- Use this to populate a secret with the values you specify.
|
|
# Be aware that these values are not encrypted by default, and could therefore visible
|
|
# to anybody with access to the values.yaml file.
|
|
secret: {}
|
|
# PASSWORD: my-password
|
|
|
|
# -- Main environment variables. Template enabled.
|
|
# Syntax options:
|
|
# A) TZ: UTC
|
|
# B) PASSWD: '{{ .Release.Name }}'
|
|
# C) PASSWD:
|
|
# envFrom:
|
|
# ...
|
|
env: {}
|
|
## Variables with values set from templates, example
|
|
## With a release name of: demo, the example env value will be: demo-admin
|
|
envTpl: {}
|
|
# TEMPLATE_VALUE: "{{ .Release.Name }}-admin"
|
|
|
|
## Variables with values from (for example) the Downward API
|
|
## See https://kubernetes.io/docs/tasks/inject-data-application/environment-variable-expose-pod-information/
|
|
envValueFrom: {}
|
|
# NODE_NAME:
|
|
# fieldRef:
|
|
# fieldPath: spec.nodeName
|
|
|
|
envFrom: []
|
|
# - configMapRef:
|
|
# name: config-map-name
|
|
# - secretRef:
|
|
# name: secret-name
|
|
# -- Custom priority class for different treatment by the scheduler
|
|
priorityClassName: # system-node-critical
|
|
|
|
# -- Allows specifying a custom scheduler name
|
|
schedulerName: # awkward-dangerous-scheduler
|
|
|
|
# -- Allows specifying explicit hostname setting
|
|
hostname:
|
|
|
|
# -- When using hostNetwork make sure you set dnsPolicy to `ClusterFirstWithHostNet`
|
|
hostNetwork: false
|
|
|
|
# -- Defaults to "ClusterFirst" if hostNetwork is false and "ClusterFirstWithHostNet" if hostNetwork is true.
|
|
dnsPolicy: # ClusterFirst
|
|
|
|
# -- Optional DNS settings, configuring the ndots option may resolve nslookup issues on some Kubernetes setups.
|
|
dnsConfig: {}
|
|
# options:
|
|
# - name: ndots
|
|
# value: "1"
|
|
|
|
# -- Enable/disable the generation of environment variables for services.
|
|
# [[ref]](https://kubernetes.io/docs/concepts/services-networking/connect-applications-service/#accessing-the-service)
|
|
enableServiceLinks: false
|
|
|
|
# -- Configure the Security Context for the Pod
|
|
podSecurityContext: {}
|
|
|
|
# -- Configure the Security Context for the main container
|
|
securityContext:
|
|
privileged: false
|
|
readOnlyRootFilesystem: false
|
|
allowPrivilegeEscalation: true
|
|
|
|
|
|
# -- Configure the lifecycle for the main container
|
|
lifecycle: {}
|
|
|
|
# -- Specify any initContainers here. Yaml will be passed in to the Pod as-is.
|
|
initContainers: []
|
|
|
|
# -- Specify any additional containers here. Yaml will be passed in to the Pod as-is.
|
|
additionalContainers: []
|
|
|
|
# -- Probe configuration
|
|
# -- [[ref]](https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/)
|
|
# @default -- See below
|
|
probes:
|
|
# -- Liveness probe configuration
|
|
# @default -- See below
|
|
liveness:
|
|
# -- Enable the liveness probe
|
|
enabled: true
|
|
# -- Set this to `true` if you wish to specify your own livenessProbe
|
|
custom: false
|
|
# -- sets the probe type when not using a custom probe
|
|
# @default -- "TCP"
|
|
type: TCP
|
|
# -- If a HTTP probe is used (default for HTTP/HTTPS services) this path is used
|
|
# @default -- "/"
|
|
path: "/"
|
|
# -- The spec field contains the values for the default livenessProbe.
|
|
# If you selected `custom: true`, this field holds the definition of the livenessProbe.
|
|
# @default -- See below
|
|
spec:
|
|
initialDelaySeconds: 2
|
|
periodSeconds: 10
|
|
timeoutSeconds: 2
|
|
failureThreshold: 5
|
|
|
|
# -- Redainess probe configuration
|
|
# @default -- See below
|
|
readiness:
|
|
# -- Enable the readiness probe
|
|
enabled: true
|
|
# -- Set this to `true` if you wish to specify your own readinessProbe
|
|
custom: false
|
|
# -- sets the probe type when not using a custom probe
|
|
# @default -- "TCP"
|
|
type: TCP
|
|
# -- If a HTTP probe is used (default for HTTP/HTTPS services) this path is used
|
|
# @default -- "/"
|
|
path: "/"
|
|
# -- The spec field contains the values for the default readinessProbe.
|
|
# If you selected `custom: true`, this field holds the definition of the readinessProbe.
|
|
# @default -- See below
|
|
spec:
|
|
initialDelaySeconds: 2
|
|
periodSeconds: 10
|
|
timeoutSeconds: 2
|
|
failureThreshold: 5
|
|
|
|
# -- Startup probe configuration
|
|
# @default -- See below
|
|
startup:
|
|
# -- Enable the startup probe
|
|
enabled: true
|
|
# -- Set this to `true` if you wish to specify your own startupProbe
|
|
custom: false
|
|
# -- sets the probe type when not using a custom probe
|
|
# @default -- "TCP"
|
|
type: TCP
|
|
# -- If a HTTP probe is used (default for HTTP/HTTPS services) this path is used
|
|
# @default -- "/"
|
|
path: "/"
|
|
# -- The spec field contains the values for the default startupProbe.
|
|
# If you selected `custom: true`, this field holds the definition of the startupProbe.
|
|
# @default -- See below
|
|
spec:
|
|
initialDelaySeconds: 3
|
|
timeoutSeconds: 2
|
|
## This means it has a maximum of 5*30=150 seconds to start up before it fails
|
|
periodSeconds: 5
|
|
failureThreshold: 60
|
|
|
|
termination:
|
|
# -- Configure the path at which the file to which the main container's termination message will be written.
|
|
# -- [[ref](https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#lifecycle-1)]
|
|
messagePath:
|
|
|
|
# -- Indicate how the main container's termination message should be populated.
|
|
# Valid options are `File` and `FallbackToLogsOnError`.
|
|
# -- [[ref](https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#lifecycle-1)]
|
|
messagePolicy:
|
|
|
|
# -- Duration in seconds the pod needs to terminate gracefully
|
|
# -- [[ref](https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#lifecycle)]
|
|
gracePeriodSeconds: 10
|
|
|
|
|
|
# -- Configure additional services for the chart here.
|
|
# @default -- See below
|
|
serviceList: []
|
|
|
|
# -- Configure the services for the chart here.
|
|
# Additional services can be added by adding a dictionary key similar to the 'main' service.
|
|
# @default -- See below
|
|
service:
|
|
main:
|
|
# -- Enables or disables the service
|
|
enabled: true
|
|
|
|
# -- Make this the primary service (used in probes, notes, etc...).
|
|
# If there is more than 1 service, make sure that only 1 service is marked as primary.
|
|
primary: true
|
|
|
|
# -- Override the name suffix that is used for this service
|
|
nameOverride:
|
|
|
|
# -- Set the service type
|
|
type: ClusterIP
|
|
annotationsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
# -- Provide additional annotations which may be required.
|
|
annotations: {}
|
|
|
|
labelsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
# -- Set labels on the deployment/statefulset/daemonset
|
|
# -- Provide additional labels which may be required.
|
|
labels: {}
|
|
|
|
# -- Configure additional Service port information here.
|
|
# @default -- See below
|
|
portsList: []
|
|
|
|
# -- Configure the Service port information here.
|
|
# Additional ports can be added by adding a dictionary key similar to the 'http' service.
|
|
# @default -- See below
|
|
ports:
|
|
main:
|
|
# -- Enables or disables the port
|
|
enabled: true
|
|
|
|
# -- Make this the primary port (used in probes, notes, etc...)
|
|
# If there is more than 1 service, make sure that only 1 port is marked as primary.
|
|
primary: true
|
|
|
|
# -- The port number
|
|
port:
|
|
|
|
# -- Port protocol.
|
|
# Support values are `HTTP`, `HTTPS`, `TCP` and `UDP`.
|
|
# HTTPS and HTTPS spawn a TCP service and get used for internal URL and name generation
|
|
protocol: HTTP
|
|
|
|
# -- Specify a service targetPort if you wish to differ the service port from the application port.
|
|
# If `targetPort` is specified, this port number is used in the container definition instead of
|
|
# the `port` value. Therefore named ports are not supported for this field.
|
|
targetPort:
|
|
|
|
# -- Specify the nodePort value for the LoadBalancer and NodePort service types.
|
|
# [[ref]](https://kubernetes.io/docs/concepts/services-networking/service/#type-nodeport)
|
|
nodePort:
|
|
|
|
|
|
# -- Configure ingressList for the chart here.
|
|
# Additional items can be added by adding a items similar to ingress
|
|
# @default -- []
|
|
ingressList: []
|
|
|
|
# -- Configure the ingresses for the chart here.
|
|
# Additional ingresses can be added by adding a dictionary key similar to the 'main' ingress.
|
|
# @default -- See below
|
|
ingress:
|
|
main:
|
|
# -- Enables or disables the ingress
|
|
enabled: false
|
|
|
|
# -- Make this the primary ingress (used in probes, notes, etc...).
|
|
# If there is more than 1 ingress, make sure that only 1 ingress is marked as primary.
|
|
primary: true
|
|
|
|
# -- Override the name suffix that is used for this ingress.
|
|
nameOverride:
|
|
|
|
# -- List of middlewares in the traefikmiddlewares k8s namespace to add automatically
|
|
# Creates an annotation with the middlewares and appends k8s and traefik namespaces to the middleware names
|
|
# Primarily used for TrueNAS SCALE to add additional (seperate) middlewares without exposing them to the end-user
|
|
fixedMiddlewares:
|
|
- chain-basic
|
|
|
|
# -- Additional List of middlewares in the traefikmiddlewares k8s namespace to add automatically
|
|
# Creates an annotation with the middlewares and appends k8s and traefik namespaces to the middleware names
|
|
middlewares: []
|
|
annotationsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
# -- Provide additional annotations which may be required.
|
|
annotations: {}
|
|
# kubernetes.io/ingress.class: nginx
|
|
# kubernetes.io/tls-acme: "true"
|
|
|
|
labelsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
# -- Set labels on the deployment/statefulset/daemonset
|
|
# -- Provide additional labels which may be required.
|
|
# -- Provide additional labels which may be required.
|
|
labels: {}
|
|
|
|
# -- Set the ingressClass that is used for this ingress.
|
|
# Requires Kubernetes >=1.19
|
|
ingressClassName: # "nginx"
|
|
|
|
## Configure the hosts for the ingress
|
|
hosts:
|
|
- # -- Host address. Helm template can be passed.
|
|
host: chart-example.local
|
|
## Configure the paths for the host
|
|
paths:
|
|
- # -- Path. Helm template can be passed.
|
|
path: /
|
|
# -- Ignored if not kubeVersion >= 1.14-0
|
|
pathType: Prefix
|
|
service:
|
|
# -- Overrides the service name reference for this path
|
|
name:
|
|
# -- Overrides the service port reference for this path
|
|
port:
|
|
|
|
# -- Configure TLS for the ingress. Both secretName and hosts can process a Helm template.
|
|
tls: []
|
|
# - secretName: chart-example-tls
|
|
# -- Create a secret from a GUI selected TrueNAS SCALE certificate
|
|
# scaleCert: true
|
|
# hosts:
|
|
# - chart-example.local
|
|
|
|
# -- Configure persistenceList for the chart here.
|
|
# Used to create an additional GUI element in SCALE for mounting USB devices
|
|
# Additional items can be added by adding a items similar to persistence
|
|
# @default -- []
|
|
deviceList: []
|
|
|
|
# -- Configure persistenceList for the chart here.
|
|
# Additional items can be added by adding a items similar to persistence
|
|
# @default -- []
|
|
persistenceList: []
|
|
|
|
# -- Configure persistence for the chart here.
|
|
# Additional items can be added by adding a dictionary key similar to the 'config' key.
|
|
# @default -- See below
|
|
persistence:
|
|
# -- Default persistence for configuration files.
|
|
# @default -- See below
|
|
config:
|
|
# -- Enables or disables the persistence item
|
|
enabled: false
|
|
annotationsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
# -- Add annotations to PVC object
|
|
annotations: {}
|
|
|
|
labelsList: []
|
|
# - name: somename
|
|
# value: somevalue
|
|
# -- Set labels on the deployment/statefulset/daemonset
|
|
# -- Provide additional labels which may be required.
|
|
# -- Add labels to PVC object
|
|
labels: {}
|
|
|
|
# -- Sets the persistence type
|
|
# Valid options are pvc, emptyDir, hostPath or custom
|
|
type: pvc
|
|
|
|
# -- force the complete PVC name
|
|
# Will not add any prefix or suffix
|
|
forceName: ""
|
|
|
|
# -- Where to mount the volume in the main container.
|
|
# Defaults to `/<name_of_the_volume>`,
|
|
# setting to '-' creates the volume but disables the volumeMount.
|
|
mountPath: # /config
|
|
# -- Specify if the volume should be mounted read-only.
|
|
readOnly: false
|
|
# -- Override the name suffix that is used for this volume.
|
|
nameOverride:
|
|
|
|
# -- Storage Class for the config volume.
|
|
# If set to `-`, dynamic provisioning is disabled.
|
|
# If set to `SCALE-ZFS`, the default provisioner for TrueNAS SCALE is used.
|
|
# If set to something else, the given storageClass is used.
|
|
# If undefined (the default) or set to null, no storageClassName spec is set, choosing the default provisioner.
|
|
storageClass: # "-"
|
|
|
|
# -- If you want to reuse an existing claim, the name of the existing PVC can be passed here.
|
|
existingClaim: # your-claim
|
|
|
|
# -- Used in conjunction with `existingClaim`. Specifies a sub-path inside the referenced volume instead of its root
|
|
subPath: # some-subpath
|
|
|
|
# mountPropagation: {}
|
|
|
|
# -- AccessMode for the persistent volume.
|
|
# Make sure to select an access mode that is supported by your storage provider!
|
|
# [[ref]](https://kubernetes.io/docs/concepts/storage/persistent-volumes/#access-modes)
|
|
accessMode: ReadWriteOnce
|
|
|
|
# -- The amount of storage that is requested for the persistent volume.
|
|
size: 1Gi
|
|
|
|
# - Set to true to retain the PVC upon `helm uninstall`
|
|
retain: false
|
|
|
|
# -- Create an emptyDir volume to share between all containers
|
|
# [[ref]]https://kubernetes.io/docs/concepts/storage/volumes/#emptydir)
|
|
# @default -- See below
|
|
shared:
|
|
enabled: false
|
|
type: emptyDir
|
|
mountPath: /shared
|
|
|
|
# -- Set the medium to "Memory" to mount a tmpfs (RAM-backed filesystem) instead
|
|
# of the storage medium that backs the node.
|
|
medium: # Memory
|
|
|
|
# -- If the `SizeMemoryBackedVolumes` feature gate is enabled, you can
|
|
# specify a size for memory backed volumes.
|
|
sizeLimit: # 1Gi
|
|
|
|
# -- Example of a hostPath mount
|
|
# [[ref]]https://kubernetes.io/docs/concepts/storage/volumes/#hostpath)
|
|
# @default -- See below
|
|
host-dev:
|
|
enabled: false
|
|
type: hostPath
|
|
# -- Which path on the host should be mounted.
|
|
hostPath: /dev
|
|
# -- Where to mount the path in the main container.
|
|
# Defaults to the value of `hostPath`
|
|
mountPath: # /myDev
|
|
# -- Specifying a hostPathType adds a check before trying to mount the path.
|
|
# See Kubernetes documentation for options.
|
|
hostPathType: ""
|
|
# -- Specify if the path should be mounted read-only.
|
|
readOnly: true
|
|
|
|
# -- Example of a custom mount
|
|
# @default -- See below
|
|
custom-mount:
|
|
enabled: false
|
|
type: custom
|
|
# -- Where to mount the volume in the main container.
|
|
# Defaults to `/<name_of_the_volume>`,
|
|
# setting to '-' creates the volume but disables the volumeMount.
|
|
mountPath: # /custom-mount
|
|
# -- Specify if the volume should be mounted read-only.
|
|
readOnly: false
|
|
# -- Define the custom Volume spec here
|
|
# [[ref]](https://kubernetes.io/docs/concepts/storage/volumes/)
|
|
volumeSpec: {}
|
|
# configMap:
|
|
# defaultMode: 420
|
|
# name: my-settings
|
|
|
|
# -- Used in conjunction with `controller.type: statefulset` to create individual disks for each instance.
|
|
volumeClaimTemplates: []
|
|
# data:
|
|
# mountPath: /data
|
|
# accessMode: "ReadWriteOnce"
|
|
# size: 1Gi
|
|
|
|
## Or use a list
|
|
# - name: backup
|
|
# mountPath: /backup
|
|
# subPath: theSubPath
|
|
# accessMode: "ReadWriteOnce"
|
|
# size: 2Gi
|
|
# storageClass: cheap-storage-class
|
|
|
|
# -- Node selection constraint
|
|
# [[ref]](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/#nodeselector)
|
|
nodeSelector: {}
|
|
|
|
# -- Defines affinity constraint rules.
|
|
# [[ref]](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/#affinity-and-anti-affinity)
|
|
affinity: {}
|
|
|
|
# -- Specify taint tolerations
|
|
# [[ref]](https://kubernetes.io/docs/concepts/scheduling-eviction/taint-and-toleration/)
|
|
tolerations: []
|
|
|
|
# -- Use hostAliases to add custom entries to /etc/hosts - mapping IP addresses to hostnames.
|
|
# [[ref]](https://kubernetes.io/docs/concepts/services-networking/add-entries-to-pod-etc-hosts-with-host-aliases/)
|
|
hostAliases: []
|
|
# - ip: "192.168.1.100"
|
|
# hostnames:
|
|
# - "example.com"
|
|
# - "www.example.com"
|
|
|
|
# -- Set the resource requests / limits for the main container.
|
|
resources: {}
|
|
## We usually recommend not to specify default resources and to leave this as a conscious
|
|
## choice for the user. This also increases chances charts run on environments with little
|
|
## resources, such as Minikube. If you do want to specify resources, uncomment the following
|
|
## lines, adjust them as necessary, and remove the curly braces after 'resources:'.
|
|
# limits:
|
|
# cpu: 100m
|
|
# memory: 128Mi
|
|
# requests:
|
|
# cpu: 100m
|
|
# memory: 128Mi
|