iac/apps/transmittal/base/worker-deployment.yaml
2026-04-27 11:39:57 +03:00

212 lines
11 KiB
YAML

---
apiVersion: apps/v1
kind: Deployment
metadata:
name: worker
namespace: transmittal
labels:
app: worker
service: worker
spec:
replicas: 1
selector:
matchLabels:
app: worker
template:
metadata:
labels:
app: worker
service: worker
annotations:
traffic.sidecar.istio.io/excludeOutboundPorts: "8200"
vault.hashicorp.com/agent-init-first: "true"
vault.hashicorp.com/agent-inject: "true"
vault.hashicorp.com/agent-pre-populate-only: "true"
vault.hashicorp.com/auth-path: auth/kubernetes
vault.hashicorp.com/role: transmittal
vault.hashicorp.com/agent-inject-secret-transmittal-db: secrets/data/postgresql/apps/transmittal
vault.hashicorp.com/agent-inject-template-transmittal-db: |-
{{- with secret "secrets/data/postgresql/apps/transmittal" -}}
TRANSMITTAL_SERVICE_DATABASE__USER={{ index .Data.data "username" }}
TRANSMITTAL_SERVICE_DATABASE__PASSWORD={{ index .Data.data "password" }}
TRANSMITTAL_SERVICE_DATABASE__HOST=postgresql.transmittal.svc.cluster.local
TRANSMITTAL_SERVICE_DATABASE__PORT=5432
TRANSMITTAL_SERVICE_DATABASE__NAME=transmittal_db
{{- end -}}
vault.hashicorp.com/agent-inject-secret-transmittal-rabbitmq: secrets/data/rabbitmq/apps/transmittal
vault.hashicorp.com/agent-inject-template-transmittal-rabbitmq: |-
{{- with secret "secrets/data/rabbitmq/apps/transmittal" -}}
TRANSMITTAL_SERVICE_RABBITMQ__USER={{ index .Data.data "username" }}
TRANSMITTAL_SERVICE_RABBITMQ__PASSWORD={{ index .Data.data "password" }}
TRANSMITTAL_SERVICE_RABBITMQ__VHOST={{ index .Data.data "vhost" }}
{{- end -}}
vault.hashicorp.com/agent-inject-secret-transmittal-s3: secrets/data/minio/apps/transmittal
vault.hashicorp.com/agent-inject-template-transmittal-s3: |-
{{- with secret "secrets/data/minio/apps/transmittal" -}}
TRANSMITTAL_SERVICE_S3_CLIENT__ACCESS_KEY={{ index .Data.data "access_key" }}
TRANSMITTAL_SERVICE_S3_CLIENT__SECRET_KEY={{ index .Data.data "secret_key" }}
{{- $buckets := index .Data.data "buckets" -}}
TRANSMITTAL_SERVICE_S3_CLIENT__DEFAULT_BUCKET={{- if gt (len $buckets) 0 -}}{{ index (index $buckets 0) "name" }}{{- else -}}transmittal-storage{{- end -}}
{{- end -}}
vault.hashicorp.com/agent-inject-secret-transmittal-django-auth: secrets/data/vault/common/django_auth
vault.hashicorp.com/agent-inject-template-transmittal-django-auth: |-
{{- with secret "secrets/data/vault/common/django_auth" -}}
TRANSMITTAL_SERVICE_SAREX_BACKEND_REPOSITORY__BASIC_AUTH_ENCODED={{ index .Data.data "key" }}
{{- end -}}
vault.hashicorp.com/agent-inject-secret-transmittal-public-key: secrets/data/vault/common/rsa_keys
vault.hashicorp.com/agent-inject-template-transmittal-public-key: |-
{{- with secret "secrets/data/vault/common/rsa_keys" -}}
TRANSMITTAL_SERVICE_AUTH__PUBLIC_KEY={{ printf "%q" (index .Data.data "public_key") }}
{{- end -}}
vault.hashicorp.com/agent-inject-secret-transmittal-mailgun: secrets/data/vault/apps/transmittal
vault.hashicorp.com/agent-inject-template-transmittal-mailgun: |-
{{- with secret "secrets/data/vault/apps/transmittal" -}}
TRANSMITTAL_SERVICE_MAILGUN__API_KEY={{ index .Data.data "TRANSMITTAL_SERVICE_MAILGUN__API_KEY" }}
{{- end -}}
spec:
serviceAccountName: transmittal-vault
containers:
- name: worker
image: cr.yandex/crp3ccidau046kdj8g9q/transmittal-api:prod_a9d879ae
imagePullPolicy: IfNotPresent
command: ["/bin/bash", "-ec"]
args:
- |
set -a
[ -f /vault/secrets/transmittal-db ] && . /vault/secrets/transmittal-db
[ -f /vault/secrets/transmittal-rabbitmq ] && . /vault/secrets/transmittal-rabbitmq
[ -f /vault/secrets/transmittal-s3 ] && . /vault/secrets/transmittal-s3
[ -f /vault/secrets/transmittal-django-auth ] && . /vault/secrets/transmittal-django-auth
[ -f /vault/secrets/transmittal-public-key ] && . /vault/secrets/transmittal-public-key
[ -f /vault/secrets/transmittal-mailgun ] && . /vault/secrets/transmittal-mailgun
set +a
exec taskiq worker --no-parse transmittal_service.tasks.broker:broker transmittal_service.tasks.transmittal.tasks transmittal_service.tasks.email.tasks
ports:
- name: http
containerPort: 8000
protocol: TCP
env:
- name: TRANSMITTAL_SERVICE_FLOWS_REPOSITORY__BASE_URL
value: http://backend-svc.flows.svc.cluster.local:8000
- name: TRANSMITTAL_SERVICE_FLOWS_REPOSITORY__MAX_CONNECTIONS
value: "10"
- name: TRANSMITTAL_SERVICE_FLOWS_REPOSITORY__MAX_KEEPALIVE_CONNECTIONS
value: "5"
- name: TRANSMITTAL_SERVICE_FLOWS_REPOSITORY__TIMEOUT
value: "30"
- name: TRANSMITTAL_SERVICE_APP__NAME
value: Transmittal Service
- name: TRANSMITTAL_SERVICE_APP__LOG_LEVEL
value: ERROR
- name: TRANSMITTAL_SERVICE_APP__HOST
value: https://lk.srx.wb.ru:30443/transmittal
- name: TRANSMITTAL_SERVICE_APP__ENVIRONMENT
value: prod
- name: TRANSMITTAL_SERVICE_CORS__ALLOW_ORIGINS
value: '["*"]'
- name: TRANSMITTAL_SERVICE_CORS__ALLOW_METHODS
value: '["*"]'
- name: TRANSMITTAL_SERVICE_CORS__ALLOW_HEADERS
value: '["*"]'
- name: TRANSMITTAL_SERVICE_CORS__ALLOW_CREDENTIALS
value: "true"
- name: TRANSMITTAL_SERVICE_UVICORN__HOST
value: 0.0.0.0
- name: TRANSMITTAL_SERVICE_UVICORN__PORT
value: "8000"
- name: TRANSMITTAL_SERVICE_UVICORN__ENABLE_AUTO_RELOAD
value: "false"
- name: TRANSMITTAL_SERVICE_OTEL__ENABLE
value: "false"
- name: TRANSMITTAL_SERVICE_OTEL__HOST
value: http://signoz-otel-collector-external.signoz.svc.cluster.local:4317
- name: TRANSMITTAL_SERVICE_OTEL__SERVICE_NAME
value: backend.transmittals-prod
- name: TRANSMITTAL_SERVICE_OTEL__INSECURE
value: "false"
- name: TRANSMITTAL_SERVICE_DATABASE__SSL_MODE
value: verify-full
- name: TRANSMITTAL_SERVICE_DATABASE__SSL_ROOT_CERT_PATH
value: /opt/.postgresql/root.crt
- name: TRANSMITTAL_SERVICE_UVICORN__LOG_LEVEL
value: info
- name: TRANSMITTAL_SERVICE_UVICORN__NUM_WORKERS
value: "2"
- name: TRANSMITTAL_SERVICE_UVICORN__ROOT_PATH
- name: TRANSMITTAL_SERVICE_DATABASE__ENABLE_SSL
value: "false"
- name: TRANSMITTAL_SERVICE_RABBITMQ__HOST
value: rabbitmq.rabbitmq.svc.cluster.local
- name: TRANSMITTAL_SERVICE_RABBITMQ__PORT
value: "5672"
- name: TRANSMITTAL_SERVICE_SAREX_BACKEND_REPOSITORY__BASE_URL
value: http://backend.django.svc.cluster.local:8000
- name: TRANSMITTAL_SERVICE_SAREX_BACKEND_REPOSITORY__MAX_CONNECTIONS
value: "10"
- name: TRANSMITTAL_SERVICE_SAREX_BACKEND_REPOSITORY__MAX_KEEPALIVE_CONNECTIONS
value: "5"
- name: TRANSMITTAL_SERVICE_SAREX_BACKEND_REPOSITORY__TIMEOUT
value: "15"
- name: TRANSMITTAL_SERVICE_RESOURCE_REPOSITORY__BASE_URL
value: http://resources-service.resources.svc.cluster.local:8000
- name: TRANSMITTAL_SERVICE_RESOURCE_REPOSITORY__MAX_CONNECTIONS
value: "10"
- name: TRANSMITTAL_SERVICE_RESOURCE_REPOSITORY__MAX_KEEPALIVE_CONNECTIONS
value: "5"
- name: TRANSMITTAL_SERVICE_RESOURCE_REPOSITORY__TIMEOUT
value: "15"
- name: TRANSMITTAL_SERVICE_DOCUMENTATIONS_REPOSITORY__BASE_URL
value: http://documentations-api.documentations.svc.cluster.local:8080
- name: TRANSMITTAL_SERVICE_DOCUMENTATIONS_REPOSITORY__MAX_CONNECTIONS
value: "10"
- name: TRANSMITTAL_SERVICE_DOCUMENTATIONS_REPOSITORY__MAX_KEEPALIVE_CONNECTIONS
value: "5"
- name: TRANSMITTAL_SERVICE_DOCUMENTATIONS_REPOSITORY__TIMEOUT
value: "15"
- name: TRANSMITTAL_SERVICE_S3_CLIENT__MAX_POOL_CONNECTIONS
value: "10"
- name: TRANSMITTAL_SERVICE_S3_CLIENT__CONNECT_TIMEOUT
value: "10"
- name: TRANSMITTAL_SERVICE_S3_CLIENT__READ_TIMEOUT
value: "50"
- name: TRANSMITTAL_SERVICE_S3_CLIENT__REGION_NAME
value: ru-central1
- name: TRANSMITTAL_SERVICE_S3_CLIENT__VERIFY
value: "true"
- name: TRANSMITTAL_SERVICE_S3_CLIENT__ENDPOINT
value: minio.minio.svc.cluster.local:9000
- name: TRANSMITTAL_SERVICE_S3_CLIENT__USE_SSL
value: "false"
- name: TRANSMITTAL_SERVICE_HTML_TO_PDF_CONVERTER__BASE_URL
value: http://export-project-service.django.svc.cluster.local:8000
- name: TRANSMITTAL_SERVICE_HTML_TO_PDF_CONVERTER__MAX_CONNECTIONS
value: "10"
- name: TRANSMITTAL_SERVICE_HTML_TO_PDF_CONVERTER__MAX_KEEPALIVE_CONNECTIONS
value: "5"
- name: TRANSMITTAL_SERVICE_HTML_TO_PDF_CONVERTER__TIMEOUT
value: "50"
- name: TRANSMITTAL_SERVICE_MARKINGS__BASE_URL
value: http://marks-service.documentations.svc.cluster.local:8000
- name: TRANSMITTAL_SERVICE_MARKINGS__MAX_CONNECTIONS
value: "10"
- name: TRANSMITTAL_SERVICE_MARKINGS__MAX_KEEPALIVE_CONNECTIONS
value: "5"
- name: TRANSMITTAL_SERVICE_MARKINGS__TIMEOUT
value: "50"
- name: TRANSMITTAL_SERVICE_MAILGUN__BASE_URL
value: https://api.mailgun.net/v3/mg.sarex.io
- name: TRANSMITTAL_SERVICE_MAILGUN__MAX_CONNECTIONS
value: "10"
- name: TRANSMITTAL_SERVICE_MAILGUN__MAX_KEEPALIVE_CONNECTIONS
value: "5"
- name: TRANSMITTAL_SERVICE_MAILGUN__TIMEOUT
value: "15"
- name: TRANSMITTAL_SERVICE_MAILGUN__EMAIL
value: hello@wb.io
resources:
requests:
cpu: "1"
memory: 1Gi
imagePullSecrets:
- name: regcred