docker容器中运行jar 出现invalid or corrupt jarfile

1,背景:

在本地java开发完毕之后,想要打包成docker镜像,方便安装。由于本地没有docker环境,也懒得装了。有一台测试的linux机器可以使用,所以先在本地打包生成xxx.jar,然后拷贝到有docker环境的linux机器上,生成docker镜像,以及使用镜像做成docker容器。

启动之后,发现报错:

复制代码
invalid or corrupt jarfile
2,思路

从报错信息来看,容器里面已经有了jar包,但是这个jar包不能执行,被破坏掉了。

这边jar的传递有两步,第一是win10系统到Linux系统,第二是Linux本地拷贝到Docker容器。

1)确认本地的jar是否正常(发现本地启动之后,可以正常跑)->那么win10本地的jar是正常的

2)第二步的拷贝,使用dockerfile拷贝,正常情况下,要么命令错误,没有拷贝到容器的镜像里面->确认了一下容器里面是有jar的,那么这个拷贝大概率没有问题。

3)考虑linux里面的xxx.jar已经有问题了。那么大概率是从本地win10系统到Linux的拷贝出问题。

3,原因

在失败之前,有传输jar,生成docker成功过。突然报错有点奇怪。

后来我想起来文件winscp进行文件传输的时候,传输方式有多种,之前是默认的Default()。中间传输别的文件的时候把这个改成了file(文件),使用file方式传输jar,尝试将这边的传输方式改成default,就能够正常跑了。

至于为什么会有这样的问题,暂时还不是特别清楚,猜测是linux系统和win10系统的换行导致?有知道的童鞋欢迎解释一下。

图片来源:winscp图片

mark一下

相关推荐
亚空间仓鼠13 小时前
Docker容器化高可用架构部署方案(六)
docker·容器·架构
前端老曹14 小时前
Docker 从入门到放弃:完整指南
运维·docker·容器
咖啡里的茶i15 小时前
在Docker环境中安装Hadoop cluster 实验报告一
hadoop·docker·容器
汪汪大队u15 小时前
续:从 Docker Compose 到 Kubernetes(2)—— 服务优化与排错
网络·后端·物联网·struts·容器
rabbit_pro15 小时前
Docker compose部署Ollama使用模型
linux·运维·docker
ILL11IIL16 小时前
k8s的pod管理及优化
云原生·容器·kubernetes
咖啡里的茶i17 小时前
在Docker环境中安装Hadoop cluster 实验报告三
docker
笑洋仟17 小时前
docker的overlay2目录占用磁盘空间很大,清理办法
运维·docker·容器
木雷坞17 小时前
2026 年 5 月国内可用 Docker 镜像源列表与配置方法
运维·docker·容器
咖啡里的茶i20 小时前
从云端数据分析平台数据图实验报告
docker