起因
通过流式任务分析用户访问日志的过程中,需要把用户的远程IP解析成对应的省份和城市。再此过程中需要加载ip库文件。ip库文件统一放到项目src/main/resources的某个目录下,但是在加载过程中报错:
net.ipip.ipdb.InvalidDatabaseException: database file size error
at net.ipip.ipdb.Reader.init(Reader.java:58)
at net.ipip.ipdb.Reader.<init>(Reader.java:25)
at net.ipip.ipdb.Reader.<init>(Reader.java:21)
at net.ipip.ipdb.City.<init>(City.java:17)
at com.xxx.xxx.util.IpDbUtils.<clinit>(IpDbUtils.java:24)
分析
如果IP库拷贝到classes目录下是可以运行的。可以排除是IP库本身的问题,那么为什么maven打包之后就无法运行了呢?
经过网上多番查找,原来是maven-resources-plugin作怪,maven打包时,会编码特定文件导致文件不可用。
解决
maven打包项目过程中pom.xml配置文件里可以配置对项目进行统一编码,但是部分文件可能不需要进行重新编码,例如: IP库文件、证书文件等;重新编码后可能导致文件不可用。
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<configuration>
<nonFilteredFileExtensions>
<!-- 需要过滤那些后缀的文件 -->
<nonFilteredFileExtension>ipdb</nonFilteredFileExtension>
<nonFilteredFileExtension>xls</nonFilteredFileExtension>
</nonFilteredFileExtensions>
</configuration>
</plugin>
之后。。。一切OK!