-
Notifications
You must be signed in to change notification settings - Fork 22
H.T.U 可视化环境
M LiJiang 20151215
这篇文档可能有些过时,仅供参考
- 应用背景
- 远程可视化方案简介
- X11 转发
- VNC 远程桌面
- 海量数据并行可视化软件 --- ParaView
对于很多有成熟图形界面的用户来说。 平时,使用电脑来做计算是这样的:
而要使用高性能计算机,我们得这样:
熟悉的图形操作不行了,还得学习一堆新知识
然后还要RTFM,查看应用软件怎么在命令行模式下使用。
同时,面对很大的计算任务,我们需要花费大量的时间在上传、下载文件上。
graph TB
本地1-->|上传算例 600MB 10min|服务器1
服务器1 -->|计算出结果 12GB 1hour |服务器2
服务器2 -->|下载结果 12GB 3hour20min |本地2
本地2 -->|查看结果是否正确 10min|本地3
如何解决?
HPC + 可视化 ---> 一站式服务
以下5张图片及内容参考NVDIA白皮书Remote Visualization on Server-Class Tesla GPUs
HPC集群在使用时一般都是通过网络连接到集群的头节点来进行远程访问,所以我们需要远程可视化的支持。
而在本地渲染模式下,Linux 图形环境时构成调用如下:
图形应用程序使用 Xlib 或 libGL 来获取图形化的支持,Xlib 会去访问 X Server,进而去访问底层图形驱动 , libGL 可以去访问 X Server ,也可以回去直接访问图形驱动。
Linux X 环境本身就提供了远程可视化的支持,如果客户机上装有 X Server 环境,那么运行在服务器上的图形程序可以在客户机上使用客户机的资源进行绘制。
一些应用程序自身采用CS架构。在服务器上进行渲染处理,将结果返回给客户端的程序,通过这种方法实现远程可视化。
一些大型的可视化软件提供这种模式的远程可视化支持,如ParaView。目前大部分的远程可视化环境 如 VNC , NX 等也都是采用这种模式。
通过应用程序来进行远程可视化存在适用性方面的问题,另外一些客户端的显示硬件往往也没有得到利用。而通过 VGL 则可以解决此问题。
各种远程方案总结:
模式 | 性能 | 软件适配性 | 目前状态 |
---|---|---|---|
X11 转发 | * * | * * * * | docker 可用 |
基于软件的远程可视化 | * * * * | * * | docker 可用* |
基于中间库的远程可视化 | * * * * | * * * * | 测试中 |
推荐用于 轻量级 的偶尔的可视化需求 ,也是目前的主要的可视化方案
始于1984,是UNIX、类UNIX、以及OpenVMS等操作系统所一致适用的标准化软件工具包及显示架构的运作协议。
X只是工具包及架构规范,X.Org是其最为普遍且最受欢迎的实现,X11是X.Org所用的协议版本。
X采用C/S的架构模型,由一个X服务器与多个X客户端程序进行通讯,服务器接受对于图形输出(窗口)的请求并反馈用户输入(键盘、鼠标、触摸屏)
X的一大特点在于“网络透明性”[2]:应用程序(“客户端”应用程序)所运行的机器,不一定是用户本地的机器(显示的“服务器”)。
天河二号上提供了X环境的支持(登陆节点、docker计算节点),但需要用户自己的终端环境有X Server 的支持
- 天河二号普通计算节点不支持X 环境,docker 计算节点支持
在终端环境的登陆节点,运行xclock
顺利的话会显示一个图形时钟,
,不顺利的话,会有出错信息:
Error: Can't open display
支持X环境的终端
- Windows 下的SSH 工具 ,配置连接时注意开启 X 转发
- MobaXterm 推荐,免费,易安装
- XManager 完整版才支持X环境,免费版不支持,使用方便,性能好
- putty + Xming 免费,安装较复杂,性能较差
- ... ...
- Linux 环境
- 如果安装了图形环境就已经支持了,SSH 连接时需要使用 -X 或 -Y 参数
ssh -i ~/key/mykey -X [email protected]
- Mac OS X
- 类似 Linux , 但可能需要额外安装 XQuartz
X 环境的问题?
- 性能
- 稳定性
- 带宽占用大
比X11 环境性能要好。
目前可供测试的可视化环境。未来的可视化平台的基础。
适合 Fluent 等商业软件的使用 。
VNC(Virtual Network Computing),为一种使用RFB协议的屏幕画面分享及远程操作软件。此软件借由网络,可发送键盘与鼠标的动作及即时的屏幕画面。
VNC与操作系统无关,因此可跨平台使用,例如可用Windows连接到某Linux的电脑,反之亦同。甚至在没有安装客户端程序的电脑中,只要有支持JAVA的浏览器,也可使用。
* 目前转发服务器 ln6 故障中
* 目前在采购GPU ,以支持高性能的渲染环境
$source runvnc.sh
123456 654321 docker
Submitted batch job 416772
http://172.16.23.16:6080/vnc.html?host=172.16.23.16&port=6080
- 此示例代码已经失效
- 目前已部署了天河星光系统,大部分的可视化需求可通过此系统完成,具体请咨询市场部门
进行中
并行渲染
...
yhrun -N 2 -n 48 pvserver --use-offscreen-rendering --disable-xdisplay-test --mpi &
...
并行渲染测试,测试用例有 7,465,946 个单元, Abaqus 输出文件大小 82 GB.