close CLOUD-137 <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **New Features** - Introduced advanced workspace-scoped search and aggregation capabilities with support for complex queries, highlights, and pagination. - Added pluggable search providers: Elasticsearch and Manticoresearch. - New GraphQL queries, schema types, and resolver support for search and aggregation. - Enhanced configuration options for search providers in self-hosted and cloud deployments. - Added Docker Compose services and environment variables for Elasticsearch and Manticoresearch. - Integrated indexer service into deployment and CI workflows. - **Bug Fixes** - Improved error handling with new user-friendly error messages for search provider and indexer issues. - **Documentation** - Updated configuration examples and environment variable references for indexer and search providers. - **Tests** - Added extensive end-to-end and provider-specific tests covering indexing, searching, aggregation, deletion, and error cases. - Included snapshot tests and test fixtures for search providers. - **Chores** - Updated deployment scripts, Helm charts, and Kubernetes manifests to include indexer-related environment variables and secrets. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
119 lines
4.2 KiB
YAML
119 lines
4.2 KiB
YAML
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
name: {{ include "doc.fullname" . }}
|
|
labels:
|
|
{{- include "doc.labels" . | nindent 4 }}
|
|
spec:
|
|
replicas: {{ .Values.replicaCount }}
|
|
selector:
|
|
matchLabels:
|
|
{{- include "doc.selectorLabels" . | nindent 6 }}
|
|
template:
|
|
metadata:
|
|
{{- with .Values.podAnnotations }}
|
|
annotations:
|
|
{{- toYaml . | nindent 8 }}
|
|
{{- end }}
|
|
labels:
|
|
{{- include "doc.selectorLabels" . | nindent 8 }}
|
|
spec:
|
|
{{- with .Values.imagePullSecrets }}
|
|
imagePullSecrets:
|
|
{{- toYaml . | nindent 8 }}
|
|
{{- end }}
|
|
serviceAccountName: {{ include "doc.serviceAccountName" . }}
|
|
containers:
|
|
- name: {{ .Chart.Name }}
|
|
image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}"
|
|
imagePullPolicy: {{ .Values.image.pullPolicy }}
|
|
env:
|
|
- name: AFFINE_PRIVATE_KEY
|
|
valueFrom:
|
|
secretKeyRef:
|
|
name: "{{ .Values.global.secret.secretName }}"
|
|
key: key
|
|
- name: NODE_ENV
|
|
value: "{{ .Values.env }}"
|
|
- name: NODE_OPTIONS
|
|
value: "--max-old-space-size=4096"
|
|
- name: NO_COLOR
|
|
value: "1"
|
|
- name: DEPLOYMENT_TYPE
|
|
value: "{{ .Values.global.deployment.type }}"
|
|
- name: DEPLOYMENT_PLATFORM
|
|
value: "{{ .Values.global.deployment.platform }}"
|
|
- name: SERVER_FLAVOR
|
|
value: "doc"
|
|
- name: AFFINE_ENV
|
|
value: "{{ .Release.Namespace }}"
|
|
- name: DATABASE_PASSWORD
|
|
valueFrom:
|
|
secretKeyRef:
|
|
name: pg-postgresql
|
|
key: postgres-password
|
|
- name: DATABASE_URL
|
|
value: postgres://{{ .Values.global.database.user }}:$(DATABASE_PASSWORD)@{{ .Values.global.database.host }}:{{ .Values.global.database.port }}/{{ .Values.global.database.name }}
|
|
- name: REDIS_SERVER_ENABLED
|
|
value: "true"
|
|
- name: REDIS_SERVER_HOST
|
|
value: "{{ .Values.global.redis.host }}"
|
|
- name: REDIS_SERVER_PORT
|
|
value: "{{ .Values.global.redis.port }}"
|
|
- name: REDIS_SERVER_USER
|
|
value: "{{ .Values.global.redis.username }}"
|
|
- name: REDIS_SERVER_PASSWORD
|
|
valueFrom:
|
|
secretKeyRef:
|
|
name: redis
|
|
key: redis-password
|
|
- name: REDIS_SERVER_DATABASE
|
|
value: "{{ .Values.global.redis.database }}"
|
|
- name: AFFINE_INDEXER_SEARCH_PROVIDER
|
|
value: "{{ .Values.global.indexer.provider }}"
|
|
- name: AFFINE_INDEXER_SEARCH_ENDPOINT
|
|
value: "{{ .Values.global.indexer.endpoint }}"
|
|
- name: AFFINE_INDEXER_SEARCH_USERNAME
|
|
value: "{{ .Values.global.indexer.username }}"
|
|
- name: AFFINE_INDEXER_SEARCH_PASSWORD
|
|
valueFrom:
|
|
secretKeyRef:
|
|
name: indexer
|
|
key: indexer-password
|
|
- name: AFFINE_SERVER_PORT
|
|
value: "{{ .Values.global.docService.port }}"
|
|
- name: AFFINE_SERVER_SUB_PATH
|
|
value: "{{ .Values.app.path }}"
|
|
- name: AFFINE_SERVER_HOST
|
|
value: "{{ .Values.app.host }}"
|
|
- name: AFFINE_SERVER_HTTPS
|
|
value: "{{ .Values.app.https }}"
|
|
ports:
|
|
- name: http
|
|
containerPort: {{ .Values.global.docService.port }}
|
|
protocol: TCP
|
|
livenessProbe:
|
|
httpGet:
|
|
path: /info
|
|
port: http
|
|
initialDelaySeconds: {{ .Values.probe.initialDelaySeconds }}
|
|
readinessProbe:
|
|
httpGet:
|
|
path: /info
|
|
port: http
|
|
initialDelaySeconds: {{ .Values.probe.initialDelaySeconds }}
|
|
resources:
|
|
{{- toYaml .Values.resources | nindent 12 }}
|
|
{{- with .Values.nodeSelector }}
|
|
nodeSelector:
|
|
{{- toYaml . | nindent 8 }}
|
|
{{- end }}
|
|
{{- with .Values.affinity }}
|
|
affinity:
|
|
{{- toYaml . | nindent 8 }}
|
|
{{- end }}
|
|
{{- with .Values.tolerations }}
|
|
tolerations:
|
|
{{- toYaml . | nindent 8 }}
|
|
{{- end }}
|