来自LibreOffice的TCP SYN_SENT在Docker Container中无头。

时间:2018-02-07 18:16:07

标签: c# docker tcp libreoffice

我正在尝试让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状态也只持续几秒钟。我对码头工人来说是全新的,所以我可能会对我的创作方式做错了。运行容器。任何帮助都会很棒!

环境

  • Windows 10
  • Docker 17.12.0-ce-win47(15139)
  • LibreOffice 5.4.4.2
  • Docker网络托管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

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