fix
This commit is contained in:
@@ -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
|
WORKDIR /app
|
||||||
|
|
||||||
# 复制 go mod 文件
|
# 安装必要的包
|
||||||
|
RUN apk add --no-cache git tzdata
|
||||||
|
|
||||||
|
# 复制模块文件
|
||||||
COPY go.mod go.sum ./
|
COPY go.mod go.sum ./
|
||||||
|
|
||||||
# 下载依赖
|
# 下载依赖
|
||||||
@@ -13,30 +20,45 @@ RUN go mod download
|
|||||||
# 复制源代码
|
# 复制源代码
|
||||||
COPY . .
|
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
|
RUN apk --no-cache add tzdata curl
|
||||||
|
|
||||||
# 设置工作目录
|
|
||||||
WORKDIR /root/
|
|
||||||
|
|
||||||
# 复制可执行文件
|
|
||||||
COPY --from=builder /app/worker .
|
|
||||||
|
|
||||||
# 复制配置文件
|
|
||||||
COPY --from=builder /app/config.yaml .
|
|
||||||
COPY --from=builder /app/configs ./configs
|
|
||||||
|
|
||||||
# 设置时区
|
# 设置时区
|
||||||
ENV TZ=Asia/Shanghai
|
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
|
# 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"]
|
||||||
|
|||||||
@@ -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);
|
|
||||||
Reference in New Issue
Block a user