服务器升级Nacos2.2.3报错、rocksdb报错问题处理

avatar
作者
筋斗云
阅读量:2

由于系统之前使用的Nacos2.0.4有反序列化漏洞,故需要将Nacos升级到2.2.3版本。
该Nacos在本地运行没有问题,但是在Windows服务器运行就会报错:

rocksdb java.lang.UnsatisfiedLinkError: C:\Users\Administrator\AppData\Local\Temp\2\librocksdbjni5975940319059115965.dll: Can't find dependent libraries 

表面上看是找不到dll文件,于是去百度,发现各种解决办法均无效。

刨根究底,发现这个问题是由于Nacos引用了rocksdb导致的,于是从rocksdb着手解决。

猜想过是因为jar包没有Temp目录的权限,从而导入文件失败导致,直接手动复制文件进目录,已然报错。
后来发现有网友说手动导入rocksdb依赖:

<dependency>             <groupId>org.rocksdb</groupId>             <artifactId>rocksdbjni</artifactId>             <version>版本号改成了跟Nacos依赖相同的版本</version>             <classifier>win64</classifier> </dependency> 

导入后发现这个依赖只是Nacos原有依赖排除掉除win64外的其他版本,并没有什么帮助。

陷入思考……

突然想到,之前旧版本(5.18.4)可以正常使用,这次Nacos2.2.3依赖的7.7.3却无法正常使用,怀疑是导入的依赖与系统(CPU?)不兼容。

于是将导入的rocksdb依赖改为:

<dependency>             <groupId>org.rocksdb</groupId>             <artifactId>rocksdbjni</artifactId>             <version>5.18.4</version>             <classifier>win64</classifier> </dependency> 

也就是改成了Nacos2.0.4依赖的rocksdb。
但是启动报了另外一个错,具体就不贴了,意思就是有一个方法不存在,猜想是7.7.3对5.18.4增加了新的方法,而且Nacos2.2.3使用了。

于是直接上mvn仓库找到最新版rocksdb,将依赖改为:

<dependency>             <groupId>org.rocksdb</groupId>             <artifactId>rocksdbjni</artifactId>             <version>9.2.1</version>             <classifier>win64</classifier> </dependency> 

然后本地测试的时候发现aliyun没有这么高等级的依赖,只能降到7.10.2才能依赖进来。

但是7.10.2和7.7.3存在着相同的问题。

于是打算从5.18.4 ~ 7.7.3之间来寻找一个能用的依赖。

直接试了6.29.5,也就是升级大版本7之前的最高版本。

然后启动成功!

总结:
Nacos项目新增依赖如下(放到所有依赖最上面):

<dependency>             <groupId>org.rocksdb</groupId>             <artifactId>rocksdbjni</artifactId>             <version>6.29.5</version>             <classifier>win64</classifier> </dependency> 

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!