起因
通过流式任务分析用户访问日志的过程中,需要把用户的远程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.(Reader.java:25) at net.ipip.ipdb.Reader.(Reader.java:21) at net.ipip.ipdb.City.(City.java:17) at com.xxx.xxx.util.IpDbUtils.(IpDbUtils.java:24)
分析
如果IP库拷贝到classes目录下是可以运行的。可以排除是IP库本身的问题,那么为什么maven打包之后就无法运行了呢?
经过网上多番查找,原来是maven-resources-plugin作怪,maven打包时,会编码特定文件导致文件不可用。
解决
maven打包项目过程中pom.xml配置文件里可以配置对项目进行统一编码,但是部分文件可能不需要进行重新编码,例如: IP库文件、证书文件等;重新编码后可能导致文件不可用。
org.apache.maven.plugins maven-resources-plugin ipdbxls
之后。。。一切OK!