AI/openviking: add k8s manifest (Kustomize) and remove redundant Dockerfile

This commit is contained in:
updsv7
2026-06-05 12:59:02 +09:00
parent 1ef1ceb384
commit 3333dba7e6
8 changed files with 140 additions and 11 deletions

View File

@@ -1,11 +0,0 @@
FROM python:3.11-slim
WORKDIR /app
RUN pip install openviking --upgrade --force-reinstall
RUN openviking-server init
EXPOSE 8000
CMD ["openviking-server", "run", "--host", "0.0.0.0", "--port", "8000"]

View File

@@ -0,0 +1,7 @@
apiVersion: v1
kind: Namespace
metadata:
name: openviking
labels:
app.kubernetes.io/name: openviking
app.kubernetes.io/managed-by: kubectl

View File

@@ -0,0 +1,52 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: openviking
namespace: openviking
labels:
app: openviking
spec:
replicas: 1
selector:
matchLabels:
app: openviking
template:
metadata:
labels:
app: openviking
spec:
containers:
- name: openviking
image: ghcr.io/volcengine/openviking:latest
ports:
- containerPort: 8000
protocol: TCP
envFrom:
- configMapRef:
name: openviking-config
resources:
requests:
cpu: 100m
memory: 256Mi
limits:
cpu: 500m
memory: 1Gi
livenessProbe:
httpGet:
path: /ready
port: 1933
initialDelaySeconds: 10
periodSeconds: 30
readinessProbe:
httpGet:
path: /ready
port: 1933
initialDelaySeconds: 5
periodSeconds: 10
volumeMounts:
- name: data
mountPath: /app/data
volumes:
- name: data
persistentVolumeClaim:
claimName: openviking-data

View File

@@ -0,0 +1,16 @@
apiVersion: v1
kind: Service
metadata:
name: openviking
namespace: openviking
labels:
app: openviking
spec:
type: ClusterIP
ports:
- port: 80
targetPort: 8000
protocol: TCP
name: http
selector:
app: openviking

View File

@@ -0,0 +1,14 @@
apiVersion: v1
kind: ConfigMap
metadata:
name: openviking-config
namespace: openviking
data:
OVIKING_PORT: "8000"
OVIKING_HOST: "0.0.0.0"
# 日志级别: debug, info, warn, error
OVIKING_LOG_LEVEL: "info"
# 数据存储路径(容器内)
OVIKING_DATA_DIR: "/app/data"
# 向量模型(可选,注释掉则使用默认模型)
# OVIKING_EMBED_MODEL: "text-embedding-3-large"

View File

@@ -0,0 +1,13 @@
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: openviking-data
namespace: openviking
labels:
app: openviking
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 5Gi

View File

@@ -0,0 +1,22 @@
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: openviking
namespace: openviking
labels:
app: openviking
annotations:
nginx.ingress.kubernetes.io/proxy-body-size: "50m"
spec:
ingressClassName: nginx
rules:
- host: openviking.local
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: openviking
port:
number: 80

View File

@@ -0,0 +1,16 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
namespace: openviking
resources:
- 00-namespace.yaml
- 01-deployment.yaml
- 02-service.yaml
- 03-configmap.yaml
- 04-pvc.yaml
- 05-ingress.yaml
commonLabels:
app.kubernetes.io/name: openviking
app.kubernetes.io/managed-by: kustomize