deployment.yaml 3.07 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# SPDX-FileCopyrightText: Copyright (c) 2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
# SPDX-License-Identifier: Apache-2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
{{- range .Values.services }}
apiVersion: apps/v1
kind: Deployment
metadata:
19
  name: {{ $.Release.Name }}-{{ .name | lower }}
20
  labels:
21
    app: {{ $.Release.Name }}-{{ .name | lower }}
22
spec:
23
  replicas: {{ .config.workers | default 1 }}
24
25
  selector:
    matchLabels:
26
      app: {{ $.Release.Name }}-{{ .name | lower }}
27
28
29
  template:
    metadata:
      labels:
30
        app: {{ $.Release.Name }}-{{ .name | lower }}
31
32
33
    spec:
      # pull secrets
      imagePullSecrets:
34
35
36
      {{- range $.Values.imagePullSecrets }}
        - name: {{ .name }}
      {{- end }}
37
38
39
      securityContext:
        runAsUser: 0
      containers:
40
      - name: {{ $.Release.Name }}-{{ .name | lower }}
41
42
        image: {{ $.Values.image }}
        args:
43
44
45
46
47
        {{ if $.Values.configFilePath }}
        - cd src && uv run dynamo serve --service-name {{ .name }} {{ $.Values.dynamoIdentifier }} -f {{ $.Values.configFilePath }}
        {{ else }}
        - cd src && uv run dynamo serve --service-name {{ .name }} {{ $.Values.dynamoIdentifier }}
        {{ end }}
48
49
50
51
52
53
        command:
        - sh
        - -c
        resources:
          requests:
            cpu: "{{ .config.resources.cpu }}"
54
55
56
57
58
59
            {{ if .config.resources.memory }}
            memory: "{{ .config.resources.memory }}"
            {{ end }}
            {{ if .config.resources.gpu }}
            nvidia.com/gpu: "{{ .config.resources.gpu }}"
            {{ end }}
60
61
          limits:
            cpu: "{{ .config.resources.cpu }}"
62
63
64
65
66
67
            {{ if .config.resources.memory }}
            memory: "{{ .config.resources.memory }}"
            {{ end }}
            {{ if .config.resources.gpu }}
            nvidia.com/gpu: "{{ .config.resources.gpu }}"
            {{ end }}
68
69
70
        env:
        - name: TRAFFIC_TIMEOUT
          value: "{{ .config.traffic.timeout }}"
71
72
73
74
75
      {{- if and .config.dynamo .config.dynamo.enabled }}
        - name: DYNAMO_NAMESPACE
          value: "{{ .config.dynamo.namespace }}"
        - name: DYNAMO_NAME
          value: "{{ .config.dynamo.name }}"
76
77
78
79
80
81
82
      {{- end }}
      {{- if .config.workers }}
        - name: WORKERS
          value: "{{ .config.workers }}"
      {{- end }}
        - name: PORT
          value: "3000"
83
        {{- if $.Values.natsAddr }}
84
        - name: NATS_SERVER
85
86
87
          value: {{ $.Values.natsAddr }}
        {{- end }}
        {{- if $.Values.etcdAddr }}
88
        - name: ETCD_ENDPOINTS
89
90
          value: {{ $.Values.etcdAddr }}
        {{- end }}
91
92
---
{{- end }}