Docker容器/bin/bash start.sh无法找到not found

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker容器/bin/bash start.sh无法找到not found

项目场景:

记一次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

造成原因

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

  1. docker中的文件夹没有获得权限
  2. start.sh文件不在指定的目录下
  3. start.sh没有权限
  4. build image时没有把该脚本传入
  5. start.sh文件中内容错误
  6. start.sh中windows和unix的CRLF和LF的换行符问题
  7. 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编辑器为例

image.png

image.png

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

image.pngimage.png

  • 原因7跟原因6一样吧

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

目录
相关文章
|
4月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
823 108
|
5月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
444 57
|
2月前
|
Shell Linux 网络安全
宝塔服务器面板部署安装git通过第三方应用安装收费怎么办—bash: git: command not found解决方案-优雅草卓伊凡
宝塔服务器面板部署安装git通过第三方应用安装收费怎么办—bash: git: command not found解决方案-优雅草卓伊凡
453 3
宝塔服务器面板部署安装git通过第三方应用安装收费怎么办—bash: git: command not found解决方案-优雅草卓伊凡
|
2月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
2月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
413 5
|
2月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
215 6
|
5月前
|
存储 监控 Java
如何对迁移到Docker容器中的应用进行性能优化?
如何对迁移到Docker容器中的应用进行性能优化?
359 59