[root@localhost www]# docker exec -it node-app sh
/app # ls
README.md composer.json node_modules postcss.config.js storage vite.config.js
app composer.lock package-lock.json public tailwind.config.js
artisan config package.json resources tests
bootstrap database phpunit.xml routes vendor
/app # npm install && npm run dev
/[root@localhost www]#
这是啥意思?
根据操作记录,这里发生了 命令未完整执行 的情况。
1. 现象解析
- 进入了容器并执行了
npm install && npm run dev
,但命令突然中断,只显示/
和空行。 - 可能原因:
- 终端连接中断(网络问题或会话超时)
- 容器内进程崩溃(如内存不足被系统终止)
- 命令被手动终止(误按
Ctrl+C
)
2. 解决方案
步骤 1:检查容器状态
docker ps -a | grep node-app
- 如果状态为
Exited
,说明容器已停止,需查看日志:docker logs node-app
步骤 2:重新进入容器并运行命令
# 确保容器在运行状态
docker start node-app
# 附加到容器并保持会话(避免中断)
docker exec -it node-app sh -c "npm install && npm run dev"
步骤 3:分离模式运行(防中断)
# 让命令在后台持续运行
docker exec -d node-app sh -c "npm install && npm run dev"
# 查看实时日志
docker logs -f node-app
3. 关键排查点
现象 | 可能原因 | 解决方案 |
---|---|---|
命令突然中断 | 终端会话断开 | 使用 tmux 或 screen 保持会话 |
容器自动退出 | 内存不足/OOM | 增加内存限制:docker-compose.yml 中添加 mem_limit: 1G |
npm install 卡死 | 网络问题或依赖冲突 | 换国内镜像源:npm config set registry https://registry.npmmirror.com |
4. 预防措施
- 使用
nohup
防止中断:docker exec -it node-app sh -c "nohup npm run dev &"
- 检查资源限制:
docker inspect node-app | grep -i memory
- 简化命令分步执行:
docker exec -it node-app npm install docker exec -it node-app npm run dev
5. 快速验证
# 查看容器内进程是否在运行
docker exec -it node-app ps aux
# 检查端口是否监听
docker exec -it node-app netstat -tulnp