我正在尝试让LibreOffice在容器内以无头模式运行,这样我就可以将其用于Windows上的文档转换。
通过以下方式在本地运行LibreOffice:
C:\Program Files\LibreOffice 5\program>soffice.exe -accept="socket,host=127.0.0.1,port=8100;urp;" -nofirststartwizard -headless
生成一个正在侦听端口8100的LibreOffice的运行实例
C:\Program Files\LibreOffice 5\program>netstat -nao|findstr -c:"8100"
TCP 127.0.0.1:8100 0.0.0.0:0 LISTENING 28168
使用LibreOffice CLI,我可以使用C#成功连接到正在运行的应用程序以转换我的文档。
这一切都运行正常,但是当我从Windows容器运行相同版本的LibreOffice时,我的程序会挂起连接步骤,永远不会超时或出错。 请参阅下面的C#代码段。
dockerfile
FROM microsoft/windowsservercore
ADD https://ftp.osuosl.org/pub/tdf/libreoffice/stable/5.4.4/win/x86_64/LibreOffice_5.4.4_Win_x64.msi .
RUN msiexec.exe /i LibreOffice_5.4.4_Win_x64.msi
RUN del LibreOffice_5.4.4_Win_x64.msi
EXPOSE 8100
ENTRYPOINT ["C:\\Program Files\\LibreOffice 5\\program\\soffice.exe"]
CMD ["-accept=\"socket,host=127.0.0.1,port=8100;urp;\"", "-headless", "-nofirststartwizard"]
泊坞窗命令
docker build -t libreoffice .
docker run -d -v C:\FileRepository:C:\FileRepository --name some-office -p 8100:8100 libreoffice
C#
var xLocalContext = uno.util.Bootstrap.defaultBootstrap_InitialComponentContext();
var xURLResolver = (XUnoUrlResolver)xLocalContext.getServiceManager()
.createInstanceWithContext("com.sun.star.bridge.UnoUrlResolver", xLocalContext);
// m_ServiceConnString = uno:socket,host=localhost,port=8100;urp;StarOffice.ComponentContext
// C# never returns from this line and doesn't error when LibreOffice is running via container
// The only way to recover is to kill the process.
var xRemoteContext = (XComponentContext)xURLResolver.resolve(m_ServiceConnString);
var xRemoteFactory = (XMultiServiceFactory)xRemoteContext.getServiceManager();
return (XComponentLoader)xRemoteFactory.createInstance("com.sun.star.frame.Desktop");
在没有容器(本地LibreOffice)的转换过程中运行netstat会显示:
>netstat -nao|findstr -c:"8100"
TCP 127.0.0.1:8100 0.0.0.0:0 LISTENING 28168
TCP 127.0.0.1:8100 127.0.0.1:57531 ESTABLISHED 28168
TCP 127.0.0.1:57531 127.0.0.1:8100 ESTABLISHED 36208
使用容器转换期间运行netstat会显示:
>netstat -nao|findstr -c:"8100"
TCP 127.0.0.1:8100 0.0.0.0:0 LISTENING 15924
TCP 127.0.0.1:8100 127.0.0.1:58931 ESTABLISHED 15924
TCP 127.0.0.1:58931 127.0.0.1:8100 ESTABLISHED 25124
TCP 172.27.208.1:58932 172.27.216.35:8100 SYN_SENT 15924
不是网络人员我觉得这与如何与容器建立连接有关,SYN_SENT
似乎意味着连接被阻止,但我无法确定。 SYN_SENT
状态也只持续几秒钟。我对码头工人来说是全新的,所以我可能会对我的创作方式做错了。运行容器。任何帮助都会很棒!
环境
nat
。docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS
PORTS NAMES
a2ad9cc76d8b libreoffice "C:\\Program Files\\Li…" 45 hours ago Up 22 minutes
0.0.0.0:8100->8100/tcp some-office
docker inspect
docker inspect --format "{{ .NetworkSettings.Networks.nat.IPAddress }}" some-office
172.27.216.35 // can't telnet to this ip with 8100 or ping.
docker inspect --format "{{ .NetworkSettings.Networks.nat.Gateway }}" some-office
172.27.208.1
答案 0 :(得分:1)
想出来。
连接到容器显示我可以telnet连接到容器中的LibreOffice。
docker exec -ti some-office cmd
telnet 127.0.0.1 8100
e ? ?'com.sun.star.bridge.XProtocolPropertiesUrpProtocolProperties.UrpProtocol
PropertiesTidm???
但是,尝试通过容器的IP进行远程登录失败。
docker exec -ti some-office cmd
C:\>telnet 172.27.216.25 8100
Connecting To 172.27.216.25...Could not open connection to the host, on port 8100: Connect failed
我将LibreOffice端口从127.0.0.1更改为0.0.0.0,这允许telnet在容器内通过容器的端口以及主机通过localhost:8100工作。
更改dockerfile并重建
CMD ["-accept=\"socket,host=0.0.0.0,port=8100;urp;\"", "-headless", "-nofirststartwizard"]
或通过以下方式创建容器:
docker run -d -v C:\FileRepository:C:\FileRepository --name some-office -p 8100:8100 libreoffice -accept=\"socket,host=0.0.0.0,port=8100;urp;\" -headless -nofirststartwizard