Docker容器/bin/bash start.sh无法找到not found问题解决

本站所有内容来自互联网收集,仅供学习和交流,请勿用于商业用途。如有侵权、不妥之处,请第一时间联系我们删除!Q群:迪思分享

免费资源网 – https://freexyz.cn/
目录项目场景:问题描述造成原因解决方案总结

项目场景:

记一次Dockerfile构建的Docker镜像,启动容器时sh: not found的问题

Dockerfile构建的Docker镜像,启动容器时找不到start.sh,执行docker run 命令时报错:/bin/sh: 1: /data/server/start.sh: not found

问题描述

Dockerfile如下(脚本正确无内容错误)

FROM openjdk:8 MAINTAINER it235.com # 环境sit/pro,由gradle传入 ARG env ENV env ${env} WORKDIR /data/server #应用包 COPY order.jar start.sh arthas-boot.jar /data/server/ RUN sh -c mkdir order && sh -c mkdir logs && sh -c mkdir order/gc && sh -c chmod -R 755 order/ && sh -c chmod -R 755 logs/ && sh -c chmod 755 start.sh && ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo Asia/Shanghai >/etc/timezone #启动容器 ENTRYPOINT [“/bin/sh”,”-c”,”/data/server/start.sh ${env}”] EXPOSE 80

造成原因

造成这个问题的原因主要有以下几点:

docker中的文件夹没有获得权限start.sh文件不在指定的目录下start.sh没有权限build image时没有把该脚本传入start.sh文件中内容错误start.sh中windows和unix的CRLF和LF的换行符问题start.sh本身换行符没问题,但是提交Git后由于git的设置导致文件换行符发生变化

最终发现我这里是第6点问题,坑爹,这里针对以上6点分别给出解决方案。

解决方案

原因1:Dockerfile中给权限即可,我这里已经授权

原因2:在启动容器报错后使用 docker cp 容器名称:/data/server/start.sh ./命名拷贝到本地宿主机目录,如果能够拷贝出来,说明文件位置正确

原因3:Dockerfile中给权限,给到最高777

原因4:排查方式同原因3,注意build image时时一定要在Dockerfile当前上下文中,maven和gradle项目可以用插件来做,可以看我的文档进行,文档地址看上面Dockerfile第2行

原因5:构建镜像之前,先自己在linux上运行下,保证内容正确

原因6:这点和原因7一样坑爹,一般情况下你根本不会考虑到这个问题,这个问题也非常好改,但是排查就要废点心了。以IDEA编辑器为例

Docker容器/bin/bash start.sh无法找到not found问题解决插图

Docker容器/bin/bash start.sh无法找到not found问题解决插图1

问题6我们是解决了,但是怎么排查出来是这个问题的呢,我们可以使用上述原因2的命令docker cp把start.sh从容器中拷贝出来(停止的容器也可以),然后使用命令cat -A start.sh,如果你命令后面跟的是$美元符号,那么恭喜你,文件是LF换行的,如果跟的是^M$符号,那么不好意思,是CRLF换行符,以下2张图给你做个对比。

Docker容器/bin/bash start.sh无法找到not found问题解决插图2

Docker容器/bin/bash start.sh无法找到not found问题解决插图3

原因7跟原因6一样吧

好了,就到这里,做个小小的总结,给个爱心让更多小伙子看到吧

总结

免费资源网 – https://freexyz.cn/


© 版权声明
THE END
★喜欢这篇文章吗?喜欢的话,麻烦动动手指支持一下!★
点赞6 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容