Add K8s deployment files, restructure to backend/frontend
This commit is contained in:
158
k8s/backend/deployment.yaml
Normal file
158
k8s/backend/deployment.yaml
Normal file
@@ -0,0 +1,158 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: todo-backend
|
||||
labels:
|
||||
app: todo-backend
|
||||
spec:
|
||||
replicas: 2
|
||||
selector:
|
||||
matchLabels:
|
||||
app: todo-backend
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: todo-backend
|
||||
spec:
|
||||
containers:
|
||||
- name: todo-backend
|
||||
image: todo-backend:latest
|
||||
imagePullPolicy: IfNotPresent
|
||||
ports:
|
||||
- containerPort: 8080
|
||||
env:
|
||||
- name: SPRING_DATASOURCE_URL
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: todo-config
|
||||
key: DATABASE_URL
|
||||
- name: SPRING_DATASOURCE_USERNAME
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: todo-config
|
||||
key: DATABASE_USERNAME
|
||||
- name: SPRING_DATASOURCE_PASSWORD
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: todo-secret
|
||||
key: DATABASE_PASSWORD
|
||||
- name: SPRING_REDIS_HOST
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: todo-config
|
||||
key: REDIS_HOST
|
||||
- name: SPRING_REDIS_PORT
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: todo-config
|
||||
key: REDIS_PORT
|
||||
resources:
|
||||
requests:
|
||||
memory: "512Mi"
|
||||
cpu: "250m"
|
||||
limits:
|
||||
memory: "1Gi"
|
||||
cpu: "500m"
|
||||
livenessProbe:
|
||||
httpGet:
|
||||
path: /actuator/health
|
||||
port: 8080
|
||||
initialDelaySeconds: 60
|
||||
periodSeconds: 10
|
||||
readinessProbe:
|
||||
httpGet:
|
||||
path: /actuator/health
|
||||
port: 8080
|
||||
initialDelaySeconds: 30
|
||||
periodSeconds: 5
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
name: todo-postgres
|
||||
labels:
|
||||
app: todo-postgres
|
||||
spec:
|
||||
serviceName: todo-postgres
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: todo-postgres
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: todo-postgres
|
||||
spec:
|
||||
containers:
|
||||
- name: postgres
|
||||
image: postgres:15-alpine
|
||||
ports:
|
||||
- containerPort: 5432
|
||||
env:
|
||||
- name: POSTGRES_DB
|
||||
value: building_materials
|
||||
- name: POSTGRES_USER
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: todo-config
|
||||
key: DATABASE_USERNAME
|
||||
- name: POSTGRES_PASSWORD
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: todo-secret
|
||||
key: DATABASE_PASSWORD
|
||||
volumeMounts:
|
||||
- name: postgres-data
|
||||
mountPath: /var/lib/postgresql/data
|
||||
- name: init-sql
|
||||
mountPath: /docker-entrypoint-initdb.d
|
||||
resources:
|
||||
requests:
|
||||
memory: "256Mi"
|
||||
cpu: "100m"
|
||||
limits:
|
||||
memory: "512Mi"
|
||||
cpu: "500m"
|
||||
volumes:
|
||||
- name: postgres-data
|
||||
emptyDir: {}
|
||||
- name: init-sql
|
||||
configMap:
|
||||
name: todo-init-sql
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
name: todo-redis
|
||||
labels:
|
||||
app: todo-redis
|
||||
spec:
|
||||
serviceName: todo-redis
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: todo-redis
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: todo-redis
|
||||
spec:
|
||||
containers:
|
||||
- name: redis
|
||||
image: redis:7-alpine
|
||||
ports:
|
||||
- containerPort: 6379
|
||||
command: ["redis-server", "--requirepass", ""]
|
||||
resources:
|
||||
requests:
|
||||
memory: "128Mi"
|
||||
cpu: "50m"
|
||||
limits:
|
||||
memory: "256Mi"
|
||||
cpu: "200m"
|
||||
volumeMounts:
|
||||
- name: redis-data
|
||||
mountPath: /data
|
||||
volumes:
|
||||
- name: redis-data
|
||||
emptyDir: {}
|
||||
98
k8s/backend/init-sql-configmap.yaml
Normal file
98
k8s/backend/init-sql-configmap.yaml
Normal file
@@ -0,0 +1,98 @@
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: todo-init-sql
|
||||
data:
|
||||
init.sql: |
|
||||
-- 初始化数据库脚本
|
||||
-- 此文件会在 PostgreSQL 首次启动时自动执行
|
||||
CREATE TABLE IF NOT EXISTS "user" (
|
||||
id VARCHAR(36) PRIMARY KEY,
|
||||
username VARCHAR(50) NOT NULL UNIQUE,
|
||||
password VARCHAR(255) NOT NULL,
|
||||
real_name VARCHAR(100),
|
||||
phone VARCHAR(20),
|
||||
role VARCHAR(20) DEFAULT 'sales',
|
||||
status INTEGER DEFAULT 1,
|
||||
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS category (
|
||||
id VARCHAR(36) PRIMARY KEY,
|
||||
name VARCHAR(100) NOT NULL,
|
||||
parent_id VARCHAR(36),
|
||||
sort_order INTEGER DEFAULT 0,
|
||||
status INTEGER DEFAULT 1,
|
||||
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS product (
|
||||
id VARCHAR(36) PRIMARY KEY,
|
||||
name VARCHAR(200) NOT NULL,
|
||||
category_id VARCHAR(36),
|
||||
unit VARCHAR(20),
|
||||
price DECIMAL(10,2),
|
||||
stock_quantity INTEGER DEFAULT 0,
|
||||
status INTEGER DEFAULT 1,
|
||||
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS customer (
|
||||
id VARCHAR(36) PRIMARY KEY,
|
||||
name VARCHAR(200) NOT NULL,
|
||||
phone VARCHAR(20),
|
||||
address VARCHAR(500),
|
||||
contact_person VARCHAR(100),
|
||||
remark TEXT,
|
||||
status INTEGER DEFAULT 1,
|
||||
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS "order" (
|
||||
id VARCHAR(36) PRIMARY KEY,
|
||||
order_no VARCHAR(50) NOT NULL UNIQUE,
|
||||
customer_id VARCHAR(36),
|
||||
sales_user_id VARCHAR(36),
|
||||
total_amount DECIMAL(10,2) DEFAULT 0,
|
||||
status VARCHAR(20) DEFAULT 'pending',
|
||||
remark TEXT,
|
||||
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS order_item (
|
||||
id VARCHAR(36) PRIMARY KEY,
|
||||
order_id VARCHAR(36) NOT NULL,
|
||||
product_id VARCHAR(36) NOT NULL,
|
||||
quantity INTEGER NOT NULL,
|
||||
unit_price DECIMAL(10,2) NOT NULL,
|
||||
subtotal DECIMAL(10,2) NOT NULL,
|
||||
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS stock (
|
||||
id VARCHAR(36) PRIMARY KEY,
|
||||
product_id VARCHAR(36) NOT NULL,
|
||||
warehouse VARCHAR(100),
|
||||
quantity INTEGER DEFAULT 0,
|
||||
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS stock_flow (
|
||||
id VARCHAR(36) PRIMARY KEY,
|
||||
product_id VARCHAR(36) NOT NULL,
|
||||
type VARCHAR(20) NOT NULL,
|
||||
quantity INTEGER NOT NULL,
|
||||
remark VARCHAR(500),
|
||||
operator_id VARCHAR(36),
|
||||
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
-- 插入默认管理员
|
||||
INSERT INTO "user" (id, username, password, real_name, role)
|
||||
VALUES ('admin', 'admin', '$2a$10$N.zmdr9k7uOCQb376NoUnuTJ8iAt6Z5EHsM8lE9lBOsl7iAt6Z5EH', '管理员', 'admin')
|
||||
ON CONFLICT (username) DO NOTHING;
|
||||
163
k8s/backend/init.sql
Normal file
163
k8s/backend/init.sql
Normal file
@@ -0,0 +1,163 @@
|
||||
-- 建材销售管家数据库初始化脚本
|
||||
-- PostgreSQL
|
||||
|
||||
-- 1. 用户表
|
||||
CREATE TABLE "users" (
|
||||
"user_id" UUID PRIMARY KEY,
|
||||
"username" VARCHAR(50) NOT NULL,
|
||||
"phone" VARCHAR(20) DEFAULT NULL,
|
||||
"password" VARCHAR(255) DEFAULT NULL,
|
||||
"wechat_openid" VARCHAR(64) DEFAULT NULL,
|
||||
"wechat_unionid" VARCHAR(64) DEFAULT NULL,
|
||||
"alipay_openid" VARCHAR(64) DEFAULT NULL,
|
||||
"role" VARCHAR(20) DEFAULT 'sales',
|
||||
"status" INTEGER DEFAULT 1,
|
||||
"created_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
"updated_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
UNIQUE ("phone"),
|
||||
UNIQUE ("wechat_openid"),
|
||||
UNIQUE ("alipay_openid")
|
||||
);
|
||||
|
||||
-- 2. 商品分类表
|
||||
CREATE TABLE "categories" (
|
||||
"category_id" UUID PRIMARY KEY,
|
||||
"name" VARCHAR(50) NOT NULL,
|
||||
"parent_id" VARCHAR(32) DEFAULT '0',
|
||||
"sort_order" INTEGER DEFAULT 0,
|
||||
"icon" VARCHAR(255) DEFAULT NULL,
|
||||
"status" INTEGER DEFAULT 1,
|
||||
"created_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
"updated_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
-- 默认分类数据
|
||||
INSERT INTO "categories" ("category_id", "name", "parent_id", "sort_order") VALUES
|
||||
('CAT001', '五金建材', '0', 1),
|
||||
('CAT002', '板材', '0', 2),
|
||||
('CAT003', '木门', '0', 3),
|
||||
('CAT004', '地板', '0', 4);
|
||||
|
||||
-- 3. 商品表
|
||||
CREATE TABLE "products" (
|
||||
"product_id" UUID PRIMARY KEY,
|
||||
"category_id" VARCHAR(32) NOT NULL,
|
||||
"name" VARCHAR(100) NOT NULL,
|
||||
"spec" VARCHAR(100) DEFAULT NULL,
|
||||
"unit" VARCHAR(20) DEFAULT '个',
|
||||
"price" DECIMAL(10,2) NOT NULL DEFAULT 0,
|
||||
"cost_price" DECIMAL(10,2) DEFAULT 0,
|
||||
"image_url" VARCHAR(500) DEFAULT NULL,
|
||||
"barcode" VARCHAR(50) DEFAULT NULL,
|
||||
"stock_alert" INTEGER DEFAULT 10,
|
||||
"description" TEXT DEFAULT NULL,
|
||||
"status" INTEGER DEFAULT 1,
|
||||
"created_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
"updated_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
-- 4. 客户表
|
||||
CREATE TABLE "customers" (
|
||||
"customer_id" UUID PRIMARY KEY,
|
||||
"name" VARCHAR(100) NOT NULL,
|
||||
"phone" VARCHAR(20) DEFAULT NULL,
|
||||
"wechat_openid" VARCHAR(64) DEFAULT NULL,
|
||||
"address" VARCHAR(255) DEFAULT NULL,
|
||||
"remark" TEXT DEFAULT NULL,
|
||||
"total_amount" DECIMAL(12,2) DEFAULT 0,
|
||||
"created_by" VARCHAR(32) DEFAULT NULL,
|
||||
"created_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
"updated_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
-- 5. 订单表
|
||||
CREATE TABLE "orders" (
|
||||
"order_id" UUID PRIMARY KEY,
|
||||
"order_no" VARCHAR(32) NOT NULL,
|
||||
"customer_id" VARCHAR(32) DEFAULT NULL,
|
||||
"customer_name" VARCHAR(100) DEFAULT NULL,
|
||||
"customer_phone" VARCHAR(20) DEFAULT NULL,
|
||||
"customer_wechat" VARCHAR(64) DEFAULT NULL,
|
||||
"total_amount" DECIMAL(12,2) NOT NULL DEFAULT 0,
|
||||
"discount_amount" DECIMAL(12,2) DEFAULT 0,
|
||||
"actual_amount" DECIMAL(12,2) NOT NULL DEFAULT 0,
|
||||
"discount_rate" DECIMAL(5,2) DEFAULT 100,
|
||||
"status" INTEGER DEFAULT 1,
|
||||
"payment_method" VARCHAR(20) DEFAULT NULL,
|
||||
"remark" TEXT DEFAULT NULL,
|
||||
"operator_id" VARCHAR(32) NOT NULL,
|
||||
"operator_name" VARCHAR(50) DEFAULT NULL,
|
||||
"created_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
"updated_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
UNIQUE ("order_no")
|
||||
);
|
||||
|
||||
-- 6. 订单明细表
|
||||
CREATE TABLE "order_items" (
|
||||
"item_id" UUID PRIMARY KEY,
|
||||
"order_id" VARCHAR(32) NOT NULL,
|
||||
"product_id" VARCHAR(32) NOT NULL,
|
||||
"product_name" VARCHAR(100) NOT NULL,
|
||||
"product_spec" VARCHAR(100) DEFAULT NULL,
|
||||
"unit" VARCHAR(20) DEFAULT NULL,
|
||||
"price" DECIMAL(10,2) NOT NULL,
|
||||
"quantity" INTEGER NOT NULL DEFAULT 1,
|
||||
"subtotal" DECIMAL(12,2) NOT NULL,
|
||||
"created_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
-- 7. 库存表
|
||||
CREATE TABLE "stock" (
|
||||
"stock_id" UUID PRIMARY KEY,
|
||||
"product_id" VARCHAR(32) NOT NULL,
|
||||
"warehouse_id" VARCHAR(32) DEFAULT 'WH001',
|
||||
"quantity" INTEGER NOT NULL DEFAULT 0,
|
||||
"locked_quantity" INTEGER DEFAULT 0,
|
||||
"updated_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
UNIQUE ("product_id", "warehouse_id")
|
||||
);
|
||||
|
||||
-- 8. 库存流水表
|
||||
CREATE TABLE "stock_flow" (
|
||||
"flow_id" UUID PRIMARY KEY,
|
||||
"product_id" VARCHAR(32) NOT NULL,
|
||||
"type" INTEGER NOT NULL,
|
||||
"quantity" INTEGER NOT NULL,
|
||||
"before_quantity" INTEGER NOT NULL,
|
||||
"after_quantity" INTEGER NOT NULL,
|
||||
"related_id" VARCHAR(32) DEFAULT NULL,
|
||||
"related_type" VARCHAR(20) DEFAULT NULL,
|
||||
"operator_id" VARCHAR(32) NOT NULL,
|
||||
"remark" VARCHAR(255) DEFAULT NULL,
|
||||
"created_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
-- 9. 仓库表
|
||||
CREATE TABLE "warehouses" (
|
||||
"warehouse_id" UUID PRIMARY KEY,
|
||||
"name" VARCHAR(50) NOT NULL,
|
||||
"address" VARCHAR(255) DEFAULT NULL,
|
||||
"remark" VARCHAR(255) DEFAULT NULL,
|
||||
"status" INTEGER DEFAULT 1,
|
||||
"created_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
||||
"updated_at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
||||
);
|
||||
|
||||
-- 默认仓库
|
||||
INSERT INTO "warehouses" ("warehouse_id", "name", "address") VALUES
|
||||
('WH001', '主仓库', '默认仓库');
|
||||
|
||||
-- 创建索引
|
||||
CREATE INDEX idx_products_category ON "products"("category_id");
|
||||
CREATE INDEX idx_products_status ON "products"("status");
|
||||
CREATE INDEX idx_orders_customer ON "orders"("customer_id");
|
||||
CREATE INDEX idx_orders_status ON "orders"("status");
|
||||
CREATE INDEX idx_orders_created ON "orders"("created_at");
|
||||
CREATE INDEX idx_order_items_order ON "order_items"("order_id");
|
||||
CREATE INDEX idx_stock_product ON "stock"("product_id");
|
||||
CREATE INDEX idx_stock_flow_product ON "stock_flow"("product_id");
|
||||
CREATE INDEX idx_stock_flow_created ON "stock_flow"("created_at");
|
||||
|
||||
-- 创建测试用户 (密码: admin123)
|
||||
INSERT INTO "users" ("user_id", "username", "phone", "password", "role")
|
||||
VALUES ('USER001', '管理员', '13800138000', '$2a$10$N.zmdr9k7uOCQb376NoUnuTJ8iAt6Z5EHsM8lE9lBOsl7iAt6Z5EH', 'admin');
|
||||
38
k8s/backend/service.yaml
Normal file
38
k8s/backend/service.yaml
Normal file
@@ -0,0 +1,38 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: todo-backend
|
||||
spec:
|
||||
type: ClusterIP
|
||||
selector:
|
||||
app: todo-backend
|
||||
ports:
|
||||
- port: 8080
|
||||
targetPort: 8080
|
||||
protocol: TCP
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: todo-postgres
|
||||
spec:
|
||||
type: ClusterIP
|
||||
selector:
|
||||
app: todo-postgres
|
||||
ports:
|
||||
- port: 5432
|
||||
targetPort: 5432
|
||||
protocol: TCP
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: todo-redis
|
||||
spec:
|
||||
type: ClusterIP
|
||||
selector:
|
||||
app: todo-redis
|
||||
ports:
|
||||
- port: 6379
|
||||
targetPort: 6379
|
||||
protocol: TCP
|
||||
10
k8s/configmap.yaml
Normal file
10
k8s/configmap.yaml
Normal file
@@ -0,0 +1,10 @@
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: todo-config
|
||||
data:
|
||||
DATABASE_URL: "jdbc:postgresql://todo-postgres:5432/building_materials"
|
||||
DATABASE_USERNAME: "postgres"
|
||||
REDIS_HOST: "todo-redis"
|
||||
REDIS_PORT: "6379"
|
||||
API_BASE_URL: "http://todo-backend:8080"
|
||||
47
k8s/frontend/deployment.yaml
Normal file
47
k8s/frontend/deployment.yaml
Normal file
@@ -0,0 +1,47 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: todo-frontend
|
||||
labels:
|
||||
app: todo-frontend
|
||||
spec:
|
||||
replicas: 2
|
||||
selector:
|
||||
matchLabels:
|
||||
app: todo-frontend
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: todo-frontend
|
||||
spec:
|
||||
containers:
|
||||
- name: todo-frontend
|
||||
image: todo-frontend:latest
|
||||
imagePullPolicy: IfNotPresent
|
||||
ports:
|
||||
- containerPort: 80
|
||||
env:
|
||||
- name: API_BASE_URL
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: todo-config
|
||||
key: API_BASE_URL
|
||||
resources:
|
||||
requests:
|
||||
memory: "64Mi"
|
||||
cpu: "50m"
|
||||
limits:
|
||||
memory: "128Mi"
|
||||
cpu: "200m"
|
||||
livenessProbe:
|
||||
httpGet:
|
||||
path: /
|
||||
port: 80
|
||||
initialDelaySeconds: 10
|
||||
periodSeconds: 10
|
||||
readinessProbe:
|
||||
httpGet:
|
||||
path: /
|
||||
port: 80
|
||||
initialDelaySeconds: 5
|
||||
periodSeconds: 5
|
||||
13
k8s/frontend/service.yaml
Normal file
13
k8s/frontend/service.yaml
Normal file
@@ -0,0 +1,13 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: todo-frontend
|
||||
spec:
|
||||
type: NodePort
|
||||
selector:
|
||||
app: todo-frontend
|
||||
ports:
|
||||
- port: 80
|
||||
targetPort: 80
|
||||
protocol: TCP
|
||||
nodePort: 30080
|
||||
7
k8s/secret.yaml
Normal file
7
k8s/secret.yaml
Normal file
@@ -0,0 +1,7 @@
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
name: todo-secret
|
||||
type: Opaque
|
||||
stringData:
|
||||
DATABASE_PASSWORD: "postgres"
|
||||
Reference in New Issue
Block a user