当前位置:网站首页>问题:OfficeException: failed to start and connect(二)

问题:OfficeException: failed to start and connect(二)

2022-07-01 06:28:00 Going_man

问题:OfficeException: failed to start and connect(二)

场景:重启tomcat服务后,预览系统启动不了

输出日志:启动office组件失败,请检查office组件是否可用

报错:org.artofsolving.jodconverter.office.OfficeException: failed to start and connect

原因二:

因为通过不断地重启发现,其实杀不死也能够让soffice被使用,它会沿用存在的soffice,去执行。

回到原点:

为什么会启动office组件失败,请检查office组件是否可用?

再次寻找原因

在不断重启过程中,我发现了项目运行和tomcat的startup.bat启动,是没有任何问题的。

有问题的情况只有:tomcat服务自启动去启动LibreOffice的时候

①当LibreOffice已启动,去启动是没有问题!

②而但LibreOffice未启动,去启动则会报错!

所以tomcat的startup.bat启动和服务自启动的区别是什么?

启动方式优点缺点
系统服务启动系统开机自启动windows系统下导出的线程信息内容不全面
startup.bat启动开机后必须再次双击startup.bat启动,关闭命令窗口服务即停止导出的线程信息比较全面

而最关键的问题:为什么系统服务启动,会导出线程信息内容不全?

因为通过satrtup.bat启动用户为当前登录账户,而通过服务启动的tomcat用户为system用户,有的是local service用户,导出线程信息时,jstack命令需要添加 -F ,不加会提示:

insufficient memory or insufficient privilege to attach

为什么用户权限不足?

Tomcat服务在启动中的用户名是:LOCAL SERVICE

解析:
①LOCAL SERVICE是windows中的内置账户,权限比普通用户Users更小,在Windows中主要作为系统服务或进程的运行账户。
②以LOCAL SERVICE权限运行的程序无法访问内核驱动程序,无法访问除“系统中断”、“System”和“系统空闲处理器百分比”之外的所有进程。注意:以这个帐户权限运行的服务无法访问Active Directory中的数据,只能访问本地电脑的数据。
在这里插入图片描述采用Startup.bat启动的用户名是Administrator
在这里插入图片描述

结论二:

tomcat的startup.bat启动和服务自启动,它们的启动用户不同!所以导致了服务启动的用户对于C:\Program Files\LibreOffice权限不够,最终启动不起来!

解决方式二:

在CMD执行sc config Tomcat9 obj=LocalSystem,将tomcat9.exe的执行用户改为System即可

sc config Tomcat9 obj=LocalSystem
原网站

版权声明
本文为[Going_man]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_44593275/article/details/125266058