【Docker 问题】Docker 与 Node.js 冲突问题

问题描述

今天在运行 docker 指令的时候,出现了这样的输出:

css 复制代码
Saved file tree to doc-filelist.js
Copied JS to doc-script.js
Compiled CSS to doc-style.css

首先想到的是通过指令来检查 Docker 有没有正确的工作:

bash 复制代码
systemctl status docker

输出显示 Docker 服务正常运行:

bash 复制代码
● docker.service - Docker Application Container Engine
   Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; preset: e>)
   Active: active (running) since Fri 2024-07-12 21:54:40 CST; 11h ago
   TriggeredBy: ● docker.socket
   Docs: https://docs.docker.com
   Main PID: 2833 (dockerd)
   Tasks: 306
   Memory: 147.7M (peak: 243.1M swap: 22.3M swap peak: 22.3M)
   CPU: 6min 47ms
   CGroup: /system.slice/docker.service
           ├─2833 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/cont>
           ├─3249 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-por>
           ├─3250 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-por>
           ├─3277 /usr/bin/docker-proxy -proto tcp -host-ip :: -host-port 109>
           ├─3278 /usr/bin/docker-proxy -proto tcp -host-ip :: -host-port 920>
           ├─3316 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-por>
           ├─3326 /usr/bin/docker-proxy -proto tcp -host-ip :: -host-port 900>
           ├─3332 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-por>
           ├─3352 /usr/bin/docker-proxy -proto tcp -host-ip :: -host-port 192>
           ├─3369 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-por>
           ├─3374 /usr/bin/docker-proxy -proto tcp -host-ip :: -host-port 800>
           ├─3475 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-por>
           ├─3500 /usr/bin/docker-proxy -proto tcp -host-ip :: -host-port 192>

然后尝试用绝对地址来指定使用 Docker:

bash 复制代码
/usr/bin/docker pull nezha123/titan-edge
/usr/bin/docker images

输出显示 Docker 正常工作:

bash 复制代码
Using default tag: latest
latest: Pulling from nezha123/titan-edge
Digest: sha256:5669cf5a88c91ce0d666d8d98fb1d8e601bcf6e096e39a0eadba4bae72d5a88e
Status: Image is up to date for nezha123/titan-edge:latest
docker.io/nezha123/titan-edge:latest
REPOSITORY                                  TAG       IMAGE ID       CREATED         SIZE
nezha123/titan-edge                         latest    488c7d20bfb2   7 days ago      571MB

回看上面的输出,觉得可能是 Node.js 的问题,因为不正确的输出看起来非常像是 docker.js 的输出,而不是 Docker 容器的相关输出。于是尝试卸载 docker.js

bash 复制代码
npm uninstall -g docker

运行 docker 指令时出现以下错误:

bash 复制代码
bash: /root/.nvm/versions/node/v20.13.0/bin/docker: 没有那个文件或目录

现在问题就已经很清晰了,docker 指令被 nvm 识别,而不是被 Docker 识别。系统中安装了 nvm 用来管理 Node.js 的版本,现在最简单的方案就是切换一下 Node.js 的版本:

bash 复制代码
nvm use 22.1.0

然后再次运行 docker 指令:

bash 复制代码
docker images
docker ps -a

输出显示 Docker 正常工作:

bash 复制代码
REPOSITORY                                  TAG       IMAGE ID       CREATED         SIZE
nezha123/titan-edge                         latest    488c7d20bfb2   7 days ago      571MB

解决方案

既想要使用 Docker 又想要特定版本的 Node.js,这种情况可以在出问题的版本上清除所有与 Docker 相关的内容:

bash 复制代码
npm uninstall -g docker \
npm remove docker \
npm remove dockerjs \
npm remove docker.js \
npm remove dock \
npm remove doc \
npm remove docker.js 

需要非常注意!!!这种操作会将这个 Node.js 版本下的所有与 Docker 相关的内容全部删除掉:

bash 复制代码
nvm use 20.13.0
npm uninstall -g docker \
npm remove docker \
npm remove dockerjs \
npm remove docker.js \
npm remove dock \
npm remove doc \
npm remove docker.js 

再次运行这个指令,我们就可以看到在清除掉与 Docker 相关的内容以后,即使在出问题的版本上依旧可以正确使用 Docker 指令:

bash 复制代码
docker images
bash 复制代码
REPOSITORY                                  TAG       IMAGE ID       CREATED         SIZE
nezha123/titan-edge                         latest    488c7d20bfb2   7 days ago      571MB
相关推荐
栗子~~4 小时前
docker-compose的方式搭建 kafka KRaft 模式集群
docker·kafka·linq
周杰伦_Jay6 小时前
详细介绍:持续集成与持续部署(CI/CD)技术细节(关键实践、CI/CD管道、优势与挑战)
程序人生·ci/cd·docker·微服务·云原生·容器·人机交互
骑台风走9 小时前
ubunut22.04安装docker(基于阿里云 Docker 镜像源安装 Docker)
阿里云·docker·容器
仇辉攻防10 小时前
【云安全】云原生-Docker(五)容器逃逸之漏洞利用
安全·web安全·网络安全·docker·云原生·容器·安全性测试
SomeBottle14 小时前
【小记】在 Google Colab 等平台上运行 GPU 容器
linux·python·docker·学习笔记·容器化·斩虫
风霜不见闲沉月16 小时前
Docker常用知识点问题
docker
三天不学习18 小时前
Docker 系列之 docker-compose 容器编排详解
docker·容器·docker-compose
一夜白头催人泪18 小时前
【阿里云】使用docker安装nginx后可以直接访问
nginx·阿里云·docker
mcharleylei1 天前
Centos 安装docker
linux·docker·centos
l1x1n01 天前
信息收集 CTF 1 挑战通关指南
笔记·python·docker