erp-java/services/aftersale-service/k8s/deployment.yaml

209 lines
5.3 KiB
YAML

apiVersion: apps/v1
kind: Deployment
metadata:
name: aftersale-service
namespace: erp
labels:
app: aftersale-service
version: v1
module: after-sale-management
spec:
replicas: 3
selector:
matchLabels:
app: aftersale-service
template:
metadata:
labels:
app: aftersale-service
version: v1
spec:
affinity:
podAntiAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 100
podAffinityTerm:
labelSelector:
matchExpressions:
- key: app
operator: In
values:
- aftersale-service
topologyKey: kubernetes.io/hostname
containers:
- name: aftersale-service
image: erp-aftersale-service:latest
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8087
name: http
protocol: TCP
env:
- name: AFTER_SALE_SERVICE_PORT
value: "8087"
- name: NACOS_HOST
value: "nacos.erp.svc.cluster.local"
- name: NACOS_PORT
value: "8848"
- name: NACOS_NAMESPACE
value: "public"
- name: PROFILE
value: "prod"
# 数据库配置
- name: DB_HOST
value: "mysql.erp.svc.cluster.local"
- name: DB_PORT
value: "3306"
- name: DB_NAME
value: "erp_db"
- name: DB_USER
valueFrom:
secretKeyRef:
name: erp-db-secret
key: username
- name: DB_PASSWORD
valueFrom:
secretKeyRef:
name: erp-db-secret
key: password
# Redis配置
- name: REDIS_HOST
value: "redis.erp.svc.cluster.local"
- name: REDIS_PORT
value: "6379"
- name: REDIS_PASSWORD
valueFrom:
secretKeyRef:
name: erp-redis-secret
key: password
# Feign服务URL
- name: ORDER_SERVICE_URL
value: "http://order-service"
- name: INVENTORY_SERVICE_URL
value: "http://inventory-service"
- name: FINANCE_SERVICE_URL
value: "http://finance-service"
# JVM配置
- name: JAVA_OPTS
value: "-Xms512m -Xmx1024m -XX:+UseG1GC -XX:MaxGCPauseMillis=200 -XX:+UnlockExperimentalVMOptions -XX:+UseContainerSupport"
resources:
requests:
memory: "512Mi"
cpu: "250m"
limits:
memory: "1Gi"
cpu: "1000m"
livenessProbe:
httpGet:
path: /actuator/health
port: 8087
initialDelaySeconds: 60
periodSeconds: 10
timeoutSeconds: 5
failureThreshold: 3
readinessProbe:
httpGet:
path: /actuator/health
port: 8087
initialDelaySeconds: 30
periodSeconds: 5
timeoutSeconds: 3
failureThreshold: 3
lifecycle:
preStop:
exec:
command: ["sh", "-c", "sleep 5"]
volumeMounts:
- name: timezone
mountPath: /etc/localtime
readOnly: true
- name: logs
mountPath: /app/logs
volumes:
- name: timezone
hostPath:
path: /usr/share/zoneinfo/Asia/Shanghai
- name: logs
emptyDir: {}
---
apiVersion: v1
kind: Service
metadata:
name: aftersale-service
namespace: erp
labels:
app: aftersale-service
annotations:
prometheus.io/scrape: "true"
prometheus.io/port: "8087"
prometheus.io/path: "/actuator/prometheus"
spec:
type: ClusterIP
ports:
- port: 8087
targetPort: 8087
protocol: TCP
name: http
selector:
app: aftersale-service
---
apiVersion: autoscaling/v2
kind: HorizontalPodAutoscaler
metadata:
name: aftersale-service-hpa
namespace: erp
spec:
scaleTargetRef:
apiVersion: apps/v1
kind: Deployment
name: aftersale-service
minReplicas: 2
maxReplicas: 10
metrics:
- type: Resource
resource:
name: cpu
target:
type: Utilization
averageUtilization: 70
- type: Resource
resource:
name: memory
target:
type: Utilization
averageUtilization: 80
behavior:
scaleDown:
stabilizationWindowSeconds: 300
policies:
- type: Percent
value: 10
periodSeconds: 60
scaleUp:
stabilizationWindowSeconds: 0
policies:
- type: Percent
value: 100
periodSeconds: 15
- type: Pods
value: 4
periodSeconds: 15
selectPolicy: Max
---
# ServiceMonitor for Prometheus
apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
name: aftersale-service-monitor
namespace: erp
labels:
app: aftersale-service
spec:
selector:
matchLabels:
app: aftersale-service
endpoints:
- port: http
path: /actuator/prometheus
interval: 15s