# ---------------------------- # Deployment # ---------------------------- apiVersion: apps/v1 kind: Deployment metadata: name: test-lessie-agents-deployment namespace: test-lessie labels: app: test-lessie-agents environment: test project: lessie spec: replicas: 1 selector: matchLabels: app: test-lessie-agents environment: test project: lessie strategy: type: RollingUpdate # 滚动更新策略 rollingUpdate: maxSurge: 1 # 最大新增副本数(先加) maxUnavailable: 0 # 最大不可用副本数(不减) template: metadata: labels: app: test-lessie-agents environment: test project: lessie spec: imagePullSecrets: - name: dxin-image-repository # 镜像仓库凭证Secret volumes: - name: aws-credentials-volume # aws-credentials 卷文件 configMap: name: aws-credentials - name: google-credentials-volume configMap: name: google-credentials - name: lessie-logs-volume hostPath: path: /data/logs/lessie-agents/ type: DirectoryOrCreate containers: - name: test-lessie-agents # 容器名称 image: uswccr.ccs.tencentyun.com/lessietest/lessie-sourcing-agents:v24_dxin_9042beec_202510271811 # 容器镜像 imagePullPolicy: IfNotPresent # 镜像拉取策略 ,有则不拉 env: - name: POD_NAME valueFrom: fieldRef: fieldPath: metadata.name - name: APP_ENV value: "s1" - name: APP_PORT value: "8000" - name: GUNICORN_WORKERS value: "2" - name: MAX_REQUESTS value: "200" - name: MAX_REQUESTS_JITTER value: "50" ports: - containerPort: 8000 # 容器暴露的端口 resources: requests: cpu: "0.5" # 容器请求分配0.5个CPU核心(这不是实际占用,但调度会以这里进行参考) memory: "2Gi" # 容器请求分配1Gi内存(这会实际预留) limits: cpu: "2" # 最多可以使用2个CPU核心 memory: "8Gi" # 容器最多可以使用8Gi内存 volumeMounts: - name: aws-credentials-volume mountPath: /root/.aws/ - name: google-credentials-volume mountPath: /root/.google/ - name: lessie-logs-volume mountPath: /data/webapps/lessie_sourcing_agents/logs/ subPathExpr: lessie-agents-$(POD_NAME) --- # ---------------------------- # Service # 集群内部:http://test-lessie-agents-svc.test-lessie.svc.cluster.local:8000 # 集群外部:http://:38000 # curl -v -X POST http://43.153.12.208:30800/api/chat/stream -H "Content-Type: application/json" -d '{"message": "hello"}' # ---------------------------- apiVersion: v1 kind: Service metadata: name: test-lessie-agents-svc namespace: test-lessie labels: app: test-lessie-agents environment: test project: lessie spec: type: NodePort selector: # 必须匹配 Deployment 的 labels 才能关联 Pod app: test-lessie-agents environment: test project: lessie ports: - name: http port: 8000 # ClusterIP 内部端口 targetPort: 8000 # 容器端口 nodePort: 30800 # 节点对外端口(30000-32767)