以下是个人修改的措施,虽然不是很好,但是能够解决项目现有问题,这边记录一下
问题:公司项目集成kkFileView插件,定时调度转换任务,在大量文件转换过程中,非常容易报出 failed to restart 重启失败的异常。
kkFileView异常源
在restart重启的时候,先去调用 doStopProcess 停掉原先的进程,在进行 doStartProcessAndConnect重启,如果说停掉成功,但重启失败,那么office进程就不存在,程序就不会执行。
restartAndWait方法修改
思想:因为公司的项目是定时调度转换,所以必须要保证office进程必须要存在,不能让它挂掉。如果失败异常,则再进行doStartProcessAndConnect重启操作,无限循环
但在转换的时候还是出现问题
异常:a process with acceptString ‘%s’ is already running; pid %d
kkFileView异常源
是在调用doStartProcessAndConnect()内部产生的异常:
- doStartProcessAndConnect() -> process.start() -> start()
start方法修改
修改思想:office进程存在,直接返回,不抛异常,因为项目做的是循环定时扫描数据库待转换文件。
但是在转换的时候还是存在异常
到这里我已经蹦了。
kkFileView异常源
同样是在调用doStartProcessAndConnect()内部产生的异常:
- doStartProcessAndConnect() -> process.start() -> start()
- 这边是调用processBuilder.start()启动office,再去查找对应的pid,如果pid不存在,则抛异常,但是抛异常丝毫不影响,因为在restartAndWait方法已经做了死循环,失败就再次重启,无伤大雅。
- 个人修改到这里就结束了
文件测试
- 14份六百多M文件,每份文件里有一万多个文件,全部转换成功。