我的编程空间,编程开发者的网络收藏夹
学习永远不晚

解决docker运行tomcat提示找不到文件的问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

解决docker运行tomcat提示找不到文件的问题

docker运行tomcat提示找不到文件

问题描述

  • docker课程中,老师是用tomcat镜像来演示docker的一些操作
  • 但同样的操作有的同学是ok的,有的同学就会遇到如下错误

  • 核心信息
Exited(1)

Cannot find /usr/local/tomcat/bin/setclasspath.sh
This 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 -a
CONTAINER ID   IMAGE                                        COMMAND                  CREATED          STATUS          PORTS                                                                                      NAMES
59463bed0fd7   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.sh
else
  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
  fi
fi
  • 可以看到我们的报错就在这里
  • 执行的时候[ -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=false
darwin=false
os400=false
hpux=false
case "`uname`" in
CYGWIN*) cygwin=true;;
Darwin*) darwin=true;;
OS400*) os400=true;;
HP-UX*) hpux=true;;
esac
  • 从这里可以看到os400初始值为false,只有你的uname是OS400的时候才为true
  • 而我们这个环境的uname的值是
[root@59463bed0fd7 ~]# uname
Linux
  • 第三部分:[ -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"
  fi
done
  • 找了半天找了个寂寞?好像是的。那问题到底在哪里呢?我也没法复现。捋一捋
  • 线索:[ -r "$CATALINA_HOME"/bin/setclasspath.sh ] 执行为非0是肯定的
  • 如果文件存在,变量存在,那问题就只能是-r了,权限问题!

解决方法

  • 在docker run命令后加一个--privileged即可
  • --privileged这个参数就是让你容器内的root用户具备拥有真正的root权限。否则容器内的root只是外部的一个普通用户权限。
  • 往上有个文档说是:与faccessat2系统调用有关,由于 runc 中的 bug,如果您的内核不支持 faccessat2,它将失败。这有点难了~看不懂

https://syntaxbug.com/6d684d2afe/

到此这篇关于解决docker运行tomcat提示找不到文件的问题的文章就介绍到这了,更多相关docker运行tomcat提示找不到文件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

解决docker运行tomcat提示找不到文件的问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

解决docker运行tomcat提示找不到文件的问题

这篇文章主要介绍了docker运行tomcat提示找不到文件的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
2023-03-07

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

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

winxp运行msconfig提示找不到文件

问:在Windows XP系统下,运行“msconfig”后,系统提示找不到该文件。但是该文件明明存在于系统分区中,而且可以双击打开。 答:这是因为msconfig.exe存在于 %systemroot% PCHea
2023-06-02

java运行提示找不到主类如何解决

出现找不到主类的错误,一般是因为编译后的class文件或者打包的jar文件中的MANIFEST.MF中指定的主类与实际的主类不一致造成的。解决方法如下:1. 确认编译后的class文件或者打包的jar文件中的MANIFEST.MF文件中指定
2023-10-07

PHP文件丢失?解决找不到文件的问题

当我们开发网站或应用程序时,经常会遇到一种常见的问题,那就是PHP文件丢失的情况。这种问题可能是由于文件路径错误、服务器配置问题或其他原因导致的,但是无论是什么原因,解决这个问题通常需要一些具体的代码示例来帮助我们找到并修复错误。1. 检
PHP文件丢失?解决找不到文件的问题
2024-03-09

idea运行提示java找不到符号怎么解决

"找不到符号"错误通常发生在以下情况下:1. 变量或方法名拼写错误:请确保你正确拼写了变量名或方法名,并且大小写也正确。2. 变量或方法未声明或未导入:请确保你已经声明了变量或方法,并且它们在当前作用域内可见。如果是使用的其他类中的变量或方
2023-08-08

pycharm运行时找不到文件如何解决

当使用PyCharm运行时找不到文件时,可以尝试以下解决方法:1. 检查文件路径:确保文件路径正确。确认文件是否位于正确的项目文件夹或子文件夹中。可以使用绝对路径或相对路径,但要确保路径是正确的。2. 刷新项目:在PyCharm的项目窗口中
2023-09-13

怎么解决python路径错误,运行.py文件,找不到路径的问题

这篇文章主要介绍“怎么解决python路径错误,运行.py文件,找不到路径的问题”,在日常操作中,相信很多人在怎么解决python路径错误,运行.py文件,找不到路径的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对
2023-06-09

ubuntu解压文件找不到文件问题怎么解决

如果在Ubuntu上解压文件时遇到找不到文件的问题,可以尝试以下方法来解决:确保你输入的解压命令是正确的,包括文件名、文件路径等信息。有时候只是输入错误导致找不到文件。确保文件路径是正确的,如果文件在不同的目录下,需要指定完整的路径或切换到
ubuntu解压文件找不到文件问题怎么解决
2024-03-01

如何解决开机提示找不到comctl32.dll的问题

  1、首先到网上下载comctl32.dll文件或者到朋友那边拷贝一下这个文件,然后将下载或者拷贝过来的存在python路径“C:\Windows\System32\目录下”下;2、将文件放http://www.
2023-06-06

开机提示找不到comctl32.dll的问题如何解决

这篇文章主要介绍“开机提示找不到comctl32.dll的问题如何解决”,在日常操作中,相信很多人在开机提示找不到comctl32.dll的问题如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”开机提示找
2023-06-13

win10提示找不到指定文件怎么解决

当Windows 10提示找不到指定文件时,可以尝试以下解决方案:1. 重新启动计算机:有时候文件丢失或错误可能是由于计算机的临时问题引起的。尝试重新启动计算机,看看问题是否得到解决。2. 检查文件路径:确保指定的文件路径是正确的。检查文件
2023-09-08

thinkphp include找不到文件问题怎么解决

这篇文章主要讲解了“thinkphp include找不到文件问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“thinkphp include找不到文件问题怎么解决”吧!1、概述T
2023-07-06

linux中ssh执行脚本提示找不到文件怎么解决

当在Linux中使用SSH执行脚本时,如果提示找不到文件,可能有以下几个原因和解决方法:脚本文件不存在:确保脚本文件存在于正确的位置,并且文件名和路径是正确的。权限问题:确保脚本文件具有可执行权限。可以使用`chmod +x filenam
2023-10-25

windows卸载软件提示找不到文件如何解决

这篇文章主要讲解了“windows卸载软件提示找不到文件如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“windows卸载软件提示找不到文件如何解决”吧!解决方法:方法一、 使用第三方
2023-07-01

命令行运行java的class文件提示找不到或无法加载主类

问题如下TestOne.javapackage moon.star;public class TestOne {public void fTestOne() { System.out.println("I an a method In TestOne cla
命令行运行java的class文件提示找不到或无法加载主类
2014-12-10

Win10 32上安装Win10 64位时运行SETUP提示找不到文件

Win10 guSgMlwr64能否在Win10 32上安装?不能直接安装,会出现“Windows找不到文件 &lsqupythono;G:\sources\setuphpp.exe’请确定文件名是否正确后,再试一次
2023-06-09

编程热搜

目录