欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 金融 > 服务器升级Nacos2.2.3报错、rocksdb报错问题处理

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

2024/10/24 13:21:25 来源:https://blog.csdn.net/qq_34972627/article/details/139505493  浏览:    关键词:服务器升级Nacos2.2.3报错、rocksdb报错问题处理

由于系统之前使用的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>

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com