mirror of
https://github.com/Wei-Shaw/claude-relay-service.git
synced 2026-01-22 16:43:35 +00:00
fix: 简化为root用户运行,彻底解决权限问题
- 移除claude用户创建,直接使用root用户运行 - 删除所有复杂的权限设置和chown操作 - 恢复简单的sed命令修改配置文件 - 移除调试权限信息输出 - 简化Dockerfile,减少构建复杂度 - 确保所有文件操作都有完整权限 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
24
Dockerfile
24
Dockerfile
@@ -13,10 +13,6 @@ RUN apk add --no-cache \
|
|||||||
sed \
|
sed \
|
||||||
&& rm -rf /var/cache/apk/*
|
&& rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
# 👤 创建应用用户
|
|
||||||
RUN addgroup -g 1001 -S nodejs && \
|
|
||||||
adduser -S claude -u 1001 -G nodejs
|
|
||||||
|
|
||||||
# 📁 设置工作目录
|
# 📁 设置工作目录
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
@@ -28,30 +24,22 @@ RUN npm ci --only=production && \
|
|||||||
npm cache clean --force
|
npm cache clean --force
|
||||||
|
|
||||||
# 📋 复制应用代码
|
# 📋 复制应用代码
|
||||||
COPY --chown=claude:nodejs . .
|
COPY . .
|
||||||
|
|
||||||
# 🔧 复制并设置启动脚本权限
|
# 🔧 复制并设置启动脚本权限
|
||||||
COPY --chown=claude:nodejs docker-entrypoint.sh /usr/local/bin/
|
COPY docker-entrypoint.sh /usr/local/bin/
|
||||||
RUN chmod +x /usr/local/bin/docker-entrypoint.sh
|
RUN chmod +x /usr/local/bin/docker-entrypoint.sh
|
||||||
|
|
||||||
# 📁 创建必要目录并设置权限 - 一次性解决所有权限问题
|
# 📁 创建必要目录
|
||||||
RUN mkdir -p logs data temp && \
|
RUN mkdir -p logs data temp
|
||||||
chown -R claude:nodejs /app && \
|
|
||||||
chmod 775 /app && \
|
|
||||||
chmod 775 /app/logs /app/data /app/temp /app/config
|
|
||||||
|
|
||||||
# 🔧 预先创建配置文件避免权限问题
|
# 🔧 预先创建配置文件
|
||||||
RUN if [ ! -f "/app/config/config.js" ] && [ -f "/app/config/config.example.js" ]; then \
|
RUN if [ ! -f "/app/config/config.js" ] && [ -f "/app/config/config.example.js" ]; then \
|
||||||
cp /app/config/config.example.js /app/config/config.js; \
|
cp /app/config/config.example.js /app/config/config.js; \
|
||||||
fi && \
|
fi && \
|
||||||
if [ ! -f "/app/.env" ] && [ -f "/app/.env.example" ]; then \
|
if [ ! -f "/app/.env" ] && [ -f "/app/.env.example" ]; then \
|
||||||
cp /app/.env.example /app/.env; \
|
cp /app/.env.example /app/.env; \
|
||||||
fi && \
|
fi
|
||||||
chown claude:nodejs /app/config/config.js /app/.env 2>/dev/null || true && \
|
|
||||||
chmod 664 /app/config/config.js /app/.env 2>/dev/null || true
|
|
||||||
|
|
||||||
# 🔐 切换到非 root 用户
|
|
||||||
USER claude
|
|
||||||
|
|
||||||
# 🌐 暴露端口
|
# 🌐 暴露端口
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
|
|||||||
@@ -44,32 +44,10 @@ if [ -f "/app/.env" ]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 使用更安全的方式更新 .env 文件 - 创建临时文件避免sed权限问题
|
# 直接使用sed修改.env文件 - root用户无权限问题
|
||||||
ENV_TEMP="/tmp/env_temp_$$"
|
sed -i "s/JWT_SECRET=.*/JWT_SECRET=${JWT_SECRET}/" /app/.env
|
||||||
|
sed -i "s/ENCRYPTION_KEY=.*/ENCRYPTION_KEY=${ENCRYPTION_KEY}/" /app/.env
|
||||||
# 替换JWT_SECRET
|
sed -i "s/REDIS_HOST=.*/REDIS_HOST=redis/" /app/.env
|
||||||
awk -v new_secret="$JWT_SECRET" '
|
|
||||||
/^JWT_SECRET=/ { print "JWT_SECRET=" new_secret; next }
|
|
||||||
{ print }
|
|
||||||
' /app/.env > "$ENV_TEMP"
|
|
||||||
|
|
||||||
# 替换ENCRYPTION_KEY
|
|
||||||
awk -v new_key="$ENCRYPTION_KEY" '
|
|
||||||
/^ENCRYPTION_KEY=/ { print "ENCRYPTION_KEY=" new_key; next }
|
|
||||||
{ print }
|
|
||||||
' "$ENV_TEMP" > "$ENV_TEMP.2"
|
|
||||||
|
|
||||||
# 替换REDIS_HOST
|
|
||||||
awk '
|
|
||||||
/^REDIS_HOST=/ { print "REDIS_HOST=redis"; next }
|
|
||||||
{ print }
|
|
||||||
' "$ENV_TEMP.2" > "$ENV_TEMP.3"
|
|
||||||
|
|
||||||
# 复制回原文件
|
|
||||||
cp "$ENV_TEMP.3" /app/.env
|
|
||||||
|
|
||||||
# 清理临时文件
|
|
||||||
rm -f "$ENV_TEMP" "$ENV_TEMP.2" "$ENV_TEMP.3"
|
|
||||||
|
|
||||||
echo "✅ .env 已配置"
|
echo "✅ .env 已配置"
|
||||||
else
|
else
|
||||||
@@ -85,10 +63,6 @@ export ENCRYPTION_KEY
|
|||||||
if [ ! -f "/app/data/init.json" ]; then
|
if [ ! -f "/app/data/init.json" ]; then
|
||||||
echo "📋 首次启动,执行初始化设置..."
|
echo "📋 首次启动,执行初始化设置..."
|
||||||
|
|
||||||
# 调试权限信息
|
|
||||||
echo "🔍 当前用户: $(whoami)"
|
|
||||||
echo "🔍 data 目录权限: $(ls -ld /app/data 2>/dev/null || echo 'directory not found')"
|
|
||||||
echo "🔍 data 目录内容: $(ls -la /app/data 2>/dev/null || echo 'directory empty or not accessible')"
|
|
||||||
|
|
||||||
# 如果设置了环境变量,显示提示
|
# 如果设置了环境变量,显示提示
|
||||||
if [ -n "$ADMIN_USERNAME" ] || [ -n "$ADMIN_PASSWORD" ]; then
|
if [ -n "$ADMIN_USERNAME" ] || [ -n "$ADMIN_PASSWORD" ]; then
|
||||||
|
|||||||
Reference in New Issue
Block a user