如何通过Qt WebGL流向多个用户提供Qt应用程序?

问题描述

Qt Quick WebGL Streaming是一项技术,通过该技术,任何Qt Quick(“ QML”)应用程序都可以向通过Web浏览器连接的用户显示其用户界面。您要做的就是在主机上启动该应用程序:

./my-qml-program -platform webgl:port=8080

这可行,但受设计限制,因此只能同时连接一个用户并查看用户界面。为此,他们引用了用户输入,查询GPU和安全性(source)方面的问题。

最初,Qt开发人员希望通过一个进程提供多个窗口来支持WebGL流中的多个用户:

将如何支持并发?就像每个连接都有自己的QGuiApplication一样,还是只有一个? […]您创建一个QGuiApplication和不同的窗口。当新客户端连接到HTTP服务器时,会有一个信号通知。发出信号后,您将创建另一个QWindow。窗口是独立的(source

但是,现在,开发人员希望通过为每个用户启动一个进程来支持WebGL流中的多个用户。

  • 我们正在努力将HTTP Server与插件解耦
  • 将提供专用的HTTP Server应用程序
    • 不是在同一进程中运行所有用户,而是为每个用户生成一个新进程
    • 新进程将处理Web套接字

source

“将HTTP Server与插件分离”意味着将其替换为QHttpServer:

我已经为该[QHttpServer]模块计划了一些用例:更改WebGL插件中的当前嵌入式Web服务器(和WebSockets),以使其易于基于该插件创建自己的自定义解决方案。 (source

到目前为止,尚未实现任何解决方案。自己在Qt WebGL流式传输中实现对多个用户的支持而不等待Qt实施的最简单方法是什么?

解决方法

这是一个使用负载平衡器Pen的解决方案,使Qt应用程序可以通过WebGL流同时访问多个用户。它会将传入的连接转发到在同一主机上运行的多个Qt进程之一,每个进程都运行自己的嵌入式Web服务器。这种转发正是负载均衡器的工作,只是它通常将连接分配到多个主机。

注意事项:在我的测试中,Qt 5.12.3中的WebGL流媒体传输速度足够快,仅在本地网络中即可使用,而不能在Internet上使用。因此,您不能使用它“廉价地将Qt应用程序转换为Web应用程序”。

说明

这些说明适用于Ubuntu 19.10、20.04和其他基于Debian的发行版。

  1. 在您的虚拟主机上安装Qt应用程序。

  2. 在您的Web主机上安装Qt WebGL平台插件。例如,它不包含在Ubuntu 19.10发行版中。在这种情况下,您必须compile and install it yourself。在Ubuntu Linux下,结果应为以下文件:

    /usr/lib/x86_64-linux-gnu/qt5/plugins/platforms/libqwebgl.so
    
  3. 启动Qt应用程序的多个进程。每个进程都应为Qt WebGL流提供一个端口。在这里,我们开始三个过程,但是您可以在内存中开始尽可能多的过程。

    nohup myapplication -platform webgl:port=8080 &
    nohup myapplication -platform webgl:port=8081 &
    nohup myapplication -platform webgl:port=8082 &
    
  4. 安装负载均衡器Pen

    sudo apt install pen
    
  5. 启动负载均衡器。请注意,使用pen 80 …可以启动负载均衡器,以便用户只需在他们的网站中输入简单的URl,例如http://example.com/。浏览器访问该应用程序。如果端口80已在使用中,则可以选择任何其他端口(例如9090),使用pen 9090 …启动负载均衡器,然后让用户访问类似http://example.com:9090/的URL。还要注意列出的每个服务器进程的后缀:1:1,它告诉pen仅将一个客户端最多连接到一个进程。

    pen 80 localhost:8080:1:1 localhost:8081:1:1 localhost:8082:1:1
    
  6. 测试设置。要测试,请从多个设备访问关联的URL http://example.com/。您应该在每个设备上为应用程序提供一个进程。在 same 设备上的两个并行浏览器选项卡中无法看到两个进程– pen随后将尝试将第二个此类选项卡连接到与第一个选项卡相同的Qt进程。请求来自相同的IP地址。结果,您会在第二个选项卡中看到一个纺车,因为Qt进程每个只允许一个连接进行WebGL流传输。

改进

一旦客户端连接,仅按需启动Qt流程,可以进一步改进此解决方案。 systemd socket activation应该可以做到这一点。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...