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:
shaw
2025-07-19 02:48:35 +08:00
parent 3f7234aa91
commit 382efff867
2 changed files with 10 additions and 48 deletions

View File

@@ -44,32 +44,10 @@ if [ -f "/app/.env" ]; then
fi
fi
# 使用更安全的方式更新 .env 文件 - 创建临时文件避免sed权限问题
ENV_TEMP="/tmp/env_temp_$$"
# 替换JWT_SECRET
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"
# 直接使用sed修改.env文件 - root用户无权限问题
sed -i "s/JWT_SECRET=.*/JWT_SECRET=${JWT_SECRET}/" /app/.env
sed -i "s/ENCRYPTION_KEY=.*/ENCRYPTION_KEY=${ENCRYPTION_KEY}/" /app/.env
sed -i "s/REDIS_HOST=.*/REDIS_HOST=redis/" /app/.env
echo "✅ .env 已配置"
else
@@ -85,10 +63,6 @@ export ENCRYPTION_KEY
if [ ! -f "/app/data/init.json" ]; then
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