CN108388460B - Remote real-time rendering platform construction method based on graphic cluster - Google Patents

Remote real-time rendering platform construction method based on graphic cluster Download PDF

Info

Publication number
CN108388460B
CN108388460B CN201810109865.XA CN201810109865A CN108388460B CN 108388460 B CN108388460 B CN 108388460B CN 201810109865 A CN201810109865 A CN 201810109865A CN 108388460 B CN108388460 B CN 108388460B
Authority
CN
China
Prior art keywords
cluster
rendering
graphics
node
graphic
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201810109865.XA
Other languages
Chinese (zh)
Other versions
CN108388460A (en
Inventor
刘海洋
李智
陈勇
林琪
宋旭民
徐灿
刁华飞
章兰英
柴华
邴启军
刘海涛
周雯雯
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Peoples Liberation Army Strategic Support Force Aerospace Engineering University
Original Assignee
Peoples Liberation Army Strategic Support Force Aerospace Engineering University
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Peoples Liberation Army Strategic Support Force Aerospace Engineering University filed Critical Peoples Liberation Army Strategic Support Force Aerospace Engineering University
Priority to CN201810109865.XA priority Critical patent/CN108388460B/en
Publication of CN108388460A publication Critical patent/CN108388460A/en
Application granted granted Critical
Publication of CN108388460B publication Critical patent/CN108388460B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Processing Or Creating Images (AREA)

Abstract

The invention discloses a remote real-time rendering platform construction method based on a graphic cluster, which comprises the steps of utilizing a Docker framework to realize the deployment of a virtual desktop system in the graphic cluster; a VNC server is embedded in a virtual desktop system, and after a VNC client accesses the VNC server, remote desktop connection is established through a VNC protocol; the graphic cluster performs dynamic load balancing according to the connection condition of the remote desktop, and establishes a dynamic task scheduling and managing mechanism of the graphic cluster; and establishing a real-time image transmission channel between the platform client and the graphic cluster server through a graphic cluster dynamic task scheduling and managing mechanism, and comprehensively integrating the remote real-time rendering platform based on the graphic cluster. Aiming at the problem of rendering application of a large number of remote users based on different requirements, the invention meets the requirements of different users for use as required by using a virtualization means by relying on a graphics cluster hardware environment according to an asynchronous distributed working mode facing multiple users, thereby facilitating management and ensuring data safety.

Description

Remote real-time rendering platform construction method based on graphic cluster
Technical Field
The invention belongs to the technical field of computer graphic rendering, and particularly relates to a remote real-time rendering platform construction method based on a graphic cluster, which is used for providing a remote real-time efficient graphic rendering environment for multiple users and is beneficial to the work in the aspects of military simulation, educational training, mobile office, autonomous controllable system popularization and the like.
Background
The graphics rendering system is the basis for implementing visual simulation, virtual reality, augmented reality and other technologies. The Graphics rendering solution is developed from an initial dedicated Graphics workstation based on SGI (Silicon Graphics, usa), to a Graphics cluster system with multiple parallel computers, and then to a multi-Graphics-card Graphics workstation using SLI (scalable Link Interface) of NVIDIA (NVIDIA, usa) or CF (cross fire) technology of AMD (Advanced Micro Devices, ultramicro semiconductors, usa), and the Graphics rendering application mode is developed by hardware technology to have a spiral rising posture. In order to solve the problem of large-scale, remote, and real-time rendering, and to effectively integrate graphics resources and improve resource utilization efficiency, the rendering mode based on the graphics cluster is the focus of research in the industry again.
Generally, a cluster rendering system used in cooperation with a graphics cluster is also called a distributed rendering environment or a rendering farm, and is composed of a plurality of computers running rendering software, and under the unified deployment of cluster rendering management software, the cluster rendering system coordinates to complete distributed rendering tasks in a parallel manner. From a real-time perspective, there are roughly two categories: one type is a non-real-time rendering system, namely, a management end issues a rendering instruction to a graphics cluster, the graphics cluster sends a rendering scene to the management end or a storage system after completing a rendering task within a certain time, and then a user checks and calls a rendering result. The rendering system is multipurpose for the fields of movie and television, animation production and the like; the other type is a real-time rendering system, namely, a management end issues a rendering instruction to a graphic cluster, the graphic cluster feeds back a rendering result to a user in real time after finishing a rendering task, and meanwhile, the interaction and control instruction of the user are responded. Such rendering systems are used in many applications, both for visual simulation and virtual reality systems.
Through investigation of relevant manufacturers and technologies of the current remote real-time rendering platform, it is found that core technologies covered by the platform mainly include VDI (Virtual Desktop Infrastructure), VMM (Virtual Machine Monitor), DCV (Desktop Cloud Visualization), vGPU (Virtual Graphics Processing Unit), and the like, and the oriented application conditions thereof are mainly embodied in the following three aspects.
1. Single-machine access single-station virtual desktop service acquisition
A user installs client software locally, a Remote graphic workstation node installs service software, and a Remote Desktop Protocol (RDP) is used for virtualizing a Desktop of the graphic workstation to the local so as to realize Remote access and display of the graphic software.
In fact, the Windows-based RDP protocol can effectively support file operations of a remote desktop and simple document processing, but is not suitable for processing videos and dynamic images. On the basis, HP proposes an RGS (Remote Graphics Software) solution, which is optimized on the basis of an RDP (Remote Graphics Software), and comprises the steps of using an image compression/decompression technology (the compression ratio can reach 170: 1) with an independent patent, greatly reducing network transmission load, and realizing the function of Remote multi-user shared desktop service through the expansion of RDP (Windows Remote desktop connection only allows one user to access at the same time, and the server becomes a screen locking state after the access; HP RGS allows a plurality of users to access the desktop of the server at the same time, and the desktop of the server can also be normally displayed). The scheme supports Windows, Linux and Unix operating systems, can basically meet the requirement of remote rendering tasks, but the server software requirement is required to be installed on a Hewlett packard graphics workstation, and no other optimization processing work is carried out on the allocation of graphics rendering resources.
2. Multi-machine access single station virtual desktop service acquisition
The scheme is suitable for multiple persons to cooperatively carry out the same work, the requirement that the multiple persons carry out different works by sharing the graphic resources cannot be met, and if each user can obtain an independent virtual desktop and can share the graphic resources, an independent desktop system, namely the deployment and the operation of a VDI (virtual desktop infrastructure) architecture, needs to be developed for each user on the graphic workstation node. At present, the mainstream VDI technology mainly comprises three solutions of Hyper-V + RGS, XenServer + HDX and NICE DCV, and the comparative analysis is as follows:
(1)Hyper-V+RGS
Hyper-V (Windows-based virtualization product from Microsoft corporation of America) is built in Windows Server 2008 and later operating system products, and has good compatibility but low speed compared with the past virtualization technology of Microsoft by adding one more operating system layer. Hyper-V allows the virtual machine to more directly use the hardware resources of the physical host, thereby increasing the performance of the virtual system. Hyper-V cuts into the field of server virtualization by virtue of the advantages of the Microsoft platform, but the Hyper-V has defects in the support of the Linux system. The function and deficiencies of RGS software are as described above.
(2)XenServer+HDX
The XenServer (a virtualization software product introduced by Sijie corporation in America) is a comprehensive and easily-managed server virtualization platform, can efficiently manage Windows and Linux virtual servers, can provide economic and efficient server integration and service continuity, has the functions of an operating system, and can be directly installed on a server to be started and operated in a guided manner. HDX (High Definition Experience, High Definition use Experience) of the samje corporation in usa is a remote High Definition interactive product which is launched aiming at desktop virtualization and application virtualization markets and can realize interaction of multimedia, voice, video and 3D graphics. However, in the field of engineering design, the product can only realize desktop virtualization interaction based on a Windows platform, and cannot realize sharing of GPU resources.
(3)KVM+NICE DCV
NICE DCV (DCV product by NICE corporation under amazon, usa) is an interactive product that enables remote access to 2D or 3D applications over standard networks, allowing the user to utilize remote 3D high-end graphics cards, fast I/O capabilities, and a large number of memory nodes. It is worth emphasizing that the performance of the software can be fully exerted by deploying NICE DCV on a KVM (Kernel-based Virtual Machine) virtualization platform. The scheme can support a Linux operating system, NICE DCV supports various GPU virtualization technologies on a hardware level, a special graphic card of NVIDIA company is matched with a vGPU driver, vGPU is distributed to each virtual machine, and GPU resource sharing can be achieved to a certain extent.
3. Multi-machine access graphics cluster to obtain virtual desktop services
The virtual desktop service mentioned in the two schemes is implemented on the basis of a single graphics workstation, and if the number of users is too large, the form of creating a virtual machine on the single graphics workstation cannot meet the application requirement, so that a plurality of graphics workstations need to be used to replace the single graphics workstation, which is the concept of graphics cluster. The third scheme is mainly based on the first two schemes, and mainly solves the problem of aggregation of the graphics clusters, namely how to organize and manage a plurality of current graphics workstations, so that the graphics workstations can conveniently and efficiently realize graphics services for multiple users like one machine.
If a plurality of independent graphics workstations are aggregated into a unified graphics Cluster system, rendering task management software is needed to allocate and schedule resources, typically VCM (Visualization Cluster Manager) and TechViz (Visualization software product of TechViz, france).
(1)VCM
The VCM introduced by Orad, Israel is cluster management software installed on a graph cluster management node, distributes rendering tasks by planning the connection mode of the graph nodes, and realizes integration and synchronization of images by using a special integration interface. The cluster management mode well realizes the distribution and management of rendering tasks, but the concept mainly provides services for a multi-channel display system, is more suitable for multi-channel synchronous output large-screen display, and is obviously not flexible and intelligent in application.
(2)TechViz
The TechViz adopts another idea in cluster management, a complete graphic application software is installed on a management node of a cluster, a local graphic card is directly called to perform rendering display after the graphic application software runs, however, the TechViz software distributes a high-resolution graphic rendering task to rendering nodes through a network in the form of OpenGL (Open Graphics Library) instruction stream, then performs rendering output by using the graphic card of the rendering nodes, and performs output synchronization between the rendering nodes through a synchronization card. This cluster management scheme does not require the installation of graphics application software on the rendering nodes and is also very flexible in the distribution of rendering tasks.
(3) Other software
Besides the above two kinds of software, there are some cluster management software for graphics rendering at home and abroad, such as Muster (cluster rendering software of Virtual version corporation, usa), Platform LSF (cluster management scheduling software of IBM corporation, usa) and EnFuzion (cluster rendering software of china troostics corporation), etc., which can manage and monitor the working condition of rendering nodes in real time, avoid the idle of the rendering nodes, and enable users to obtain final rendering products in the shortest time.
The graphics cluster system provides a good hardware basis in the aspect of providing remote real-time rendering services for multiple users, and the cluster rendering software system at the present stage focuses on the aspects of cluster architecture, cluster management, load balancing, parallel rendering and the like, so that although a faster and more efficient solution can be provided for the users in a synchronous parallel mode, the problem of rendering application of a large number of remote users based on different requirements is not solved.
Different from a traditional cluster rendering system, the technology provided by the invention mainly adopts a multi-user-oriented asynchronous distributed working mode, depends on a graphics cluster hardware environment, and utilizes a virtualization means to meet the requirements of different users for use as required. The core idea is that a user remotely accesses a graph cluster, the graph cluster provides a real-time and efficient running environment for the user, and responds to the local interactive operation of the user, so that the user obtains a working experience close to a graph workstation, and data resources and a computing program of the graph cluster are deployed at a far end, thereby facilitating management and ensuring data safety.
Disclosure of Invention
In order to solve the technical problems, the invention provides a remote real-time rendering platform construction method based on a graphic cluster, VDI is deployed and operated on the graphic cluster through virtual desktop system deployment based on a Docker framework, an independent virtual desktop system is opened up for a user, display driving is directly called under a Docker operation environment to realize GPU (Graphics Processing Unit) accelerated rendering, meanwhile, a VNC protocol is adopted to establish remote desktop connection, a real-time image transmission channel is established for the user, and an asynchronous distributed real-time rendering service is provided for multiple users by combining with a dynamic task scheduling and management mechanism of the graphic cluster.
The purpose of the invention is realized by the following technical scheme:
the remote real-time rendering platform construction method based on the graphic cluster comprises the following steps:
the method comprises the following steps that firstly, deployment of a virtual desktop system is achieved inside a graph cluster by means of a Docker framework;
embedding a VNC server in the virtual desktop system, and after the VNC client accesses the VNC server, establishing remote desktop connection through a VNC protocol;
thirdly, the graphics cluster performs dynamic load balancing according to the connection condition of the remote desktop, and establishes a dynamic task scheduling and managing mechanism of the graphics cluster;
and step four, establishing a real-time image transmission channel between the platform client and the graphic cluster server through a graphic cluster dynamic task scheduling and managing mechanism, and comprehensively integrating the remote real-time rendering platform based on the graphic cluster.
The method specifically comprises the following steps:
creating a Docker container on a graph cluster rendering node operating system;
making the packaged virtual desktop system into a Docker mirror image and storing the Docker mirror image into a shared storage system;
the Docker container realizes deployment of a virtual desktop system in the graphics cluster by loading Docker mirror images, and simultaneously realizes GPU rendering acceleration based on a Docker architecture in the virtual desktop system.
The step of implementing Graphics Processing Unit (GPU) rendering acceleration based on a Docker architecture in the virtual desktop system comprises the following steps:
mapping a Graphics card driver kernel file of a Graphics cluster rendering node operating system into an integrated environment of a Docker container, and calling a window extension plug-in of OpenGL (Open Graphics Library) to realize real-time rendering acceleration of a GPU (Graphics Processing Unit) in a virtual desktop system.
The display of the virtual desktop system adopts a virtual external output mode, and the mode comprises the following steps:
and distributing virtual display output for each Docker container, and outputting the graphics in the Docker container to a client through the virtual display output when a user accesses the Docker container, so that GPU rendering is independent of an actual graphics card output interface.
The second step specifically comprises:
the VNC server side screens the changed image areas by using a block matching area change detection algorithm, transmits the image compressed to the corresponding VNC client side, and establishes remote desktop connection based on a C/S framework through a VNC protocol;
the VNC server side utilizes a block matching area change detection algorithm to screen changed image areas, and the method comprises the following steps:
setting a unit area needing change detection;
acquiring information of a redrawing area of a screen of an intercepting system;
if the intercepted redrawing area of the system screen is smaller than the unit area, sending the position information of the area;
if the intercepted redrawing area of the system screen is larger than the unit area, the intercepted redrawing area of the system screen is split, the coordinate information of the split area is stored in a linked list, the coordinate information of each split area in the linked list is subjected to traversal detection to obtain the position information of the change area needing to be retransmitted, and the position information of the change area needing to be retransmitted is stored and transmitted.
In step three, the dynamic task scheduling and managing mechanism of the graphics cluster includes:
under a certain load balancing strategy, reasonably arranging rendering nodes by a cluster management node to provide service resources for users;
the dynamic task management and scheduling of the graph cluster relates to dynamic conversion among one or more of four conditions including but not limited to a single-user to single node, multiple-user to single node, a single-user to multiple nodes and/or multiple-user to multiple nodes.
The load balancing strategy comprises the following steps:
under the condition that a single user is opposite to a single node, a polling strategy is adopted to distribute rendering nodes;
under the condition that multiple nodes are subjected to multi-user pair, indexes such as resource utilization rate, network bandwidth and Input/Output (I/O) rate of rendering nodes are comprehensively considered, a single-target planning problem with rendering system load variance or standard deviation as a minimum value is solved by using a dynamic load balancing model, and an optimized graph cluster load balancing strategy is obtained.
The comprehensive integrated remote real-time rendering platform based on the graphic cluster comprises a platform client, a graphic cluster management node, a graphic cluster rendering node and a shared storage system;
the platform client is deployed at the user operation terminal and used for initiating an application request to the graphics cluster server;
the graphic cluster management node and the graphic cluster rendering node are deployed at a graphic cluster server and used for responding to an application request initiated by a platform client;
and the shared storage system is used for storing and managing user configuration files, virtual desktop system images and/or rendering model data information.
The fourth step specifically comprises:
the method comprises the steps that a VNC client side is embedded into a platform client side, a Docker container and a VNC server side are embedded into a graph cluster rendering node, a Docker mirror image is stored in a shared storage system, and a graph cluster management node performs cluster load balancing according to a dynamic task scheduling and management mechanism;
when an application request initiated by a platform client is received, a graphics cluster management node designates a rendering node for the platform client, the rendering node starts a Docker container and loads a Docker mirror image, and meanwhile, a remote real-time rendering channel is established by utilizing a VNC protocol, so that remote real-time rendering service is provided for a user.
Wherein the application mode of the remote real-time rendering platform comprises:
after the graphics cluster server receives an application request initiated by the platform client, the graphics cluster management node distributes a rendering task to the rendering nodes, and the rendering nodes provide rendering services for users by creating an independent virtual desktop system.
Aiming at the problem of rendering application of a large number of remote users based on different requirements, the invention provides a real-time and efficient running environment for the users by utilizing a virtualization means based on a Docker architecture and relying on a graphics cluster hardware environment, and responds to the local interactive operation of the users. The method is not only suitable for different hardware environments and operating system platforms, but also can realize that multiple users share GPU rendering resources, so that the users can obtain work experience close to a graphic workstation.
Drawings
FIG. 1 is a flow chart of a method for constructing a remote real-time rendering platform based on a graphics cluster.
Fig. 2 is a diagram comparing the technical mechanisms of a virtual machine and a Docker.
FIG. 3 is a diagram of an overall framework of a remote real-time rendering platform based on graphics clusters.
FIG. 4 is a functional module design diagram of a remote real-time rendering platform based on graphics clusters.
FIG. 5 is an exemplary diagram of an application flow for a user using a remote real-time rendering platform.
FIG. 6a is a host operating system rendering effect diagram; FIG. 6b is a Docker container rendering effect diagram.
FIG. 7a is a schematic diagram of a single node supporting two users; fig. 7b is a diagram of a single node supporting four users.
Detailed Description
In order to make the technical solutions of the present invention better understood, the technical solutions in the embodiments of the present invention will be clearly and completely described below with reference to the drawings in the embodiments of the present invention, and it is obvious that the described embodiments are only a part of the embodiments of the present invention, and not all of the embodiments. All other embodiments, which can be derived by a person skilled in the art from the embodiments given herein without making any creative effort, shall fall within the protection scope of the present invention.
Referring to fig. 1, fig. 1 is a flowchart illustrating an embodiment of a method for building a remote real-time rendering platform based on a graphics cluster according to the present invention, where the method includes: step one to step four.
In the first step, deployment of the virtual desktop system is achieved inside the graphics cluster by using a Docker architecture.
Firstly, VDIs are deployed and operated on a graph cluster, an independent virtual desktop system is opened up for users, and application requirements of different users can be better met. In consideration of the restriction of the virtual machine operation mode on the GPU rendering capability, the system adopts a VDI solution scheme based on a Docker (application container engine), and directly calls a display driver under a Docker operation environment, so that the GPU rendering efficiency is greatly improved.
Generally, a virtual desktop system based on a virtual machine realizes a display function by calling a display driver of a basic operating system, the display resource of the virtual desktop system is limited, and a processing mode mostly belongs to a serial working mode, so that the GPU rendering capability of a graphics cluster high-end display card cannot be fully exerted. The VDI solution based on Docker utilizes a GPU virtualization technology to penetrate through the display drive of a basic operating system, and graphics acceleration based on a GPU is realized inside a plurality of independent virtual machines, so that multi-user sharing of GPU resources is realized to a certain extent. Referring to fig. 2, fig. 2 is a schematic diagram comparing the technical mechanisms of the virtual machine and the Docker.
The method specifically comprises the following steps: creating a Docker container on a graph cluster rendering node operating system; making the packaged virtual desktop system into a Docker mirror image and storing the Docker mirror image into a shared storage system; the Docker container realizes deployment of a virtual desktop system in the graphics cluster by loading Docker mirror images, and simultaneously realizes GPU rendering acceleration based on a Docker architecture in the virtual desktop system.
The Docker is a high-level Container open source engine based on an LXC (Linux Container), and mainly includes three components, namely, a daemon (Docker daemon), an Image (Image) and a Container (Container), wherein the daemon is used as a server to receive and process a request from a client, the Image is a read-only template for the Container to run, and the Container includes an integrated environment required by the user application to run.
The rendering acceleration step specifically includes: mapping a Graphics card driver kernel file of a Graphics cluster rendering node operating system into an integrated environment of a Docker container, and calling a window extension plug-in of OpenGL (Open Graphics Library) to realize real-time rendering acceleration of a GPU (Graphics Processing Unit) in a virtual desktop system.
Because the Docker container shares the operating system kernel with the host operating system, the user application can directly call the hardware resources in the host operating system. However, in the actual application process, the user cannot realize effective GPU rendering by running the application in the integrated environment directly provided by the container. Through a large number of test experiments, the graphics card driver kernel file of the host operating system is mapped into the integrated environment of the container, and meanwhile, the X window extension plug-in of OpenGL is called, so that the rendering acceleration of the GPU can be well realized.
Further, the display of the virtual desktop system adopts a virtual external output mode, which includes:
and distributing virtual display output for each Docker container, and outputting the graphics in the Docker container to a client through the virtual display output when a user accesses the Docker container, so that GPU rendering is independent of an actual graphics card output interface.
In general, a GPU rendering pipeline performs on-screen rendering, and asynchronous access by multiple users cannot achieve screen sharing. Aiming at the problem, virtual external output is adopted to distribute virtual display output for each container, and when a user accesses the container, a graph outputs the display to a client, so that GPU rendering does not depend on an actual graph card output interface, and the problem of multi-user asynchronous application is well solved.
In step two, a VNC (Virtual Network Console) service end is embedded in the Virtual desktop system, and after the VNC client accesses the VNC service end, a remote desktop connection is established through a VNC protocol.
The VNC server side screens the changed image areas by using a block matching area change detection algorithm, the images are compressed and then sent to the corresponding VNC client side, and remote desktop connection based on a C/S framework is established through a VNC protocol.
The VNC server side utilizes a block matching area change detection algorithm to screen changed image areas, and the method comprises the following steps:
setting a unit area needing change detection;
acquiring information of a redrawing area of a screen of an intercepting system;
if the intercepted redrawing area of the system screen is smaller than the unit area, sending the position information of the area;
if the intercepted redrawing area of the system screen is larger than the unit area, the intercepted redrawing area of the system screen is split, the coordinate information of the split area is stored in a linked list, the coordinate information of each split area in the linked list is subjected to traversal detection to obtain the position information of the change area needing to be retransmitted, and the position information of the change area needing to be retransmitted is stored and transmitted.
Wherein the steps are as follows: the VNC mechanism intercepts redrawing area information of a system screen by adopting a message hook mechanism. Setting a unit area needing change detection, if the size of the unit area rgn is recorded as 32 multiplied by 32, if the redrawing area of the intercepted system screen is smaller than the unit area, directly sending the position information of the area; if the redrawing area of the intercepted system screen is larger than the unit area, splitting the redrawing area of the intercepted system screen to obtain a rectangular chain table (traversal chain table) for storing coordinate information of the split area, recording the rectangular chain table as array _ list, defining a change area as vnc _ rgn, specially storing area position information needing to be retransmitted, and calling the detection algorithm for each member rectangle of the array _ list to detect the change area.
A preferred embodiment:
(1) assuming that one member rectangle is ari, if the length and the width of ari are all less than 32 x 32, directly serving as a change area to be retransmitted, and storing the change area into vnc _ rgn, otherwise, analyzing and detecting the ari.
(2) Firstly, defining a new rectangle arrj (arri.left, 0, arri.right, 0), finding a changed line in arri, recording the y coordinate of the line, and recording arrj.top as y, and at the same time, increasing y + as 16 to find a non-changed line, and temporarily recording arrj.bottom as y; then, a comparison is made between the bottom y-1 of arrj, a line with changed content is found, and the y coordinate of the line is set to arrj. The final top, bottom coordinates of the variation rectangle arrj are determined so far. While setting the value of ari to ari (ari. left, arrj. bottom, ari. right, ari. bottom). After the analysis of arrj is completed, the analysis of arri is followed until the end.
(3) After the rectangle arrj is determined, the rectangle arrj is analyzed. Firstly, defining a rectangular arn (0, 0, 0, 0), searching a column which is changed firstly in arrj, recording left and top coordinates of a changed area after finding the column, wherein the left is x, and the arm is y, and analyzing the cyclic traversal of the x and y axes respectively (namely x + is 32, and y + is 32), if the screen pixel data of the column is changed, continuing to compare the x + with the x + 32; otherwise, recording the array.right ═ x, performing the same comparison in the y axis direction, y + ═ 32, and recording the array.bottom ═ y, finally obtaining the rectangular coordinates of the change region to be sent, storing the rectangle into the rectangular linked list finally sent, simultaneously recording the array (array.right, array.top, array.right, array.bottom), the array (array.left, array.bottom, array j.right, array j.bottom), and the array (array.j.bottom), assigning the array and the array to the array j respectively to perform similar analysis detection, and sequentially cycling the whole array j until finishing.
By the screen change area detection algorithm, the member rectangles of the whole array _ list linked list are traversed to obtain the coordinate information of the change area which needs to be sent again.
In addition, for the real-time transmission control of the image, the system adopts a C/S (Client/Server) framework to establish an image transmission channel between a Client and a Server, the Server collects and compresses the image and then sends the image to the Client, and the Client receives and decompresses the image and then displays the image to a user. The VNC protocol is adopted for image real-time transmission, the server side screens changed image areas by using a block matching area change detection algorithm, and the image areas are sent to the client side after being compressed, so that the network sending data volume is greatly reduced. The image refreshing speed of the client is autonomously controlled by a user, the server transmits images after receiving the refreshing request of the client, and when the client is busy or the network delay is large, the image refreshing speed is correspondingly reduced.
The method for enhancing the image transmission real-time property mainly comprises two aspects, namely, the efficiency of the region change detection algorithm is improved, and the image compression algorithm with higher compression rate and shorter encoding time is used. The VNC regional change detection algorithm is improved, and the image change region is subdivided through interlaced scanning, so that redundant unchanged image data are further eliminated. The system tests the algorithm, taking a 24-bit screen image of 1280 x 800 as an example, the refreshing interval of a client screen is 40ms, the data transmission amount in the applications of word processing, web browsing and the like is about 200kb/s, and the data amount can be reduced by about 10% on average by applying the algorithm; the data transmission amount exceeds 4Mb/s in high-dynamic image application, the influence of the application of the algorithm on the data amount is small, the CPU utilization rate is obviously improved, and therefore the method has weak influence on the real-time property of high-dynamic image transmission. The compression rate and the time spent on encoding are comprehensively considered, the system usually adopts an MJPEG (image compression algorithm) algorithm with higher efficiency to compress and encode the image, and experimental results show that the data transmission flow by adopting the MJPEG algorithm can be reduced to be less than 50% of that of a ZLib (image compression algorithm defaulted by a VNC protocol) algorithm under the same conditions, so that the problem of network congestion caused by overlarge data volume can be avoided to a certain extent.
In the third step, the graphics cluster performs dynamic load balancing according to the connection condition of the remote desktop, and establishes a dynamic task scheduling and management mechanism of the graphics cluster.
The graph cluster dynamic task scheduling and managing mechanism comprises:
under a certain load balancing strategy, reasonably arranging rendering nodes by a cluster management node to provide service resources for users; the dynamic task management and scheduling of the graph cluster relates to dynamic conversion among one or more of four conditions including but not limited to a single-user to single node, multiple-user to single node, a single-user to multiple nodes and/or multiple-user to multiple nodes.
The load balancing strategy comprises the following steps:
under the condition that a single user is opposite to a single node, a polling strategy is adopted to distribute rendering nodes; under the condition that multiple nodes are subjected to multi-user pair, indexes such as resource utilization rate, network bandwidth and Input/Output (I/O) rate of rendering nodes are comprehensively considered, a single-target planning problem with rendering system load variance or standard deviation as a minimum value is solved by using a dynamic load balancing model, and an optimized graph cluster load balancing strategy is obtained.
The task scheduling and management mechanism of the remote real-time rendering system is that under a certain load balancing strategy, the cluster management nodes reasonably arrange the rendering nodes to provide service resources for users. In general, cluster management involves four situations, namely single-user to single node, multi-user to single node, single-user to multi-node, and multi-user to multi-node, and dynamic switching of multiple situations may occur during system operation.
In the case of single-user to single-node, the rendering nodes can be allocated by adopting a polling strategy, and in the actual application, more than one user to multiple nodes are used. Under the condition that the number of users and the number of rendering nodes are fixed, indexes such as resource utilization rate, network bandwidth and I/O rate of the rendering nodes are comprehensively considered, and a load balancing strategy can be summarized as making a decision in the selection of the rendering nodes, namely solving a single-target planning problem that the load variance or standard deviation of a rendering system is a minimum value; if the number of users or the number of rendering nodes changes, the solution process may evolve into a complex dynamic programming problem in a period of time, but the solution process can be treated as a single-target programming problem at the present moment.
Let EiAnd if the load value of the rendering node of the ith station is the load value of the rendering node of the ith station, the load value of the rendering node of the ith station is as follows:
Ei=w1Ci+w2Mi+w3Gi+w4Ni+w5IOi (1)
in the formula, Ci、Mi、GiRespectively the occupancy rates of the rendering node CPU, the memory and the GPU of the ith platform, NiFor network utilization, IOiIs the I/O rate, wj(j-1, 2, …,5) is a weight value corresponding to the above 5 indexes, each index item and the load value EiNormalization is required.
The total load mean of the rendering system is:
Figure BDA0001568873190000111
simplifying the solving of the rendering system load variance into solving of the minimum value of the difference value between the load of each rendering node and the total load mean value, namely:
Figure BDA0001568873190000112
after load balancing, the load value of each rendering node is generally stabilized above or below the average value of the total load of the system. In order to avoid the influence on the rendering experience of the current user due to excessive additional users, when the management node monitors that the rendering frame frequency of the current user of the rendering node is lower than a set value (default is 24 frames/second), the management node preferentially distributes the user request to other rendering nodes or rejects the access request of the user according to rules.
In the fourth step, a real-time image transmission channel is established between the platform client and the graphic cluster server through a graphic cluster dynamic task scheduling and managing mechanism, and a remote real-time rendering platform based on the graphic cluster is integrated comprehensively.
As shown in fig. 3, the steps specifically include:
when an application request initiated by a platform client is received, a VNC client is embedded into the platform client (the client n is short for term in figure 3, n is more than or equal to 1), a Docker container (the container n is short for term in figure 3, n is more than or equal to 1) and a VNC server are embedded into a graph cluster rendering node (the node is short for term in figure 3), a Docker mirror image (the mirror image is short for term in figure 3) is stored in a shared storage system, and cluster load balancing is carried out by a graph cluster management node according to a dynamic task scheduling and management mechanism;
the method comprises the steps that a graphic cluster management node designates a rendering node for a platform client, the rendering node starts a Docker container and loads a Docker mirror image, meanwhile, a VNC protocol is used for establishing a remote real-time rendering channel, and a remote real-time rendering platform based on a graphic cluster is integrated comprehensively.
The comprehensive integrated remote real-time rendering platform based on the graphic cluster comprises a platform client, a graphic cluster management node, a graphic cluster rendering node and a shared storage system; the platform client is deployed at the user operation terminal and used for initiating an application request to the graphics cluster server; the graphic cluster management node and the graphic cluster rendering node are deployed at a graphic cluster server and used for responding to an application request initiated by a platform client; and the shared storage system is used for storing and managing user configuration files, virtual desktop system images and/or rendering model data information.
The application mode of the remote real-time rendering platform comprises the following steps: after the graphics cluster server receives an application request initiated by the platform client, the graphics cluster management node distributes a rendering task to the rendering nodes, and the rendering nodes provide rendering services for users by creating an independent virtual desktop system.
In an embodiment, the remote real-time rendering system utilizes a Docker architecture to implement virtual desktop system deployment, and establishes a remote desktop connection using a VNC. And the remote user sends a Docker container management request to the cluster server, and establishes remote desktop connection with the VNC server by using the VNC client. At the graphic cluster server, the cluster management node manages and schedules the container through a Docker daemon, and a Docker registry is used for storing user-defined image files. After the server receives a container management request sent by the client, the Docker daemon searches the mirror image in the registry and creates a user container, and simultaneously starts the VNC server in the container.
After the graphic cluster receives an application request initiated by a user terminal, a management node distributes a rendering task to rendering nodes, and the rendering nodes provide rendering services for users by creating an independent virtual desktop system. The remote real-time rendering platform based on the graphic cluster mainly comprises a platform client, a graphic cluster management node, a graphic cluster rendering node and a shared storage system, wherein the platform client is deployed at a user operation terminal, the graphic cluster management node and the rendering node are deployed at a graphic cluster server, and the shared storage system mainly provides convenient and reliable storage management for user configuration files, virtual desktop system images, rendering model data and the like. The platform function module is shown in fig. 4.
The platform client sends a virtual desktop request to the graph cluster management node through a user registration/login mode, and the node to be managed is responsible for establishing remote desktop connection with the rendering node providing rendering service after the rendering node is appointed. The platform client can directly access the shared storage system and upload, download or modify a specific configuration file within the user authority range.
The graphic cluster management node mainly comprises 3 modules of initialization, task management and node management. After the system is started, the initialization functions of cluster internal connection, configuration file loading and the like are firstly completed; the task management module is mainly used for completing functions of task storage, scheduling, query and the like, after receiving a virtual desktop request of a platform client, querying the load condition of each rendering node in a cluster, and meanwhile, utilizing a dynamic load balancing algorithm to appoint the rendering node for the platform client, wherein if the virtual desktop request is in a new user registration mode, the rendering node newly opens a virtual desktop system, and if the virtual desktop request is in a user login mode, the rendering node loads a virtual desktop system file from a shared storage system; the node management mainly completes functions of adding and deleting, configuring, state query and the like of rendering nodes.
After the virtual desktop system is started, the graphics cluster rendering node establishes an independent data connection channel with the platform client through remote desktop management, and provides remote rendering service for a user. The rendering node mainly comprises two parts, namely virtual desktop system management and remote desktop system management, wherein the virtual desktop system management is responsible for creating and managing the virtual desktop system and providing real-time rendering service for a user, and the remote desktop system management is mainly used for remote display and interaction control.
The virtual desktop system management module is mainly used for creating a Docker container on a Linux operating system, making an encapsulated virtual desktop system into a Docker mirror image and storing the Docker mirror image into a shared storage system, realizing VDI (virtual device interface) deployment by loading the Docker mirror image when the virtual desktop system needs to be created, and solving the real-time rendering problem in the virtual desktop system by using a Docker-based GPU (graphics processing Unit) rendering technology.
The remote desktop management module mainly adopts a VNC solution, and since the VNC captures information of a redrawing area of a system screen by using a message hook mechanism, the remote desktop management module needs to create a display output interface map for a virtual desktop system of each user, that is, create a virtual "screen". And a VNC server is installed in the virtual desktop system, the platform client establishes remote desktop connection with the virtual desktop system by calling the VNC client, and the transmission instantaneity is optimized by adopting a VNC-based image real-time transmission control method. An example of an application flow for a user using a remote real-time rendering platform is shown in FIG. 5, which includes:
the platform client initiates a connection request, the graphic cluster management node receives the connection request, the graphic cluster management node selects a rendering node for a user, judges whether the connection is made by a new user, and if so, starts an application container engine and creates a virtual desktop system; if not, starting an application container engine and loading the mirror image of the virtual desktop system; the graph cluster rendering node responds to the user connection request, the graph cluster rendering node creates a VNC real-time rendering channel, the platform client completes remote desktop connection, and the user starts system application.
In order to test the application effect of the system, two graphic workstations are selected to form a graphic cluster, one of the two graphic workstations is used as a management node, a platform client is installed on a common PC, and the network environment is a gigabit local area network. The hardware configuration of the graphic cluster node is an Intel to strong quad-core processor, a 16G memory, an Nvidia Q7000 professional graphic card (a video memory 6G), and the operating system is a 64-bit Ubuntu Kylin 16.04 (a Kylin operating system in Wuban diagram). After logging in, the platform client establishes remote desktop connection with the graphics cluster rendering node, and respectively performs GPU rendering efficiency and multi-user asynchronous application experiments on 1280 multiplied by 800 resolution.
GPU rendering efficiency experiment: the same pattern test samples are respectively run in the host operating system and the Docker container environment, and due to the limitation of the screen refreshing frequency, the running effect is that the running frame frequency on the host operating system is not more than 60 frames/second as shown in FIG. 6a, the running frame frequency in the Docker container environment can reach 85 frames/second, and the running effect is shown in FIG. 6 b. Test results show that the efficiency of Docker-based GPU rendering is already substantially close to the efficiency of usage on the host operating system.
Multi-user asynchronous application experiment: after the multi-platform clients are started simultaneously, the rendering frame frequency is gradually reduced along with the increase of the number of the platform clients under the condition of stable operation of the system, the rendering frame frequency difference among the platform clients is not large, and the platform clients do not have obvious pause phenomenon. When a single rendering node supports 1 user, the average frame rate can reach 140 frames/second, when 2 users are supported, the average frame rate is about 120 frames/second, the display effect of the platform client is as shown in fig. 7a, when 4 users are supported, the average frame rate is about 75 frames/second, and the display effect of the platform client is as shown in fig. 7 b.
To sum up, the embodiment of the invention aims at the problem of rendering application of a large number of remote users based on different requirements, and meets the requirements of different users for use as required by relying on a graphics cluster hardware environment according to an asynchronous distributed working mode facing multiple users. The core idea is that a user remotely accesses a graph cluster, the graph cluster provides a real-time and efficient running environment for the user, and responds to the local interactive operation of the user, so that the user obtains a working experience close to a graph workstation, and data resources and a computing program of the graph cluster are deployed at a far end, thereby facilitating management and ensuring data safety.

Claims (6)

1. The remote real-time rendering platform construction method based on the graphic cluster comprises the following steps:
the method comprises the following steps that firstly, deployment of a virtual desktop system is achieved inside a graph cluster by means of a Docker framework;
embedding a VNC server in the virtual desktop system, and after the VNC client accesses the VNC server, establishing remote desktop connection through a VNC protocol;
thirdly, the graphics cluster performs dynamic load balancing according to the connection condition of the remote desktop, and establishes a dynamic task scheduling and managing mechanism of the graphics cluster;
establishing a real-time image transmission channel between the platform client and the graphic cluster server through a graphic cluster dynamic task scheduling and managing mechanism, and comprehensively integrating a remote real-time rendering platform based on the graphic cluster;
the method specifically comprises the following steps: creating a Docker container on a graph cluster rendering node operating system; making the packaged virtual desktop system into a Docker mirror image and storing the Docker mirror image into a shared storage system; the Docker container realizes deployment of a virtual desktop system in the graphics cluster by loading Docker mirror images, and simultaneously realizes GPU rendering acceleration based on a Docker architecture in the virtual desktop system;
the step of realizing the acceleration of GPU rendering based on a Docker architecture in the virtual desktop system comprises the following steps: mapping a graphics card driver kernel file of a graphics cluster rendering node operating system into an integrated environment of a Docker container, and calling a window extension plug-in of OpenGL (open graphics library) to realize real-time rendering acceleration of a GPU (graphics processing Unit) in a virtual desktop system;
the display of the virtual desktop system adopts a virtual external output mode, and the mode comprises the following steps: distributing virtual display output for each Docker container, and outputting the graphics in the Docker container to a client through the virtual display output when a user accesses the Docker container, so that GPU rendering is independent of an actual graphics card output interface;
the application mode of the remote real-time rendering platform comprises the following steps: after the graphics cluster server receives an application request initiated by the platform client, the graphics cluster management node distributes a rendering task to the rendering nodes, and the rendering nodes provide rendering services for users by creating an independent virtual desktop system.
2. The method of claim 1, wherein the graphics cluster-based remote real-time rendering platform,
the second step specifically comprises:
the VNC server side screens the changed image areas by using a block matching area change detection algorithm, the images are compressed and then sent to the corresponding VNC client side, and remote desktop connection based on a C/S framework is established through a VNC protocol.
3. The method for constructing the remote real-time rendering platform based on the graphic cluster as claimed in claim 2, wherein the VNC server filters the changed image area by using a block matching area change detection algorithm, including:
setting a unit area needing change detection;
acquiring information of a redrawing area of a screen of an intercepting system;
if the intercepted redrawing area of the system screen is smaller than the unit area, sending the position information of the redrawing area of the system screen;
if the intercepted redrawing area of the system screen is larger than the unit area, the intercepted redrawing area of the system screen is split, the coordinate information of the split area is stored in a linked list, the coordinate information of each split area in the linked list is subjected to traversal detection to obtain the position information of the change area needing to be retransmitted, and the position information of the change area needing to be retransmitted is stored and transmitted.
4. The method of claim 1, wherein the graphics cluster-based remote real-time rendering platform,
in step three, the dynamic task scheduling and managing mechanism of the graphics cluster includes:
under a load balancing strategy, reasonably arranging rendering nodes by a cluster management node to provide service resources for users;
the dynamic task management and scheduling of the graph cluster relates to dynamic conversion among one or more of four conditions including but not limited to single-user to single node, multi-user to single node, single-user to multi-node and/or multi-user to multi-node;
the load balancing strategy comprises the following steps:
under the condition that a single user is opposite to a single node, a polling strategy is adopted to distribute rendering nodes;
under the condition that multiple nodes are subjected to multi-user pair, resource utilization rate, network bandwidth and I/O rate indexes of rendering nodes are comprehensively considered, a single-target planning problem that the rendering system load variance or standard deviation is a minimum value is solved by using a dynamic load balancing model, and an optimized graph cluster load balancing strategy is obtained.
5. The method of claim 1, wherein the graphics cluster-based remote real-time rendering platform,
the comprehensive integrated remote real-time rendering platform based on the graphic cluster comprises a platform client, a graphic cluster management node, a graphic cluster rendering node and a shared storage system;
the platform client is deployed at the user operation terminal and used for initiating an application request to the graphics cluster server;
the graphic cluster management node and the graphic cluster rendering node are deployed at a graphic cluster server and used for responding to an application request initiated by a platform client;
and the shared storage system is used for storing and managing user configuration files, virtual desktop system images and/or rendering model data information.
6. The graphics cluster-based remote real-time rendering platform construction method of claim 5,
the fourth step specifically comprises:
the method comprises the steps that a VNC client side is embedded into a platform client side, a Docker container and a VNC server side are embedded into a graph cluster rendering node, a Docker mirror image is stored in a shared storage system, and a graph cluster management node performs cluster load balancing according to a dynamic task scheduling and management mechanism;
when an application request initiated by a platform client is received, a graphics cluster management node designates a rendering node for the platform client, the rendering node starts a Docker container and loads a Docker mirror image, and meanwhile, a remote real-time rendering channel is established by utilizing a VNC protocol, so that remote real-time rendering service is provided for a user.
CN201810109865.XA 2018-02-05 2018-02-05 Remote real-time rendering platform construction method based on graphic cluster Active CN108388460B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810109865.XA CN108388460B (en) 2018-02-05 2018-02-05 Remote real-time rendering platform construction method based on graphic cluster

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810109865.XA CN108388460B (en) 2018-02-05 2018-02-05 Remote real-time rendering platform construction method based on graphic cluster

Publications (2)

Publication Number Publication Date
CN108388460A CN108388460A (en) 2018-08-10
CN108388460B true CN108388460B (en) 2021-05-18

Family

ID=63074556

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810109865.XA Active CN108388460B (en) 2018-02-05 2018-02-05 Remote real-time rendering platform construction method based on graphic cluster

Country Status (1)

Country Link
CN (1) CN108388460B (en)

Families Citing this family (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109213561A (en) * 2018-09-14 2019-01-15 珠海国芯云科技有限公司 The equipment scheduling method and device of virtual desktop based on container
CN111163345B (en) * 2018-11-07 2021-11-26 杭州海康威视***技术有限公司 Image rendering method and device
CN109587118B (en) * 2018-11-11 2021-05-11 长沙摩智云计算机科技有限公司 Distributed multi-terminal and multi-network supporting system for Android online game
CN111343219B (en) * 2018-12-18 2022-08-02 同方威视技术股份有限公司 Computing service cloud platform
CN109725986B (en) * 2019-01-29 2023-01-20 中山大学 Graphical and containerized virtual network environment construction and batch deployment method
CN109949201B (en) * 2019-01-29 2023-04-07 福建多多云科技有限公司 Image rendering acceleration method for Linux container
CN110032413B (en) * 2019-03-05 2021-08-31 华为技术有限公司 Desktop virtualization method, related equipment and computer storage medium
CN112470194A (en) * 2019-04-12 2021-03-09 艾司科软件有限公司 Method and system for generating and viewing 3D visualizations of objects with printed features
CN110442389B (en) * 2019-08-07 2024-01-09 北京技德***技术有限公司 Method for sharing GPU (graphics processing Unit) in multi-desktop environment
CN111984352A (en) * 2020-08-10 2020-11-24 南京江北新区生物医药公共服务平台有限公司 Desktop cloud service platform system based on spice protocol optimization
CN112200712B (en) * 2020-09-08 2023-10-27 成都安易迅科技有限公司 GLES image rendering method and device, storage medium and computer equipment
CN112085988A (en) * 2020-09-11 2020-12-15 北京信息科技大学 Virtual simulation experiment system and method for penetration attack
CN112398914B (en) * 2020-10-28 2023-03-24 武汉大势智慧科技有限公司 Cloud rendering platform based on Kubernetes container cluster
CN114531740B (en) * 2022-02-16 2024-06-14 北京易智时代数字科技有限公司 VR head display terminal application rendering operation method and system
CN115185667B (en) * 2022-09-13 2022-12-20 天津市天河计算机技术有限公司 Visual application acceleration method and device, electronic equipment and storage medium

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103631634A (en) * 2012-08-24 2014-03-12 中国电信股份有限公司 Graphics processor virtualization achieving method and device

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103631634A (en) * 2012-08-24 2014-03-12 中国电信股份有限公司 Graphics processor virtualization achieving method and device

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
Evaluation of Docker Containers Based on Hardware Utilization;Preeth E N等;《2015 International Conference on Control, Communication & Computing India (ICCC)》;20151121;第697-700页 *
在低速网络下利用VNC实现应用程序共享的解决方案;dj0379;《https://blog.csdn.net/dj0379/article/details/52397788?biz_id=102&utm_term=jingle%20vnc&utm_medium=distribute.pc_search_result.none-task-blog-2~all~so***web~default-0-52397788&spm=1018.2118.3001.4187》;20160901;第1-4页 *

Also Published As

Publication number Publication date
CN108388460A (en) 2018-08-10

Similar Documents

Publication Publication Date Title
CN108388460B (en) Remote real-time rendering platform construction method based on graphic cluster
CN109582425B (en) GPU service redirection system and method based on cloud and terminal GPU fusion
US11029990B2 (en) Delivering a single end user experience to a client from multiple servers
Doerr et al. CGLX: a scalable, high-performance visualization framework for networked display environments
US8112513B2 (en) Multi-user display proxy server
US9479358B2 (en) Managing graphics load balancing strategies
CN108762934B (en) Remote graphic transmission system and method and cloud server
CN106020929A (en) System and method for supporting 3D application in virtual environment
CN112306636B (en) Cloud rendering platform and intelligent scheduling method thereof
CN113902866B (en) Double-engine driven digital twin system
CN113079216B (en) Cloud application implementation method and device, electronic equipment and readable storage medium
CN107948731B (en) Video stream merging method, server and computer-readable storage medium
KR20160092136A (en) Virtual Desktop Providing Method and Virtual Desktop Providing Server thereof
TW201417035A (en) System and method for processing load balance of graphic streams
CN112988346B (en) Task processing method, device, equipment and storage medium
Lai et al. A service based lightweight desktop virtualization system
CN115550335A (en) Distributed mobile WEB3D rendering system and method
KR20210042992A (en) Method and apparatus for training a deep learning model
KR101319815B1 (en) Cloud computing-based App implementing system using distributed multi-mobile terminal
CN102968807A (en) Automatic image generating method and automatic image generating system
CN103618968B (en) A kind of network TV play method and system towards under cloud environment
CN109144453A (en) Massive information high-resolution collaborative work cloud platform based on parallel computation
Sumalatha et al. A novel thin client architecture with hybrid push-pull model, adaptive display pre-fetching and graph colouring
CN114064182A (en) Low-cost desktop virtualization system and operation method
Luo Pace: Augmenting personal mobile devices with scalable computing

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant