docker中pip install or uninstall报错

事件起因

今天开发同学咨询了一个问题,他说在docker的一个运行容器中执行如下命令:

  • cd /usr/lib/python2.7/site-packages/ 该目录下有两个目录,分别是:smart_open 和 samrt_open-1.5.5-py2.7.egg-info
  • rm -rf samrt_open-1.5.5-py2.7.egg-info/ 这时出现报错,报错信息如下:
rm: cannot remove 'smart_open-1.5.5-py2.7.egg-info/': Directory not empty
  • 通过命令ls -l查看该目录下的文件时出现如下错误信息:
ls: cannot access PKG-INFO: No such file or directory
ls: cannot access SOURCES.txt: No such file or directory
ls: cannot access dependency_links.txt: No such file or directory
ls: cannot access installed-files.txt: No such file or directory
ls: cannot access requires.txt: No such file or directory
ls: cannot access top_level.txt: No such file or directory

?????????????? ? ? ? ?         ? PKG-INFO
?????????????? ? ? ? ?         ? SOURCES.txt
?????????????? ? ? ? ?         ? dependency_links.txt
?????????????? ? ? ? ?         ? installed-files.txt
?????????????? ? ? ? ?         ? requires.txt
?????????????? ? ? ? ?         ? top_level.txt
  • 卸载 smart_open: pip uninstall smart_open 出现如下报错信息:
...
OSError: [Errno 39] Directory not empty: "/usr/lib/python2.7/site-packages/smart_open-1.5.5-py2.7.egg-info"

分析原因

  • 查看 docker 的存储驱动
# docker info
Containers: 80
 Running: 37
 Paused: 0
 Stopped: 43
Images: 1342
Server Version: 17.09.0-ce
Storage Driver: overlay
 Backing Filesystem: extfs
 Supports d_type: true
Logging Driver: json-file
Cgroup Driver: cgroupfs
  • 根据开发同学反馈,相同的docker镜像,在MAC本上是没有该问题出现的,查看下MAC本的docker存储驱动
docker info
Containers: 0
 Running: 0
 Paused: 0
 Stopped: 0
Images: 19
Server Version: 17.09.0-ce
Storage Driver: overlay2
 Backing Filesystem: extfs
 Supports d_type: true
 Native Overlay Diff: true
Logging Driver: json-file
Cgroup Driver: cgroupfs
  • 发现linux上docker存储驱动是overlay,而Mac本的存储驱动是overlay2。

比较以上信息,出现本次问题的原因可能是:该问题在docker的overlay存储驱动下可能出现该问题,原因可能是因为overlay存储层并非是完全的隔离,在容器层卸载相关包的时候会导致镜像层的内容无法进行写操作。

处理方式

强制重新安装包

pip install [包名] --ignore-installed [包名]

转载于:https://blog.51cto.com/wutengfei/2161960

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐