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月前
|
Shell Docker 容器
|
5月前
|
Oracle Java 关系型数据库
Linux下JDK环境的配置及 bash: /usr/local/java/bin/java: cannot execute binary file: exec format error问题的解决
如果遇到"exec format error"问题,文章建议先检查Linux操作系统是32位还是64位,并确保安装了与系统匹配的JDK版本。如果系统是64位的,但出现了错误,可能是因为下载了错误的JDK版本。文章提供了一个链接,指向Oracle官网上的JDK 17 Linux版本下载页面,并附有截图说明。
Linux下JDK环境的配置及 bash: /usr/local/java/bin/java: cannot execute binary file: exec format error问题的解决
|
6月前
|
SQL Shell API
实时计算 Flink版操作报错合集之任务提交后出现 "cannot run program "/bin/bash": error=1, 不允许操作" ,是什么原因
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
实时计算 Flink版操作报错合集之任务提交后出现 "cannot run program "/bin/bash": error=1, 不允许操作" ,是什么原因
|
4月前
|
网络协议 应用服务中间件 Linux
docker常见报错提示WARNING: IPv4 forwarding is disabled. Networking will not work.或/usr/bin/docker-current:
### 故障与解决方法概览 1. **故障现象**:运行 `docker run -d -P httpd:centos` 时提示“IPv4转发已禁用,网络将无法工作”。 - **解决方法**:通过编辑 `/etc/sysctl.conf` 设置 `net.ipv4.ip_forward=1` 并执行 `sysctl -p` 启用路由转发,然后重启 Docker 服务。
194 0
|
5月前
|
Unix Shell Linux
5-15|Docker报错OCI runtime exec failed: exec failed: unable to start container process: exec: “/bin/ba
5-15|Docker报错OCI runtime exec failed: exec failed: unable to start container process: exec: “/bin/ba
|
6月前
|
Kubernetes Shell Docker
在K8S中,如果容器没有bash命令,如何进⼊容器排查问题?
在K8S中,如果容器没有bash命令,如何进⼊容器排查问题?
|
6月前
|
Shell Docker 容器
在Docker中,如何退出一个镜像的bash,而不终止它?
在Docker中,如何退出一个镜像的bash,而不终止它?
|
6月前
|
Kubernetes 监控 Shell
在K8S中,我们公司用户反应pod连接数非常多,希望看一下这些连接都是什么信息?什么状态?怎么排查?容器里面没有集成bash环境、网络工具,怎么处理?
在K8S中,我们公司用户反应pod连接数非常多,希望看一下这些连接都是什么信息?什么状态?怎么排查?容器里面没有集成bash环境、网络工具,怎么处理?
|
8月前
|
Shell Linux 开发工具
Anaconda安装后报错 -bash: conda: command not found 如何处理
【6月更文挑战第26天】Anaconda安装后报错 -bash: conda: command not found 如何处理
1807 4
|
8月前
|
Shell Linux 开发工具
Anaconda安装后报错 -bash: conda: command not found 如何处理
【6月更文挑战第17天】Anaconda安装后报错 -bash: conda: command not found 如何处理
375 4