feat(charts): add Helm chart for gitks Git bare repository service
- Create Chart.yaml with application metadata and keywords - Add _helpers.tpl with name, fullname, labels, and DNS template functions - Generate ConfigMap with all gitks configuration environment variables - Implement StatefulSet with persistent volume claims for repository data - Create headless service for pod DNS and cluster communication - Add gRPC service for client connections and metrics service - Include HorizontalPodAutoscaler for dynamic scaling - Add PodDisruptionBudget to maintain cluster availability - Create ServiceAccount with proper security context - Add test connection pod using grpcurl for health checks - Generate NOTES.txt with installation instructions and quick start guide - Create .helmignore file to exclude common development files - Configure persistence, resource limits, and security settings - Add support for cluster mode with etcd service discovery
This commit is contained in:
@@ -0,0 +1,23 @@
|
||||
# Patterns to ignore when building packages.
|
||||
# This supports shell glob matching, relative path matching, and
|
||||
# negation (prefixed with !). Only one pattern per line.
|
||||
.DS_Store
|
||||
# Common VCS dirs
|
||||
.git/
|
||||
.gitignore
|
||||
.bzr/
|
||||
.bzrignore
|
||||
.hg/
|
||||
.hgignore
|
||||
.svn/
|
||||
# Common backup files
|
||||
*.swp
|
||||
*.bak
|
||||
*.tmp
|
||||
*.orig
|
||||
*~
|
||||
# Various IDEs
|
||||
.project
|
||||
.idea/
|
||||
*.tmproj
|
||||
.vscode/
|
||||
@@ -0,0 +1,11 @@
|
||||
apiVersion: v2
|
||||
name: gitks
|
||||
description: A gRPC-accessible Git bare repository operations service with cluster support
|
||||
type: application
|
||||
version: 0.1.0
|
||||
appVersion: "1.0.0"
|
||||
keywords:
|
||||
- git
|
||||
- grpc
|
||||
- bare-repository
|
||||
- cluster
|
||||
@@ -0,0 +1,49 @@
|
||||
Thank you for installing gitks {{ .Chart.AppVersion }}!
|
||||
|
||||
gitks is a gRPC-accessible Git bare repository operations service.
|
||||
|
||||
{{- if .Values.gitks.etcd.endpoints }}
|
||||
🚀 Cluster mode: ENABLED
|
||||
etcd endpoints: {{ .Values.gitks.etcd.endpoints }}
|
||||
Nodes will discover each other via etcd and elect a PRIMARY.
|
||||
{{- else }}
|
||||
⚠️ Cluster mode: DISABLED (gitks.etcd.endpoints is empty)
|
||||
Running in standalone mode — no automatic failover.
|
||||
{{- end }}
|
||||
|
||||
📦 StatefulSet: {{ include "gitks.fullname" . }}
|
||||
Replicas: {{ .Values.replicaCount }}
|
||||
Each pod mounts its own PVC for /data/repos.
|
||||
|
||||
🔌 Services:
|
||||
gRPC: {{ include "gitks.fullname" . }}:{{ .Values.service.port }}
|
||||
Metrics: {{ include "gitks.fullname" . }}-metrics:{{ .Values.metricsService.port }}
|
||||
Cluster: {{ include "gitks.headlessServiceName" . }} (headless, pod DNS)
|
||||
|
||||
{{- if contains "NodePort" .Values.service.type }}
|
||||
gRPC NodePort: kubectl get svc {{ include "gitks.fullname" . }} -o jsonpath='{.spec.ports[0].nodePort}'
|
||||
{{- else if contains "LoadBalancer" .Values.service.type }}
|
||||
gRPC external IP: kubectl get svc {{ include "gitks.fullname" . }} --template "{{"{{ range (index .status.loadBalancer.ingress 0) }}{{.}}{{ end }}"}}"
|
||||
{{- else }}
|
||||
Port-forward gRPC:
|
||||
kubectl port-forward svc/{{ include "gitks.fullname" . }} {{ .Values.service.port }}:{{ .Values.service.port }}
|
||||
|
||||
Port-forward metrics:
|
||||
kubectl port-forward svc/{{ include "gitks.fullname" . }}-metrics {{ .Values.metricsService.port }}:{{ .Values.metricsService.port }}
|
||||
{{- end }}
|
||||
|
||||
📊 Metrics:
|
||||
Prometheus endpoint available at :{{ .Values.metricsService.port }}/metrics
|
||||
Metrics Service annotations include prometheus.io/scrape labels.
|
||||
|
||||
💡 Quick start:
|
||||
# Check pod status
|
||||
kubectl get pods -l app.kubernetes.io/instance={{ .Release.Name }}
|
||||
|
||||
# View logs
|
||||
kubectl logs -f statefulset/{{ include "gitks.fullname" . }}
|
||||
|
||||
# Scale up cluster
|
||||
helm upgrade {{ .Release.Name }} . --set replicaCount=5
|
||||
|
||||
For more information, see the project README.
|
||||
@@ -0,0 +1,75 @@
|
||||
{{/*
|
||||
Expand the name of the chart.
|
||||
*/}}
|
||||
{{- define "gitks.name" -}}
|
||||
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Create a default fully qualified app name.
|
||||
*/}}
|
||||
{{- define "gitks.fullname" -}}
|
||||
{{- if .Values.fullnameOverride }}
|
||||
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }}
|
||||
{{- else }}
|
||||
{{- $name := default .Chart.Name .Values.nameOverride }}
|
||||
{{- if contains $name .Release.Name }}
|
||||
{{- .Release.Name | trunc 63 | trimSuffix "-" }}
|
||||
{{- else }}
|
||||
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Headless service name (used for StatefulSet pod DNS).
|
||||
*/}}
|
||||
{{- define "gitks.headlessServiceName" -}}
|
||||
{{- printf "%s-headless" (include "gitks.fullname" .) | trunc 63 | trimSuffix "-" }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Create chart name and version as used by the chart label.
|
||||
*/}}
|
||||
{{- define "gitks.chart" -}}
|
||||
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Common labels
|
||||
*/}}
|
||||
{{- define "gitks.labels" -}}
|
||||
helm.sh/chart: {{ include "gitks.chart" . }}
|
||||
{{ include "gitks.selectorLabels" . }}
|
||||
{{- if .Chart.AppVersion }}
|
||||
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
|
||||
{{- end }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Selector labels
|
||||
*/}}
|
||||
{{- define "gitks.selectorLabels" -}}
|
||||
app.kubernetes.io/name: {{ include "gitks.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
app.kubernetes.io/component: server
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Create the name of the service account to use
|
||||
*/}}
|
||||
{{- define "gitks.serviceAccountName" -}}
|
||||
{{- if .Values.serviceAccount.create }}
|
||||
{{- default (include "gitks.fullname" .) .Values.serviceAccount.name }}
|
||||
{{- else }}
|
||||
{{- default "default" .Values.serviceAccount.name }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Pod DNS name template: pod-name.headless-svc.namespace.svc.cluster.local
|
||||
*/}}
|
||||
{{- define "gitks.podDnsTemplate" -}}
|
||||
$(STORAGE_NAME).{{ include "gitks.headlessServiceName" . }}.{{ .Release.Namespace }}.svc.cluster.local
|
||||
{{- end }}
|
||||
@@ -0,0 +1,35 @@
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: {{ include "gitks.fullname" . }}
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
data:
|
||||
RUST_LOG: {{ .Values.gitks.rustLog | quote }}
|
||||
REPO_PREFIX_PATH: {{ .Values.gitks.repoPrefixPath | quote }}
|
||||
GITKS_HOST: {{ .Values.gitks.grpc.host | quote }}
|
||||
GITKS_PORT: {{ .Values.gitks.grpc.port | quote }}
|
||||
GITKS_METRICS_PORT: {{ .Values.gitks.metrics.port | quote }}
|
||||
GITKS_CLUSTER_PORT: {{ .Values.gitks.cluster.port | quote }}
|
||||
GITKS_CLUSTER_COOKIE: {{ .Values.gitks.cluster.cookie | quote }}
|
||||
{{- if .Values.gitks.etcd.endpoints }}
|
||||
GITKS_ETCD_ENDPOINTS: {{ .Values.gitks.etcd.endpoints | quote }}
|
||||
{{- end }}
|
||||
GITKS_ETCD_CONNECT_TIMEOUT: {{ .Values.gitks.etcd.connectTimeout | quote }}
|
||||
GITKS_LEASE_TTL: {{ .Values.gitks.etcd.leaseTtl | quote }}
|
||||
GITKS_HEALTH_CHECK_INTERVAL: {{ .Values.gitks.healthCheck.interval | quote }}
|
||||
GITKS_MAX_HEALTH_FAILURES: {{ .Values.gitks.healthCheck.maxFailures | quote }}
|
||||
GITKS_DISK_CACHE_ENABLED: {{ .Values.gitks.diskCache.enabled | quote }}
|
||||
GITKS_DISK_CACHE_MAX_AGE: {{ .Values.gitks.diskCache.maxAge | quote }}
|
||||
GITKS_PACK_CACHE_ENABLED: {{ .Values.gitks.packCache.enabled | quote }}
|
||||
GITKS_PACK_CACHE_BACKPRESSURE: {{ .Values.gitks.packCache.backpressure | quote }}
|
||||
GITKS_HOOKS_ENABLED: {{ .Values.gitks.hooks.enabled | quote }}
|
||||
GITKS_HOOK_TIMEOUT: {{ .Values.gitks.hooks.timeout | quote }}
|
||||
GITKS_ALLOW_CUSTOM_HOOKS: {{ .Values.gitks.hooks.allowCustomHooks | quote }}
|
||||
{{- if .Values.gitks.hooks.serverHooksDir }}
|
||||
GITKS_SERVER_HOOKS_DIR: {{ .Values.gitks.hooks.serverHooksDir | quote }}
|
||||
{{- end }}
|
||||
{{- if .Values.gitks.hooks.callbackAddr }}
|
||||
GITKS_HOOK_CALLBACK_ADDR: {{ .Values.gitks.hooks.callbackAddr | quote }}
|
||||
{{- end }}
|
||||
GITKS_RATE_LIMIT_MAX_CONCURRENT: {{ .Values.gitks.rateLimit.maxConcurrent | quote }}
|
||||
@@ -0,0 +1,29 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ include "gitks.headlessServiceName" . }}
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
{{- with .Values.headlessService.annotations }}
|
||||
annotations:
|
||||
{{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
spec:
|
||||
type: ClusterIP
|
||||
clusterIP: None
|
||||
publishNotReadyAddresses: true
|
||||
ports:
|
||||
- name: grpc
|
||||
port: {{ .Values.gitks.grpc.port }}
|
||||
targetPort: grpc
|
||||
protocol: TCP
|
||||
- name: metrics
|
||||
port: {{ .Values.gitks.metrics.port }}
|
||||
targetPort: metrics
|
||||
protocol: TCP
|
||||
- name: cluster
|
||||
port: {{ .Values.gitks.cluster.port }}
|
||||
targetPort: cluster
|
||||
protocol: TCP
|
||||
selector:
|
||||
{{- include "gitks.selectorLabels" . | nindent 4 }}
|
||||
@@ -0,0 +1,32 @@
|
||||
{{- if .Values.autoscaling.enabled }}
|
||||
apiVersion: autoscaling/v2
|
||||
kind: HorizontalPodAutoscaler
|
||||
metadata:
|
||||
name: {{ include "gitks.fullname" . }}
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
spec:
|
||||
scaleTargetRef:
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
name: {{ include "gitks.fullname" . }}
|
||||
minReplicas: {{ .Values.autoscaling.minReplicas }}
|
||||
maxReplicas: {{ .Values.autoscaling.maxReplicas }}
|
||||
metrics:
|
||||
{{- if .Values.autoscaling.targetCPUUtilizationPercentage }}
|
||||
- type: Resource
|
||||
resource:
|
||||
name: cpu
|
||||
target:
|
||||
type: Utilization
|
||||
averageUtilization: {{ .Values.autoscaling.targetCPUUtilizationPercentage }}
|
||||
{{- end }}
|
||||
{{- if .Values.autoscaling.targetMemoryUtilizationPercentage }}
|
||||
- type: Resource
|
||||
resource:
|
||||
name: memory
|
||||
target:
|
||||
type: Utilization
|
||||
averageUtilization: {{ .Values.autoscaling.targetMemoryUtilizationPercentage }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,22 @@
|
||||
{{- if .Values.metricsService.enabled }}
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ include "gitks.fullname" . }}-metrics
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
app.kubernetes.io/component: metrics
|
||||
{{- with .Values.metricsService.annotations }}
|
||||
annotations:
|
||||
{{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
spec:
|
||||
type: {{ .Values.metricsService.type }}
|
||||
ports:
|
||||
- port: {{ .Values.metricsService.port }}
|
||||
targetPort: metrics
|
||||
protocol: TCP
|
||||
name: metrics
|
||||
selector:
|
||||
{{- include "gitks.selectorLabels" . | nindent 4 }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,18 @@
|
||||
{{- if .Values.podDisruptionBudget.enabled }}
|
||||
apiVersion: policy/v1
|
||||
kind: PodDisruptionBudget
|
||||
metadata:
|
||||
name: {{ include "gitks.fullname" . }}
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
spec:
|
||||
{{- with .Values.podDisruptionBudget.minAvailable }}
|
||||
minAvailable: {{ . }}
|
||||
{{- end }}
|
||||
{{- with .Values.podDisruptionBudget.maxUnavailable }}
|
||||
maxUnavailable: {{ . }}
|
||||
{{- end }}
|
||||
selector:
|
||||
matchLabels:
|
||||
{{- include "gitks.selectorLabels" . | nindent 6 }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,19 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ include "gitks.fullname" . }}
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
{{- with .Values.service.annotations }}
|
||||
annotations:
|
||||
{{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
spec:
|
||||
type: {{ .Values.service.type }}
|
||||
ports:
|
||||
- port: {{ .Values.service.port }}
|
||||
targetPort: grpc
|
||||
protocol: TCP
|
||||
name: grpc
|
||||
selector:
|
||||
{{- include "gitks.selectorLabels" . | nindent 4 }}
|
||||
@@ -0,0 +1,13 @@
|
||||
{{- if .Values.serviceAccount.create -}}
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
name: {{ include "gitks.serviceAccountName" . }}
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
{{- with .Values.serviceAccount.annotations }}
|
||||
annotations:
|
||||
{{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
automountServiceAccountToken: {{ .Values.serviceAccount.automount }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,131 @@
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
name: {{ include "gitks.fullname" . }}
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
spec:
|
||||
serviceName: {{ include "gitks.headlessServiceName" . }}
|
||||
{{- if not .Values.autoscaling.enabled }}
|
||||
replicas: {{ .Values.replicaCount }}
|
||||
{{- end }}
|
||||
podManagementPolicy: Parallel
|
||||
selector:
|
||||
matchLabels:
|
||||
{{- include "gitks.selectorLabels" . | nindent 6 }}
|
||||
template:
|
||||
metadata:
|
||||
{{- with .Values.podAnnotations }}
|
||||
annotations:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 8 }}
|
||||
{{- with .Values.podLabels }}
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
spec:
|
||||
{{- with .Values.imagePullSecrets }}
|
||||
imagePullSecrets:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
serviceAccountName: {{ include "gitks.serviceAccountName" . }}
|
||||
{{- with .Values.podSecurityContext }}
|
||||
securityContext:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
terminationGracePeriodSeconds: 30
|
||||
containers:
|
||||
- name: gitks
|
||||
{{- with .Values.securityContext }}
|
||||
securityContext:
|
||||
{{- toYaml . | nindent 12 }}
|
||||
{{- end }}
|
||||
image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}"
|
||||
imagePullPolicy: {{ .Values.image.pullPolicy }}
|
||||
command: ["gitks"]
|
||||
ports:
|
||||
- name: grpc
|
||||
containerPort: {{ .Values.gitks.grpc.port }}
|
||||
protocol: TCP
|
||||
- name: metrics
|
||||
containerPort: {{ .Values.gitks.metrics.port }}
|
||||
protocol: TCP
|
||||
- name: cluster
|
||||
containerPort: {{ .Values.gitks.cluster.port }}
|
||||
protocol: TCP
|
||||
envFrom:
|
||||
- configMapRef:
|
||||
name: {{ include "gitks.fullname" . }}
|
||||
env:
|
||||
# Pod identity — used as STORAGE_NAME and for cluster addressing
|
||||
- name: STORAGE_NAME
|
||||
valueFrom:
|
||||
fieldRef:
|
||||
fieldPath: metadata.name
|
||||
# Advertised gRPC address for remote clients (other nodes use this)
|
||||
- name: GITKS_ADVERTISE_ADDR
|
||||
value: "http://{{ include "gitks.podDnsTemplate" . }}:{{ .Values.gitks.grpc.port }}"
|
||||
# Cluster hostname for ractor TCP connections
|
||||
- name: GITKS_CLUSTER_HOSTNAME
|
||||
value: {{ include "gitks.podDnsTemplate" . | quote }}
|
||||
{{- with .Values.extraEnv }}
|
||||
{{- toYaml . | nindent 12 }}
|
||||
{{- end }}
|
||||
{{- with .Values.resources }}
|
||||
resources:
|
||||
{{- toYaml . | nindent 12 }}
|
||||
{{- end }}
|
||||
livenessProbe:
|
||||
tcpSocket:
|
||||
port: grpc
|
||||
initialDelaySeconds: 10
|
||||
periodSeconds: 10
|
||||
failureThreshold: 3
|
||||
readinessProbe:
|
||||
tcpSocket:
|
||||
port: grpc
|
||||
initialDelaySeconds: 5
|
||||
periodSeconds: 5
|
||||
failureThreshold: 3
|
||||
startupProbe:
|
||||
tcpSocket:
|
||||
port: grpc
|
||||
initialDelaySeconds: 5
|
||||
periodSeconds: 5
|
||||
failureThreshold: 30
|
||||
volumeMounts:
|
||||
- name: repo-data
|
||||
mountPath: {{ .Values.gitks.repoPrefixPath | quote }}
|
||||
{{- with .Values.nodeSelector }}
|
||||
nodeSelector:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
{{- with .Values.affinity }}
|
||||
affinity:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
{{- with .Values.tolerations }}
|
||||
tolerations:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
{{- if .Values.persistence.enabled }}
|
||||
volumeClaimTemplates:
|
||||
- metadata:
|
||||
name: repo-data
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 10 }}
|
||||
{{- with .Values.persistence.annotations }}
|
||||
annotations:
|
||||
{{- toYaml . | nindent 10 }}
|
||||
{{- end }}
|
||||
spec:
|
||||
accessModes:
|
||||
- {{ .Values.persistence.accessMode }}
|
||||
{{- with .Values.persistence.storageClass }}
|
||||
storageClassName: {{ . | quote }}
|
||||
{{- end }}
|
||||
resources:
|
||||
requests:
|
||||
storage: {{ .Values.persistence.size }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,21 @@
|
||||
apiVersion: v1
|
||||
kind: Pod
|
||||
metadata:
|
||||
name: "{{ include "gitks.fullname" . }}-test-connection"
|
||||
labels:
|
||||
{{- include "gitks.labels" . | nindent 4 }}
|
||||
annotations:
|
||||
"helm.sh/hook": test
|
||||
"helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded
|
||||
spec:
|
||||
containers:
|
||||
- name: grpc-health
|
||||
image: fullstorydev/grpcurl:latest
|
||||
command: ['grpcurl']
|
||||
args:
|
||||
- -plaintext
|
||||
- -connect-timeout
|
||||
- "5"
|
||||
- {{ include "gitks.fullname" . }}:{{ .Values.service.port }}
|
||||
- list
|
||||
restartPolicy: Never
|
||||
@@ -0,0 +1,152 @@
|
||||
# Number of gitks cluster nodes (StatefulSet replicas).
|
||||
# Each pod gets a stable identity (gitks-0, gitks-1, ...) used as STORAGE_NAME.
|
||||
replicaCount: 3
|
||||
|
||||
image:
|
||||
repository: gitks
|
||||
pullPolicy: IfNotPresent
|
||||
tag: ""
|
||||
|
||||
imagePullSecrets: []
|
||||
nameOverride: ""
|
||||
fullnameOverride: ""
|
||||
|
||||
serviceAccount:
|
||||
create: true
|
||||
automount: true
|
||||
annotations: {}
|
||||
name: ""
|
||||
|
||||
# -- GitKS application configuration.
|
||||
# Mirrors the environment variables from docker-compose.yaml / .env.
|
||||
gitks:
|
||||
# -- Log level (error | warn | info | debug | trace).
|
||||
rustLog: info
|
||||
|
||||
# -- Absolute path inside the container where bare repositories live.
|
||||
repoPrefixPath: /data/repos
|
||||
|
||||
# -- gRPC server configuration.
|
||||
grpc:
|
||||
host: "0.0.0.0"
|
||||
port: 50051
|
||||
|
||||
# -- Prometheus-compatible metrics endpoint.
|
||||
metrics:
|
||||
port: 9100
|
||||
|
||||
# -- Ractor cluster TCP listener.
|
||||
cluster:
|
||||
port: 4697
|
||||
cookie: gitks-default-cookie
|
||||
|
||||
# -- etcd service discovery configuration.
|
||||
etcd:
|
||||
# -- External etcd endpoints (comma-separated).
|
||||
# Example: "http://etcd-0.etcd-headless:2379,http://etcd-1.etcd-headless:2379"
|
||||
# Leave empty to disable cluster mode (standalone).
|
||||
endpoints: ""
|
||||
# -- etcd connection timeout in milliseconds.
|
||||
connectTimeout: 5000
|
||||
# -- etcd lease TTL in seconds.
|
||||
leaseTtl: 15
|
||||
|
||||
# -- Cluster health check (self-election triggers).
|
||||
healthCheck:
|
||||
interval: 1
|
||||
maxFailures: 10
|
||||
|
||||
# -- Disk cache (caches gRPC responses to disk).
|
||||
diskCache:
|
||||
enabled: false
|
||||
maxAge: 300
|
||||
|
||||
# -- Pack cache (caches pack-objects results). Requires diskCache.enabled.
|
||||
packCache:
|
||||
enabled: false
|
||||
backpressure: true
|
||||
|
||||
# -- Git hooks (server-side, custom, and callback hooks).
|
||||
hooks:
|
||||
enabled: true
|
||||
timeout: 30
|
||||
allowCustomHooks: true
|
||||
# -- Path to server-side hook scripts (empty = use default).
|
||||
serverHooksDir: ""
|
||||
# -- gRPC address for hook callbacks (empty = disabled).
|
||||
callbackAddr: ""
|
||||
|
||||
# -- Per-repository rate limiting.
|
||||
rateLimit:
|
||||
maxConcurrent: 200
|
||||
|
||||
# -- Persistence configuration for repository data.
|
||||
# Each StatefulSet pod gets its own PVC via volumeClaimTemplates.
|
||||
persistence:
|
||||
enabled: true
|
||||
storageClass: ""
|
||||
accessMode: ReadWriteOnce
|
||||
size: 10Gi
|
||||
annotations: {}
|
||||
|
||||
# -- gRPC Service.
|
||||
service:
|
||||
type: ClusterIP
|
||||
port: 50051
|
||||
annotations: {}
|
||||
|
||||
# -- Metrics Service (Prometheus scraping).
|
||||
metricsService:
|
||||
enabled: true
|
||||
type: ClusterIP
|
||||
port: 9100
|
||||
annotations:
|
||||
prometheus.io/scrape: "true"
|
||||
prometheus.io/port: "9100"
|
||||
prometheus.io/path: "/metrics"
|
||||
|
||||
# -- Headless service is always created (required for StatefulSet DNS).
|
||||
headlessService:
|
||||
annotations: {}
|
||||
|
||||
podAnnotations: {}
|
||||
podLabels: {}
|
||||
|
||||
podSecurityContext:
|
||||
fsGroup: 1000
|
||||
|
||||
securityContext:
|
||||
capabilities:
|
||||
drop:
|
||||
- ALL
|
||||
readOnlyRootFilesystem: false
|
||||
runAsNonRoot: true
|
||||
runAsUser: 1000
|
||||
|
||||
resources:
|
||||
requests:
|
||||
cpu: 100m
|
||||
memory: 128Mi
|
||||
limits:
|
||||
cpu: 1000m
|
||||
memory: 1Gi
|
||||
|
||||
autoscaling:
|
||||
enabled: false
|
||||
minReplicas: 1
|
||||
maxReplicas: 10
|
||||
targetCPUUtilizationPercentage: 80
|
||||
|
||||
# -- Pod Disruption Budget to protect cluster quorum.
|
||||
podDisruptionBudget:
|
||||
enabled: true
|
||||
minAvailable: 1
|
||||
|
||||
nodeSelector: {}
|
||||
tolerations: []
|
||||
affinity: {}
|
||||
|
||||
# -- Extra environment variables (key-value pairs).
|
||||
extraEnv: []
|
||||
# - name: GITKS_EXTRA
|
||||
# value: "some-value"
|
||||
Reference in New Issue
Block a user