返回顶部
首页 > 资讯 > 精选 >docker运行tomcat提示找不到文件如何解决
  • 681
分享到

docker运行tomcat提示找不到文件如何解决

2023-07-05 09:07:17 681人浏览 安东尼
摘要

这篇“Docker运行Tomcat提示找不到文件如何解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“docker运行tom

这篇“Docker运行Tomcat提示找不到文件如何解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“docker运行tomcat提示找不到文件如何解决”文章吧。

    docker运行tomcat提示找不到文件

    问题描述

    docker运行tomcat提示找不到文件如何解决

    • 核心信息

    Exited(1)Cannot find /usr/local/tomcat/bin/setclasspath.shThis file is needed to run this program
    • 一开始也挺费解的,我虽然不上这个课,但也比较好奇,自己始终无法复现,但不断有学员问,我看到就回复,在docker run命令后加一个--privileged即可

    • 但为何呢,不能说的很清楚,因为--privileged这个参数就是让你容器内的root用户具备拥有真正的root权限。否则容器内的root只是外部的一个普通用户权限。

    线索一:容器退出码

    • 从上面的提示可以看到容器退出了,ExitCode是1

    • 1的意思是:

      • 程序错误,或者Dockerfile中引用不存在的文件,如 entrypoint中引用了错误的包

      • 程序错误可以很简单,例如“除以0”,也可以很复杂,比如空引用或者其他程序 crash

    • ExitCode1: Indicates failure due to application error

    • Indicates that the container stopped due to either an application error or an incorrect reference in Dockerfile to a file that is not present in the container.

    • An application error can be as simple as “divide by 0” or as complex as “Reference to a bean name that conflicts with existing, non-compatible bean definition of same name and class.”

    • An incorrect reference in Dockerfile to a file not present in the container can be as simple as a typo (the example below has sample.ja instead of sample.jar)

    • 知道了这个似乎帮助不大,不过有的容器退出码是非常能指向原因的,比如ExitCode 0

    线索二:无法找到文件

    • 这个线索就非常重要了

    • 那为何会无法找到,真的有吗?有的

    • 比如在我这个正常的容器中

    [root@hecs-67651 ~]# docker ps -aCONTAINER ID   IMAGE                                        COMMAND                  CREATED          STATUS          PORTS                                                                                      NAMES59463bed0fd7   tomcat                                       "catalina.sh run"        35 minutes aGo   Up 35 minutes   8080/tcp                                                                                   mytomcat5[root@hecs-67651 ~]# docker exec -it 594 ls /usr/local/tomcat/bin/setclasspath.sh/usr/local/tomcat/bin/setclasspath.sh
    • 那遇到问题的学员为何找不到呢?

    • 我们的这个tomcat镜像在启动的时候会执行一个脚本

    [root@hecs-67651 ~]# docker inspect -f '{{.Config.Cmd}}' tomcat:latest[catalina.sh run]
    • 来看看catalina.sh做了啥

    顺藤摸瓜:catalina.sh

    • 这个shell脚本比较大646行,我就摘录关键部分

    • 你看懂需要懂一些shell

    • 第一部分:报错在哪里

    if $os400; then  # -r will Only work on the os400 if the files are:  # 1. owned by the user  # 2. owned by the PRIMARY group of the user  # this will not work if the user belongs in secondary groups  . "$CATALINA_HOME"/bin/setclasspath.shelse  if [ -r "$CATALINA_HOME"/bin/setclasspath.sh ]; then    . "$CATALINA_HOME"/bin/setclasspath.sh  else    echo "Cannot find $CATALINA_HOME/bin/setclasspath.sh"    echo "This file is needed to run this program"    exit 1  fifi
    • 可以看到我们的报错就在这里

    • 执行的时候[ -r "$CATALINA_HOME"/bin/setclasspath.sh ]这个分支为假就走到了我们的报错中,exit 1

    • 这句话的意思是看 "$CATALINA_HOME"/bin/setclasspath.sh文件是否有read权限

    root@59463bed0fd7:/usr/local/tomcat/bin# ll setclasspath.sh-rwxr-xr-x 1 root root 3342 Mar  6 23:33 setclasspath.sh*
    • 在我这个OK的环境中的权限如上,read是有的

    • 那可能的问题就是在CATALINA_HOME这个变量是否存在

    • 而再往前看我们走到第一个else是因为$os400为假

    第二部分:os400(仅供学习,对本问题没有作用,无需分析)

    cygwin=falsedarwin=falseos400=falsehpux=falsecase "`uname`" inCYGWIN*) cygwin=true;;Darwin*) darwin=true;;OS400*) os400=true;;HP-UX*) hpux=true;;esac
    • 从这里可以看到os400初始值为false,只有你的uname是OS400的时候才为true

    • 而我们这个环境的uname的值是

    [root@59463bed0fd7 ~]# unamelinux
    • 第三部分:[ -r "$CATALINA_HOME"/bin/setclasspath.sh ]

      • 等价于 test -r "$CATALINA_HOME"/bin/setclasspath.sh

      • 我这个OK的环境执行效果

    root@59463bed0fd7:/usr/local/tomcat/bin# [ -r "$CATALINA_HOME"/bin/setclasspath.sh ]root@59463bed0fd7:/usr/local/tomcat/bin# echo $?0
    • 可以看到,是为0的返回值,那自然就不会报错,报错的环境肯定是非0 的

    • 问题的焦点似乎就集中到了$CATALINA_HOME上

    第四部分:$CATALINA_HOME怎么来的

    # 下面的意思是如果没有CATALINA_HOME这个变量就设置为cd "$PRGDIR/.." >/dev/null; pwd 这个pwd的结果[ -z "$CATALINA_HOME" ] && CATALINA_HOME=`cd "$PRGDIR/.." >/dev/null; pwd`# 而PRGDIR是这么来的PRGDIR=`dirname "$PRG"`# PRG来自PRG="$0"  # 就是catalina.sh所在目录# 下面的我也有点看不懂了,大致就是获取目录while [ -h "$PRG" ]; do  ls=`ls -ld "$PRG"`  link=`expr "$ls" : '.*-> \(.*\)$'`  if expr "$link" : '/.*' > /dev/null; then    PRG="$link"  else    PRG=`dirname "$PRG"`/"$link"  fidone
    • 找了半天找了个寂寞?好像是的。那问题到底在哪里呢?我也没法复现。捋一捋

    • 线索:[ -r "$CATALINA_HOME"/bin/setclasspath.sh ] 执行为非0是肯定的

    • 如果文件存在,变量存在,那问题就只能是-r了,权限问题!

    解决方法

    • 在docker run命令后加一个--privileged即可

    • --privileged这个参数就是让你容器内的root用户具备拥有真正的root权限。否则容器内的root只是外部的一个普通用户权限。

    • 往上有个文档说是:与faccessat2系统调用有关,由于 runc 中的 bug,如果您的内核不支持 faccessat2,它将失败。

    以上就是关于“docker运行tomcat提示找不到文件如何解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

    --结束END--

    本文标题: docker运行tomcat提示找不到文件如何解决

    本文链接: https://lsjlt.com/news/351002.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • docker运行tomcat提示找不到文件如何解决
      这篇“docker运行tomcat提示找不到文件如何解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“docker运行tom...
      99+
      2023-07-05
    • 解决docker运行tomcat提示找不到文件的问题
      目录docker运行tomcat提示找不到文件问题描述线索一:容器退出码线索二:无法找到文件顺藤摸瓜:catalina.sh解决方法docker运行tomcat提示找不到文件 问题描...
      99+
      2023-03-07
      docker运行tomcat提示找不到文件 docker启动tomcat提示找不到文件
    • Tomcat运行找不到主类如何解决
      当Tomcat运行时出现找不到主类的错误,可能是由于以下原因导致的:1. Tomcat的启动脚本配置有误:请检查Tomcat的启动脚...
      99+
      2023-09-11
      Tomcat
    • winxp运行msconfig提示找不到文件
      问:在Windows XP系统下,运行“msconfig”后,系统提示找不到该文件。但是该文件明明存在于系统分区中,而且可以双击打开。 答:这是因为msconfig.exe存在于 %systemr...
      99+
      2023-06-02
      winxp 无法运行 msconfig 文件
    • java运行提示找不到主类如何解决
      出现找不到主类的错误,一般是因为编译后的class文件或者打包的jar文件中的MANIFEST.MF中指定的主类与实际的主类不一致造...
      99+
      2023-10-07
      java
    • pycharm运行时找不到文件如何解决
      当使用PyCharm运行时找不到文件时,可以尝试以下解决方法:1. 检查文件路径:确保文件路径正确。确认文件是否位于正确的项目文件夹...
      99+
      2023-09-13
      pycharm
    • tomcat运行不了jsp文件如何解决
      要解决Tomcat无法运行JSP文件的问题,可以尝试以下几个步骤:1. 检查Tomcat配置:确保Tomcat的配置文件中启用了JS...
      99+
      2023-09-27
      tomcat jsp
    • windows卸载软件提示找不到文件如何解决
      这篇文章主要讲解了“windows卸载软件提示找不到文件如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“windows卸载软件提示找不到文件如何解决”吧!解决方法:方法一、 使用第三方...
      99+
      2023-07-01
    • tomcat启动找不到指定文件如何解决
      当Tomcat启动时找不到指定文件,可能是由于以下几个原因:1. 路径配置错误:请确保指定的文件路径是正确的,包括文件名和文件路径的...
      99+
      2023-09-13
      tomcat
    • service.msc运行找不到如何解决
      本篇内容主要讲解“service.msc运行找不到如何解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“service.msc运行找不到如何解决”吧! ...
      99+
      2023-02-02
      service.msc
    • eclipse找不到tomcat如何解决
      如果Eclipse找不到Tomcat服务器,你可以尝试以下解决方法:1. 确保你已经正确安装了Tomcat服务器,并且知道Tomca...
      99+
      2023-09-26
      eclipse tomcat
    • idea运行提示java找不到符号怎么解决
      "找不到符号"错误通常发生在以下情况下:1. 变量或方法名拼写错误:请确保你正确拼写了变量名或方法名,并且大小写也正确。2. 变量或...
      99+
      2023-08-08
      idea java
    • win11提示找不到wt.exe如何解决
      今天小编给大家分享一下win11提示找不到wt.exe如何解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。方法一:首先通过...
      99+
      2023-07-02
    • 电脑运行程序时提示无法找到组件如何解决
      当电脑运行程序时提示无法找到组件,可能是由于以下几个原因:1. 缺少必要的软件或驱动程序:某些程序可能需要特定的软件或驱动程序才能正...
      99+
      2023-10-18
      电脑
    • win10提示找不到指定文件怎么解决
      当Windows 10提示找不到指定文件时,可以尝试以下解决方案:1. 重新启动计算机:有时候文件丢失或错误可能是由于计算机的临时问...
      99+
      2023-09-08
      win10
    • linux中ssh执行脚本提示找不到文件怎么解决
      当在Linux中使用SSH执行脚本时,如果提示找不到文件,可能有以下几个原因和解决方法: 脚本文件不存在:确保脚本文件存在于正确...
      99+
      2023-10-25
      linux ssh
    • tomcat中找不到指定文件怎么解决
      当在Tomcat中找不到指定文件时,可以尝试以下解决方法: 检查文件路径:确保文件路径是正确的。检查文件所在的目录是否存在,并且...
      99+
      2023-10-22
      tomcat
    • tomcat运行不了jsp文件怎么解决
      当Tomcat无法运行JSP文件时,可能是由于以下几个原因导致的: 缺少JSP编译器:确保Tomcat的lib文件夹中有JSP编...
      99+
      2023-10-27
      tomcat jsp
    • windows找不到文件如何解决
      这篇文章主要介绍“windows找不到文件如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“windows找不到文件如何解决”文章能帮助大家解决问题。解决方法:按下“win+R”打开运行输入 r...
      99+
      2023-07-01
    • python找不到文件如何解决
      本文小编为大家详细介绍“python找不到文件如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“python找不到文件如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。解决方法:点击进入“此电脑”。 右...
      99+
      2023-07-01
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作