Dockerized Spring Boot应用程序中的FileSystemNotFoundException

时间:2019-02-27 00:00:10

标签: java spring-boot docker

我正在尝试在Docker容器中运行的Spring Boot应用程序中加载文件,但出现以下异常:

java.nio.file.FileSystemNotFoundException 
 at com.sun.nio.zipfs.ZipFileSystemProvider.getFileSystem(ZipFileSystemProvider.java:171) ~[zipfs.jar:1.8.0_191] 
   at com.sun.nio.zipfs.ZipFileSystemProvider.getPath(ZipFileSystemProvider.java:157) ~[zipfs.jar:1.8.0_191] 
 at java.nio.file.Paths.get(Paths.java:143) ~[?:1.8.0_191] 
 at app.metrics.collector.util.FileUtils.getContentAsSingleLine(FileUtils.java:17) ~[classes!/:?] 
     at app.metrics.collector.jobs.DbQueryJob.generatePreparedStatement(DbQueryJob.java:54) ~[classes!/:?] 
at app.metrics.collector.jobs.DbQueryJob.execute(DbQueryJob.java:36) ~[classes!/:?] 
  at org.quartz.core.JobRunShell.run(JobRunShell.java:202) [quartz-2.3.0.jar!/:?] 

当我在容器外部执行jar时,不会出现错误。

这是Dockerfile:

FROM openjdk:8-jdk-alpine
ADD build/app.jar app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","app.jar"]

这是加载文件的方法:

    public static String getContentAsSingleLine(String fileName) throws URISyntaxException, IOException {
    String data;
    Path path = Paths.get(FileUtils.class.getClassLoader().getResource(fileName).toURI());
    Stream<String> lines = Files.lines(path);
    data = lines.collect(Collectors.joining(StringUtils.SPACE));
    lines.close();
    return data;
}

该文件位于资源文件夹中:

/src/main/resources/database/file.sql

,传递给该方法的参数为:

"database/file.sql"
  • 有人知道这个问题的原因及其可能的解决方案吗?

2 个答案:

答案 0 :(得分:0)

该异常似乎是在处理zip /存档文件,请确保一次是在加载sql还是其他文件时?

答案 1 :(得分:0)

我认为,通过在容器外部执行jar意味着在IDE中运行项目。然后database/file.sql实际上可以作为文件使用。

在jar中,Paths.get()无法实际使用该文件。

尝试访问资源时,应使用

InputStream in = getClass().getResourceAsStream(fileName);

然后您可以使用java.util.Scanner来收集行:

String data = new Scanner(in)
 .useDelimiter('\n')
 .tokens()
 .collect(Collectors.joining(StringUtils.SPACE));