mirror of
https://git.mirrors.martin98.com/https://github.com/infiniflow/ragflow.git
synced 2025-07-30 04:12:01 +08:00

### What problem does this PR solve? The initial Helm chart implementation added in #3815 suffers from an issue where the 5GB data volume for the SQL DB is filled up with [binlog](https://dev.mysql.com/doc/refman/8.4/en/binary-log.html) files after just a few days. Since the app uses a non-replicated SQL DB config I think it makes sense to disable the binlog in the SQL DB container. This is achieved by simply adding the required argument to the container startup command. ### Type of change - [X] Bug Fix (non-breaking change which fixes an issue)
97 lines
2.8 KiB
YAML
97 lines
2.8 KiB
YAML
---
|
|
apiVersion: v1
|
|
kind: PersistentVolumeClaim
|
|
metadata:
|
|
name: {{ include "ragflow.fullname" . }}-mysql
|
|
labels:
|
|
{{- include "ragflow.labels" . | nindent 4 }}
|
|
app.kubernetes.io/component: mysql
|
|
spec:
|
|
{{- with .Values.mysql.storage.className }}
|
|
storageClassName: {{ . }}
|
|
{{- end }}
|
|
accessModes:
|
|
- ReadWriteOnce
|
|
resources:
|
|
requests:
|
|
storage: {{ .Values.mysql.storage.capacity }}
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
name: {{ include "ragflow.fullname" . }}-mysql
|
|
labels:
|
|
{{- include "ragflow.labels" . | nindent 4 }}
|
|
app.kubernetes.io/component: mysql
|
|
spec:
|
|
replicas: 1
|
|
selector:
|
|
matchLabels:
|
|
{{- include "ragflow.selectorLabels" . | nindent 6 }}
|
|
app.kubernetes.io/component: mysql
|
|
{{- with .Values.mysql.deployment.strategy }}
|
|
strategy:
|
|
{{- . | toYaml | nindent 4 }}
|
|
{{- end }}
|
|
template:
|
|
metadata:
|
|
labels:
|
|
{{- include "ragflow.labels" . | nindent 8 }}
|
|
app.kubernetes.io/component: mysql
|
|
annotations:
|
|
checksum/config-mysql: {{ include (print $.Template.BasePath "/mysql-config.yaml") . | sha256sum }}
|
|
checksum/config-env: {{ include (print $.Template.BasePath "/env.yaml") . | sha256sum }}
|
|
spec:
|
|
containers:
|
|
- name: mysql
|
|
image: {{ .Values.mysql.image.repository }}:{{ .Values.mysql.image.tag }}
|
|
envFrom:
|
|
- secretRef:
|
|
name: {{ include "ragflow.fullname" . }}-env-config
|
|
args:
|
|
- --max_connections=1000
|
|
- --character-set-server=utf8mb4
|
|
- --collation-server=utf8mb4_general_ci
|
|
- --default-authentication-plugin=mysql_native_password
|
|
- --tls_version=TLSv1.2,TLSv1.3
|
|
- --init-file=/data/application/init.sql
|
|
- --disable-log-bin
|
|
ports:
|
|
- containerPort: 3306
|
|
name: mysql
|
|
{{- with .Values.mysql.deployment.resources }}
|
|
resources:
|
|
{{- . | toYaml | nindent 10 }}
|
|
{{- end }}
|
|
volumeMounts:
|
|
- mountPath: /var/lib/mysql
|
|
name: mysql-data
|
|
- mountPath: /data/application/init.sql
|
|
subPath: init.sql
|
|
readOnly: true
|
|
name: init-script-volume
|
|
volumes:
|
|
- name: mysql-data
|
|
persistentVolumeClaim:
|
|
claimName: {{ include "ragflow.fullname" . }}-mysql
|
|
- name: init-script-volume
|
|
configMap:
|
|
name: mysql-init-script
|
|
---
|
|
apiVersion: v1
|
|
kind: Service
|
|
metadata:
|
|
name: {{ include "ragflow.fullname" . }}-mysql
|
|
labels:
|
|
{{- include "ragflow.labels" . | nindent 4 }}
|
|
app.kubernetes.io/component: mysql
|
|
spec:
|
|
selector:
|
|
{{- include "ragflow.selectorLabels" . | nindent 4 }}
|
|
app.kubernetes.io/component: mysql
|
|
ports:
|
|
- protocol: TCP
|
|
port: 3306
|
|
targetPort: mysql
|
|
type: {{ .Values.mysql.service.type }}
|