Add K8s deployment files, restructure to backend/frontend

This commit is contained in:
Agent
2026-03-20 05:12:22 +00:00
parent cea86e48a7
commit f70ba958c7
8 changed files with 371 additions and 0 deletions

158
k8s/backend/deployment.yaml Normal file
View 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: {}

View 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
View 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
View 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