我正在尝试在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"
答案 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));