mirror of
https://github.com/Wei-Shaw/claude-relay-service.git
synced 2026-01-22 16:43:35 +00:00
fix: 彻底修复权限问题,确保data目录可写
- 修复Dockerfile中权限设置顺序,避免递归覆盖 - 设置data目录权限为775,确保claude用户可写入init.json - 为config目录和配置文件设置正确权限(775/664) - 添加调试信息显示用户和目录权限状态 - 移除-R标志,精确控制每个目录的权限 - 确保setup.js能够成功创建/app/data/init.json文件 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -36,9 +36,9 @@ 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 logs data temp && \
|
chown -R claude:nodejs /app && \
|
||||||
chmod -R 755 /app && \
|
chmod 755 /app && \
|
||||||
chmod -R 775 logs data temp
|
chmod 775 logs data temp 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 \
|
||||||
@@ -47,7 +47,8 @@ RUN if [ ! -f "/app/config/config.js" ] && [ -f "/app/config/config.example.js"
|
|||||||
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
|
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 用户
|
# 🔐 切换到非 root 用户
|
||||||
USER claude
|
USER claude
|
||||||
|
|||||||
@@ -65,6 +65,11 @@ 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
|
||||||
echo "📌 检测到预设的管理员凭据"
|
echo "📌 检测到预设的管理员凭据"
|
||||||
|
|||||||
Reference in New Issue
Block a user