1. Technical Field
The present invention relates to an improved data processing system. In particular, the present invention relates to presenting navigable data center information to users. Still more particularly, the present invention relates to presenting navigable data center information to users in virtual reality.
2. Description of Related Art
In a data center that comprises a large number of heterogeneous devices, information, such as inventories, assignments, statuses, and loads of the devices must be tracked and reported. Currently, data center management systems track and report this information statically using textual representation. While some systems present this information visually to show statuses and allocations of devices, it is difficult to navigate through all the devices since the volume of information to be rendered is large.
In addition, most data center management systems present the information in two-dimensions, which makes it cumbersome and time consuming for the users to interact with the data center inventory. Therefore, it would be advantageous to have an improved method to present data center information, such that the limitations of two-dimension displays may be eliminated and interactions with data center inventory is easier.
The present invention provides a method, an apparatus, and computer instructions in a data processing system for presenting data center information in virtual reality using leading edge rendering engines. The mechanism of the present invention constructs a virtual reality space using a virtual reality rendering engine, populates the virtual reality space with data center information, renders the virtual reality space in a user interface to at least one operator, and performs data center operations based on the commands responsive to receiving commands from the at least one operator.
The novel features believed characteristic of embodiments of the invention are set forth in the appended claims. Embodiments of the invention itself, however, as well as a preferred mode of use, further objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings, wherein:
With reference now to the figures,
In the depicted example, server 104 is connected to network 102 along with storage unit 106. In addition, clients 108, 110, and 112 are connected to network 102. These clients 108, 110, and 112 may be, for example, personal computers or network computers. In the depicted example, server 104 provides data, such as boot files, operating system images, and applications to clients 108-112. Clients 108, 110, and 112 are clients to server 104. Network data processing system 100 may include additional servers, clients, and other devices not shown. In the depicted example, network data processing system 100 is the Internet with network 102 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, government, educational and other computer systems that route data and messages. Of course, network data processing system 100 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN).
Referring to
Peripheral component interconnect (PCI) bus bridge 214 connected to I/O bus 212 provides an interface to PCI local bus 216. A number of modems may be connected to PCI local bus 216. Typical PCI bus implementations will support four PCI expansion slots or add-in connectors. Communications links to clients 108-112 in
Additional PCI bus bridges 222 and 224 provide interfaces for additional PCI local buses 226 and 228, from which additional modems or network adapters may be supported. In this manner, data processing system 200 allows connections to multiple network computers. A memory-mapped graphics adapter 230 and hard disk 232 may also be connected to I/O bus 212 as depicted, either directly or indirectly.
Those of ordinary skill in the art will appreciate that the hardware depicted in
The data processing system depicted in
With reference now to
An operating system runs on processor 302 and is used to coordinate and provide control of various components within data processing system 300 in
Those of ordinary skill in the art will appreciate that the hardware in
As another example, data processing system 300 may be a stand-alone system configured to be bootable without relying on some type of network communication interfaces As a further example, data processing system 300 may be a personal digital assistant (PDA) device, which is configured with ROM and/or flash ROM in order to provide non-volatile memory for storing operating system files and/or user-generated data.
The depicted example in
Turning now to
Customer 402 may be, for example, a client or an administrator who uses a data processing system, such as data processing system 300 in
Software products 416 are applications that may be deployed to a client or a server. Load balancer 418 spreads traffic among multiple systems such that no single system is overwhelmed. Load balancer 418 is normally implemented as software running on a data processing system. Data container 420 may be a database, such as DB2 Universal Database, a product available from International Business Machines Corporation.
Data center 400, as depicted in
Embodiments of the present invention provide a method, an apparatus, and computer instructions for presenting data center information in virtual reality using leading edge rendering engines. The processes of the embodiments of the present invention may be performed by a processing unit comprising one or more processors, such as processor 302 in
In an illustrative embodiment, the present invention leverages existing leading edge rendering engines that support three-dimensional virtual reality representation. An example of leading edge rendering engines includes a virtual reality engine provided by ID software, Inc. With the capabilities of leading edge rendering engines, maps representing data center geography, statuses of data center devices may all be represented in a three-dimensional space.
In an embodiment of the present invention, administrators may navigate and manage data center operations as if the administrators are physically present. Also, devices that are physically remote maybe joined locally in the virtual space to save time in moving between data center installations. Thus, an administrator of the data center may join as players in the virtual space and interact with data center devices regardless of their physical locations.
In addition to maps and device statuses, common functionalities of devices provided by different vendors may be abstracted to a control button in the virtual space. In this way, administrators may easily configure the devices. For example, a create VLAN function may be represented by a control button in the virtual space. If an administrator wants to connect all servers together in a VLAN, the administrator may simply push the control button. This saves significant configuration effort currently spent to configure each server.
In an illustrative embodiment, all servers that support application X may be placed in the same room, while all servers that support application Y may be placed in another room. In this way, maintenance operations may be performed to all servers in the same room at the same time. For example, all servers supporting application X may be turned off, or patches may be applied at the same time. Alternatively, operational status of all servers may be placed in one room, while patch status of these servers may be placed in another room.
Moreover, servers that are free in the free pool room may be assigned to a room for a specific application. In this case, an administrator may physically pick up a server in virtual reality from a stack of servers in a free pool room that contains unassigned servers. The administrator may then carry the server to an application room. By placing the server in the application room, correct operations are requested via the data center management system to remove the server from the free pool, configure it for use in the application, and add it to the cluster.
Alternatively, an application room may include three racks of servers with each rack representing an application tier. The server that was taken from the free pool room may be placed in the appropriate rack to join the cluster of any of the three application tiers. In yet another illustrative embodiment, patches may be applied to servers in a room by spraying them across banks of servers in the room or poured into the room full of servers.
In one example implementation, the mechanism of the present invention may detect that the administrator assigns all servers in a room from VLAN 7 to VLAN 8 using any one of the methods described above. In turn, the mechanism of the present invention sends a message to the existing data center management system that manages those servers, routers, or switches. The data center management system then interacts with the devices that are currently managing the VLANs, and assigns the servers to VLAN 8. The data center management system is a provisioning system that provisions and deprovisions resources.
In an illustrative embodiment, the provisioning system may be modified to include processes of the present invention. For example, the provisioning system may be modified to accept commands from a virtual reality rendering engine. These commands are translated from navigations and movements of data center objects in the virtual space made by the operators. The provisioning system then makes changes to the actual data center devices based on interpretations of the navigations and movements by performing data center operations.
In one scenario, consider a two tier managed application, such as a Web application that consists of servers and network devices. The servers used by the application can be assigned to a free pool, a web server tier, or the Web application tier. Rendered in the virtual space, a room can be dedicated to this type of application, with three racks of servers, one for each of the possible tier assignments. The room is then added to a virtual map, accessible to the operators who are acting as player characters, and moving between rooms.
When an operator enters this application room, the virtual reality rendering engine queries the provisioning system for a list of servers in the Web tier, application tier, and the free pool. The virtual reality rendering engine then represents each server as a non-player character (NPC) or an interactive object (IO), using the appropriate visual representation, and places the servers in the appropriate racks within the room. The virtual reality rendering engine may also register an interest in these servers, and instruct the provisioning system to deliver notifications of any server status or state changes.
In an illustrative embodiment, communication between the provisioning system and the virtual reality rendering engine may be facilitated using any number of mechanisms. One mechanism is by using Simple Object Access Protocol (SOAP) to access Web Services. Queries to the provisioning system from the rendering engine may be made using the Web Services Resource Framework (WSRF). Notifications from the provisioning system to the rendering engine may be provided using Web Services Notification (WS-Notification). The provisioning system may expose Web services to receive instructions from the rendering engine to make changes to the data center. A shared credential system may also allow the rendering engine to request changes from the provisioning system using the identity of the player or operator.
Continuing with the scenario above, if a failure occurs in one of the servers in the Web tier, the provisioning system may send a notification of the state change to the rendering engine. The rendering engine then identifies the affected server by consulting a lookup table, which maps the server identity to the NPC or IO. In the virtual space, an administrator may see a red warning light on a virtual console displayed as a map on a room wall in the main hall. Traveling virtually to the indicated room, the administrator may notice a red, flashing light above the door. Upon entering the room, the administrator may notice that the affected server is glowing red, or a light is flashing on its virtual console.
At this time, the administrator may navigate to the server in its rack, using the movement or action controls for the rendering engine client (typically a computer mouse), and press the button on that server to request a reboot. The rendering engine then translates the action into Web service calls to the provisioning system, again by using a lookup table to determine the correct action and the appropriate server. The provisioning system then reports the state back to the rendering engine, which may indicate that the reboot operation is in progress by showing the server status as yellow.
However, if the reboot operation fails, the administrator needs to remove the failing server from the Web tier, and replace it with one from the free pool. The administrator would, in the virtual space, pick up the bad server, and place it into a trash bin. The rendering engine then recognizes this action as putting the server into a maintenance mode, and makes the appropriate calls to the provisioning system.
Next, the administrator may pick up a server off of the free pool rack. The rendering engine would instruct the provisioning system to remove that server from the free pool. If the free pool is shared, other operators in other application rooms may also see that the server is removed from the free pool, which causes the server to disappear from the view of other operators.
Finally, the administrator would place the free server into the application Web tier, and the rendering engine would instruct the provisioning system to add the new server to the Web tier. The provisioning system would respond by installing, configuring, and starting the appropriate software. Then, the provisioning system updates any network and load balancer routing information. These actions are reported back to the rendering engine as state changes, visually represented to the administrator. Finally, with all servers and the application room showing a green status, the administrator may return to the main hall.
Turning now to
In this example, 2-D representation 500 illustrates two VLANS, VLAN 1502 and VLAN 2509. VLAN 1502 includes three assigned servers: SVR 1504, SVR 2506, and SVR 3508. Similarly, VLAN 2509 includes three assigned servers: SVR 4510, SVR 5512, and SVR 6514. Administrators may find out about statuses, assignments, and inventories of VLANs or servers by selecting the individual VLAN or server.
For example, an administrator may select SVR 1504 from VLAN 1502 and data center information of SVL 1504 is presented in 2-D representation 500 accordingly. In this example, data center information of SVR 1504 includes a patch status of active 516, an assignment to VLAN 1518 and an assignment to application X 520.
While 2-D representation 500 presents data center information of SVR 1504 in a navigable way, it is often difficult for administrators to interact with the individual VLAN or server to change the assignments or inventories. The administrator has to manually add SVR 1504 to VLAN 2509 and reconfigure SVR 1504 based on its current data center information, which is cumbersome and time-consuming. Therefore, a more interactive solution is desired.
Turning now to
Turning now to
VR rendering engine 700 may send data center information to a plurality of client data processing systems 704 and render the information on the displays as 3-D images from the perspective of the operator's location. These 3-D images represent data center devices, such as servers, disks, or network devices.
Instead of using 2-D operator's console of client data processing systems 704, operators may use a virtual reality helmet, gloves, or eyewear, to navigate and move data center objects just like players of a 3-D game. For example, virtual reality rendering engine provided by ID software, Inc. provides a 3-D view on a 2-D display from the perspective of an operator. This viewpoint is used in a 3-D game, such as games known as first person shooters. Operators may use a keyboard or a mouse to navigate in the 3-D view.
When interacting with data center object, actions that the operators initiated or performed represent data device operations. For example, by pushing a reboot server button, reboot operations are performed on the selected server. In addition to sending data center information, VR rendering engine 700 also manages navigation and movement of the data center objects by the operators and accepts provisioning commands from the operators 706 based on their movement. The commands are translated by a provisioning system from navigation and movements of the data center objects made by operators 708. In turn, the provisioning system makes changes to the actual data center devices based on interpretations of the navigations and movements.
When VR rendering engine 700 renders the 3-D images, the 3-D images may be represented as rooms, and other locations on a map. The rooms and locations represent different aspects of a data center, for example, a room for a multi-tiered application, or all servers that belong to a given VLAN. Furthermore, the 3-D images also include objects or actions in the virtual space that can be manipulated or modified by the operators, for example, network connections between servers.
Since VR rendering engine 700 may represent data center resources in 3-D, the environment in which the data center resources reside may be branded for a particular organization. For example, a room or a wall may be branded with the enterprise corporate colors and logos. In addition, colors and signage may be used to enhance the navigation environment, for example, different colors or logos may be used to assist the operator to find resources that are specific to a division.
Turning now to
As shown in
In addition to VLAN assignments, rooms may be set up to include servers for a specific application or specific status. Furthermore, statuses of devices may be shown virtually on the rendered objects in the room, such that administrators may visually distinguish the devices and the type of device. Statuses of devices may be updated dynamically in the room by changes made by the administrators physically, virtually, or as a result of actual occurrences. For example, status of a server may be updated from idle to busy, or from up to down.
Turning now to
As shown in
However, SVR 2 may be shown in red to illustrate that the server needs attention. When SVR 2 is shown as red, administrators may use virtual buttons in room 902 to repair the problem. For example, the administrator may use power on/off button 904 to power on or off SVR 2, use reboot button 906 to reboot SVR 2, or use apply patch button 908 to apply a security patch to SVR 2. Alternatively, the operator may apply a patch by selecting one from a shelf and physically taking the patch off the shelf. The operator may then apply the patch to a target server by directly inserting or attaching it to the target server. In addition to power on/off, reboot server, and apply patches operations, other operations may be represented in the virtual space. For example, moving or assigning resources to distributed applications and application clusters, reconfiguring and assigning devices to load balancers, reconfiguring network connections and routing, creating or changing Virtual Private Networks and VLANs. Thus, with the capabilities of presenting data center devices in three dimensions, administrators may manage and report devices in virtual space without the limitations of two-dimensional displays.
Turning now to
Next, the mechanism of the present invention adds devices to a room or other appropriate rooms with their data center information (step 1004). Examples of data center information for the devices include statuses, inventories, load and assignments. The mechanism of the present invention presents the virtual room to administrators in the virtual space (step 1005). Later, the mechanism of the present invention detects changes made by the administrators in the virtual space (step 1006) and sends change messages to the existing data center management system (step 1008). The existing data center management system then makes appropriate changes to the devices (step 1010) and the process terminates thereafter.
In summary, embodiments of the present invention provide a way to present data center information in virtual reality, such that administrators may manipulate data center devices and its information more easily. With the mechanism of embodiments of the present invention, device assignments and statuses may be changed without the need for reconfiguration and remote devices may be connected together regardless of their physical locations.
It is important to note that while embodiments of the present invention have been described in the context of a fully functioning data processing system, those of ordinary skill in the art will appreciate that the processes of embodiments of the present invention are capable of being distributed in the form of a computer usable medium of instructions and a variety of forms and that embodiments of the present invention applies equally regardless of the particular type of signal bearing media actually used to carry out the distribution. Examples of computer usable media include recordable-type media such as a floppy disc, a hard disk drive, a RAM, and CD-ROMs and transmission-type media such as digital and analog communications links.
The description of the embodiments of the present invention have been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to embodiments of the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiments were chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand embodiments of the invention for various embodiments with various modifications as are suited to the particular use contemplated.