3 Commits

Author SHA1 Message Date
OpenClaw Agent
05a39bd495 feat(docker): 添加生产环境 Docker Compose 配置
- 使用预编译镜像 ouaone/sms-receiver-go:latest
- 自动数据卷挂载(data/ 和 logs/)
- 只读配置文件挂载
- 健康检查和资源限制配置
- 完整的使用说明文档
2026-02-12 11:13:39 +08:00
OpenClaw Agent
ebe9d61665 fix(docker): 复制 templates 和 static 目录到运行时镜像
- 修复容器启动时找不到模板文件导致崩溃的问题
- 添加 COPY 指令复制 templates/ 和 static/ 目录
- 验证容器可正常启动并通过健康检查
2026-02-12 00:59:46 +08:00
OpenClaw Agent
69814a3822 docs: 更新 README.md 添加 v2.0.1 变更日志 2026-02-08 23:15:44 +08:00
3 changed files with 113 additions and 0 deletions

View File

@@ -49,6 +49,10 @@ WORKDIR /app
COPY --from=builder /app/sms-receiver . COPY --from=builder /app/sms-receiver .
COPY --from=builder /app/config.example.yaml config.yaml COPY --from=builder /app/config.example.yaml config.yaml
# 复制运行时需要的目录(模板和静态资源)
COPY --from=builder /app/templates ./templates
COPY --from=builder /app/static ./static
# 创建数据目录并设置权限 # 创建数据目录并设置权限
RUN mkdir -p /app/data /app/logs && \ RUN mkdir -p /app/data /app/logs && \
chown -R appuser:appuser /app chown -R appuser:appuser /app

View File

@@ -464,6 +464,18 @@ MIT License
## 📝 更新日志 ## 📝 更新日志
### [v2.0.1] - 2026-02-08
#### 🐛 Bug 修复
- ✅ 修复登录会话创建失败问题(`securecookie: the value is not valid`
- ✅ 回退密钥处理逻辑确保向后兼容性
- ✅ 改进会话初始化错误处理
#### 🔧 兼容性
- ✅ 与 v2.0.0 Cookie 完全兼容,无需清除
- ✅ 支持 `/api/v1/*``/api/*` 路由
- ✅ 密钥长度不足时仅记录警告
### [v2.0.0] - 2026-02-08 ### [v2.0.0] - 2026-02-08
#### 🔴 高优先级 (6项) #### 🔴 高优先级 (6项)

View File

@@ -0,0 +1,97 @@
# SmsReceiver-go 生产环境 Docker Compose 配置
# 使用预编译好的 Docker 镜像,无需本地编译
#
# 快速启动:
# 1. 复制配置文件cp config.example.yaml config.yaml
# 2. 根据需要修改 config.yaml数据库路径、API Token 等)
# 3. 启动服务docker compose -f docker-compose.production.yml up -d
#
# 访问地址http://localhost:28001
# 默认账号admin / admin123
services:
sms-receiver:
# 使用 Docker Hub 上的预编译镜像
image: ouaone/sms-receiver-go:latest
# 或指定版本image: ouaone/sms-receiver-go:v2.0.2
container_name: sms-receiver-go
# 自动重启策略
restart: unless-stopped
# 端口映射
ports:
- "28001:28001"
# 数据卷挂载
volumes:
# 数据库目录(容器内 /app/data
- ./data:/app/data
# 日志目录(容器内 /app/logs
- ./logs:/app/logs
# 配置文件(只读挂载)
- ./config.yaml:/app/config.yaml:ro
# 环境变量
environment:
- TZ=Asia/Shanghai
# 健康检查
healthcheck:
test: ["CMD", "wget", "--no-verbose", "--tries=1", "--spider", "http://localhost:28001/health"]
interval: 30s # 每 30 秒检查一次
timeout: 3s # 超时时间 3 秒
retries: 3 # 失败 3 次后标记为不健康
start_period: 5s # 容器启动后 5 秒开始检查
# 网络
networks:
- sms-network
# 资源限制(可选)
deploy:
resources:
limits:
cpus: '0.5'
memory: 128M
reservations:
cpus: '0.1'
memory: 32M
networks:
sms-network:
driver: bridge
# 使用说明:
#
# 1. 首次使用前,创建配置文件:
# cp config.example.yaml config.yaml
#
# 2. 编辑 config.yaml 配置:
# - data_path: /app/data (数据库名称,无需修改)
# - admin_password: admin123 (修改为强密码,或使用 password_hash
# - api_tokens: 添加你的 TranspondSms APP 的 Token 配置
#
# 3. 启动服务:
# docker compose -f docker-compose.production.yml up -d
#
# 4. 查看日志:
# docker compose -f docker-compose.production.yml logs -f
#
# 5. 停止服务:
# docker compose -f docker-compose.production.yml down
#
# 6. 更新镜像:
# docker compose -f docker-compose.production.yml pull
# docker compose -f docker-compose.production.yml up -d
#
# 目录结构示例:
# SmsReceiver-go/
# ├── docker-compose.production.yml (本文件)
# ├── config.yaml (配置文件,需自行创建)
# ├── config.example.yaml (配置示例)
# ├── data/ (自动创建,存放数据库)
# └── logs/ (自动创建,存放日志)