This commit is contained in:
2025-09-02 17:13:16 +08:00
parent c7c4ab7a19
commit d73659fed3
2 changed files with 42 additions and 116 deletions

View File

@@ -1,10 +1,17 @@
# 使用官方 Go 镜像作为构建环境
FROM golang:1.23-alpine AS builder
# 第一阶段:构建阶段
FROM golang:1.23.4-alpine AS builder
# 设置Go代理和Alpine镜像源
ENV GOPROXY https://goproxy.cn,direct
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
# 设置工作目录
WORKDIR /app
# 复制 go mod 文件
# 安装必要的包
RUN apk add --no-cache git tzdata
# 复制模块文件
COPY go.mod go.sum ./
# 下载依赖
@@ -13,30 +20,45 @@ RUN go mod download
# 复制源代码
COPY . .
# 构建 Worker 可执行文件
RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o worker cmd/worker/main.go
# 构建应用程序
ARG VERSION=1.0.0
ARG COMMIT=dev
ARG BUILD_TIME
RUN BUILD_TIME=${BUILD_TIME:-$(date -u +"%Y-%m-%dT%H:%M:%SZ")} && \
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build \
-ldflags "-X main.version=${VERSION} -X main.commit=${COMMIT} -X main.date=${BUILD_TIME} -w -s" \
-a -installsuffix cgo \
-o worker \
cmd/worker/main.go
# 使用轻量级的 alpine 镜像作为运行环境
FROM alpine:latest
# 第二阶段:运行阶段
FROM alpine:3.19
# 设置Alpine镜像源
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
# 安装必要的包
RUN apk --no-cache add ca-certificates tzdata
# 设置工作目录
WORKDIR /root/
# 复制可执行文件
COPY --from=builder /app/worker .
# 复制配置文件
COPY --from=builder /app/config.yaml .
COPY --from=builder /app/configs ./configs
RUN apk --no-cache add tzdata curl
# 设置时区
ENV TZ=Asia/Shanghai
# 设置工作目录
WORKDIR /app
# 从构建阶段复制二进制文件
COPY --from=builder /app/worker .
# 复制配置文件
COPY --chown=tyapi:tyapi config.yaml .
COPY --chown=tyapi:tyapi configs/ ./configs/
# 暴露端口(如果需要)
# EXPOSE 8080
# 运行 Worker
CMD ["./worker"]
# 健康检查
HEALTHCHECK --interval=30s --timeout=10s --start-period=60s --retries=3 \
CMD curl -f http://localhost:8080/health || exit 1
# 启动命令
CMD ["./worker", "-env=production"]

View File

@@ -1,96 +0,0 @@
-- 文章系统数据库迁移脚本
-- 创建时间: 2024-01-01
-- 描述: 创建文章相关的数据库表结构
-- 文章分类表
CREATE TABLE IF NOT EXISTS article_categories (
id VARCHAR(36) PRIMARY KEY COMMENT '分类唯一标识',
name VARCHAR(100) NOT NULL COMMENT '分类名称',
description TEXT COMMENT '分类描述',
sort_order INT DEFAULT 0 COMMENT '排序',
active BOOLEAN DEFAULT TRUE COMMENT '是否启用',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
deleted_at TIMESTAMP NULL COMMENT '软删除时间',
INDEX idx_article_categories_active (active),
INDEX idx_article_categories_sort_order (sort_order),
INDEX idx_article_categories_deleted_at (deleted_at)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='文章分类表';
-- 文章标签表
CREATE TABLE IF NOT EXISTS article_tags (
id VARCHAR(36) PRIMARY KEY COMMENT '标签唯一标识',
name VARCHAR(50) NOT NULL COMMENT '标签名称',
color VARCHAR(20) DEFAULT '#1890ff' COMMENT '标签颜色',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
deleted_at TIMESTAMP NULL COMMENT '软删除时间',
UNIQUE KEY uk_article_tags_name (name),
INDEX idx_article_tags_deleted_at (deleted_at)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='文章标签表';
-- 文章表
CREATE TABLE IF NOT EXISTS articles (
id VARCHAR(36) PRIMARY KEY COMMENT '文章唯一标识',
title VARCHAR(200) NOT NULL COMMENT '文章标题',
content TEXT NOT NULL COMMENT '文章内容',
summary VARCHAR(500) COMMENT '文章摘要',
cover_image VARCHAR(500) COMMENT '封面图片',
category_id VARCHAR(36) COMMENT '分类ID',
status ENUM('draft', 'published', 'archived') DEFAULT 'draft' COMMENT '文章状态',
is_featured BOOLEAN DEFAULT FALSE COMMENT '是否推荐',
published_at TIMESTAMP NULL COMMENT '发布时间',
view_count INT DEFAULT 0 COMMENT '阅读量',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
deleted_at TIMESTAMP NULL COMMENT '软删除时间',
INDEX idx_articles_category_id (category_id),
INDEX idx_articles_status (status),
INDEX idx_articles_is_featured (is_featured),
INDEX idx_articles_published_at (published_at),
INDEX idx_articles_created_at (created_at),
INDEX idx_articles_deleted_at (deleted_at),
FOREIGN KEY (category_id) REFERENCES article_categories(id) ON DELETE SET NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='文章表';
-- 文章标签关联表
CREATE TABLE IF NOT EXISTS article_tag_relations (
id VARCHAR(36) PRIMARY KEY COMMENT '关联记录唯一标识',
article_id VARCHAR(36) NOT NULL COMMENT '文章ID',
tag_id VARCHAR(36) NOT NULL COMMENT '标签ID',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
UNIQUE KEY uk_article_tag_relation (article_id, tag_id),
INDEX idx_article_tag_relations_article_id (article_id),
INDEX idx_article_tag_relations_tag_id (tag_id),
FOREIGN KEY (article_id) REFERENCES articles(id) ON DELETE CASCADE,
FOREIGN KEY (tag_id) REFERENCES article_tags(id) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='文章标签关联表';
-- 插入默认分类数据
INSERT INTO article_categories (id, name, description, sort_order, active) VALUES
('cat-001', '技术分享', '技术相关的文章分享', 1, true),
('cat-002', '产品介绍', '产品功能介绍和使用指南', 2, true),
('cat-003', '公司动态', '公司最新动态和新闻', 3, true),
('cat-004', '行业资讯', '行业相关的最新资讯', 4, true),
('cat-005', '用户指南', '用户使用指南和帮助文档', 5, true)
ON DUPLICATE KEY UPDATE
name = VALUES(name),
description = VALUES(description),
sort_order = VALUES(sort_order),
active = VALUES(active);
-- 插入默认标签数据
INSERT INTO article_tags (id, name, color) VALUES
('tag-001', '技术', '#1890ff'),
('tag-002', '产品', '#52c41a'),
('tag-003', '新闻', '#faad14'),
('tag-004', '教程', '#722ed1'),
('tag-005', '更新', '#13c2c2'),
('tag-006', 'API', '#eb2f96'),
('tag-007', '文档', '#fa8c16'),
('tag-008', '公告', '#f5222d')
ON DUPLICATE KEY UPDATE
name = VALUES(name),
color = VALUES(color);