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
|
||||
|
||||
# 复制 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"]
|
||||
|
||||
@@ -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