DOCKER镜像启动报no such file or directory问题


概述

在通过dockerfile搭建docker镜像,启动镜像时常常会报no such file or directory提示,今天说明一下异常产生的原因。

原因分析

原因大概分为两类,第一类确实无该文件,第二类文件编码问题

1.文件确实不存在

可能是真的没有该文件,首先要确保此文件存在。
可以通过在DOCKERFILE中切换到该目录,然后运行RUN ls查看文件是否存在来确定,如果文件存在还报该异常,则考虑第二种情况.

...
WORKDIR yourdirectory/
RUN ls

2.文件编码问题

这种情况就比较恶心了,通常情况下我们写dockerfile的entrypoint.sh或其他.sh文件时是在windows系统下写的,所以常常忽略一个问题。

那就是windows使用的编码和linux是不一样的,当我们把文件复制到linux系统时,linux无法识别隐藏的编码造成linux系统无法识别该文件。

可以通过cat -v entrypoint.sh查看文件信息,如果命令中出现^M则代表此文件时windows系统编码文件,这时候则相当于没有该文件所,以会报no such file or directory异常。

是不是很坑,哈哈,这个问题如果没意识到,怎么想也不会想到是编码的问题.

[cluster@cluster202 alpine-nginx]$ cat -v entrypoint.sh
#如果出现下面的^M字符说明是编码问题
#!/bin/bash^M
.....^M
...

3.如何解决

文件不存在情况,则补齐文件,这里就不说明了,可以使用DOCKERFILE的COPY命令。

文件存在情况,很简单,将原来的文件拿出来用notepad++打开,点击编辑,选择格式转换,转换为Unix格式。

再用该文件或者其中的内容替换linux系统中的entrypoint.sh 或其他.sh文件,再次启动docker即可,如此就可以正常调试你的entrypoint.sh脚本啦。

总结

我们常常忽略linux和windows的编码问题,这个问题非常严重,常常给我们带来以下不必要的问题,所以在windows和linux用到文件交互的时候.sh类型文件最好是先转码一下为Unix格式,以避免此类问题带来的困扰.

一盏灯, 一片昏黄; 一简书, 一杯淡茶。 守着那一份淡定, 品读属于自己的寂寞。 保持淡定, 才能欣赏到最美丽的风景! 保持淡定, 人生从此不再寂寞。



   Reprint policy


《DOCKER镜像启动报no such file or directory问题》 by jackromer is licensed under a Creative Commons Attribution 4.0 International License
 Previous
JAVA的EQUAL和==解析 JAVA的EQUAL和==解析
概述 本文主要解析JAVA中equal和==的区别和理解。 Equal 在Object类当中,而Object是所有类的父类,包含在jdk里面,但并不适合绝大多数场景,通常需要重写. public boolean equals(
2019-08-27
Next 
JVM优化 JVM优化
概述 本文主要介紹JVM以及JVM优化和FULL GC 的处理. 什么是JVM JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿
2019-08-27
  目录