Pandora: Documentation en: RemoteManagement

From Pandora FMS Wiki
Revision as of 15:22, 13 June 2014 by Michael konrad (talk | contribs) (Introduction)
Jump to: navigation, search

Go back to Pandora FMS documentation index

1 Remote Systems Management by Pandora FMS

1.1 Introduction

Pandora FMS is a monitoring tool and it doesn't use agents in order to establish a connection to the systems. It isn't useful to control the monitored systems remotely in this way. Some systems, such as routers and switches could be managed by using Telnet or SSH. In order to have access to them you're only required to fire the appropriate command.

Pandora FMS includes a Java plug in by default to be able to establish a connection from the web console via VNC to the remote servers by using the IP configured within them. This could be easy if we're in the same local network segment and have a direct connection. It's more complicated in some other cases.

We're distinguishing between complex and simple environments. These would be e.g. the characteristics of a simple environment:

  • The server's IP doesn't change.
  • The access (paths and firewalls) from the operator's PC to the servers has open ports and it knows how to connect by using normal TCP/IP.
  • We're able to install a remote control software within the server's host system or it already has one.

The characteristics we consider to be the ones of a complex environment are the following:

  • The server's IP changes (it's dynamic).
  • There is no direct access from the operator's PC to the server we intend to monitor.
  • We're unable to install any remote control software on the remote system.

There are also intermediate cases, e.g. the machines have a fixed IP, but we don't have direct remote access from the operator's PC to the server via TCP/IP. In any case, there are three possible ways to acquire remote access to these systems:

1. Directly:
It's possible to install e.g. an SSH server, to activate the remote desktop or to install a VNC server on the host system. From the perspective of the operator's PC, it's completely sufficient if we're inserting the remote system's IP into the client program which is running on it and it's ready. For the 'simple' environments, this is the appropriate way to go. We strongly recommend to use UltraVNC if you decide to use this method.

2. By using an inverse System:
We're referring to remote control systems which connect by using a server on the internet which allows to connect both computers so they can 'talk' if the operator's PC communicates with the same server on the internet, instead of just waiting to connect with an open TCP port. The internal network wouldn't communicate with them in this way at all. This system, although useful in complex environments, has many disadvantages such as the speed or the fact that if the server we're required to control doesn't have access to the internet. In this case, we wouldn't be able to communicate with it. We strongly recommend to use TeamViewer here.

3. By using a Direct Connection System:
UltraVNC allows to configure one proxy, so it's going to be the one which connects to the remote server. We're going to connect with the intermediate server (proxy) and connect this one to the end server. This is called 'Ultra VNC Repeater'. You can find more information about this method on the UVNC Repeater page.

On the picture below, you're looking at a basic working sketch of this system.

Ultra vnc modeI.png

The UltraVNC tool itself allows you to conduct the setup graphically:

Ultra vnc repeater.gif

The connection to the VNC server utilizes the proxy to connect to the destination server, as we can see on the picture below.

Vnc sample2.gif

1.2 Using VNC integrated in Pandora FMS

It's possible, through the Pandora FMS "VNC" extension, to have access, from the WEB console itself, without having to install additional software or doing anything extra. To do this, the only requisites are these:

  • Having installed a VNC server that includes the Java applet, listening in the port 5800 of each server we want to manage remotely.
  • Having the Java plugin installed in its browser.
  • Having direct connection from the PC where the operator is connected to the Pandora console, to the monitored server that we want to manage remotely. The connection has to allow the port 5800/TCP

If we fulfil these requisites, we only have to press on the flap with the extension "VNC" in the operation view of one agent and we'll see the following:

Vnc tab.png

Look of the VNC flap (first one by left)

When the communication is reestablished, it's necessary to introduce a password that is configured when the VNC server is installed in the machine.

Vnc ext 1.png

Once we have introduced the password, we have access to the server " as if we were there".

Vnc ext 2.png

We recommend the use of the UltraVNC [1], so, besides being very strong, support connection coding, and allow file transfer from one machine to other, it's OpenSource and free.

The limitations of this system are mainly the following:

  • Needs connection between your PC and the machine to monitor remotely. If it's behind one firewall or a Router, in Internet, it won't be able to connect.
  • Needs to know the IP. With Pandora FMS, it could tell to the agent that notifies the current IP to Pandora, and this will know which one is the IP, but sometimes it won't work well (if it has several network adapters, if it doesn't update the IP in an standard way or due to other possible causes)
  • Needs to install the UltraVNC software, may be that due to security policies it won't be able to install it.

In case that the problem is the first point, you could use the direct connection method through proxy, but the method shown there won't work, so you will need to download a client program and execute it manually from your PC in order to connect with the remote system.

1.3 Using TeamViewer with Pandora FMS

TeamViewer is one of the best remote management systems available. Teamviewer can use intermediate servers in Internet to connect with their equipments, regardless of changes in the IP, firewalls or other problems we've previously mentioned. You will only need three things:

  • Internet connection in both ends (the server to monitor and the operator's PC).
  • Take note of the machine ID and remember the password.
  • Install the TeamViewer software in the remote server.

Once it has been installed, you'll assign an ID to this machine and you'll have the chance to configure a password for permanent access. The TeamViewer IDs has the format "XXX XXX XXX" (nine digits). This is the ID you need to connect to a server. For this, we use the Enterprise feature "Customized fields" to create this field in all the agents and write there the ID of each machine.

I create the custom field (Configuration -> Agents -> Manage customized fields -> Create)

Custom field create.png

Once created, I can store there the ID of this machine, in this case 623 596 886

Custom field create1.png

Now, I only have to go to the TeamViewer page, [2] introduce my ID and go to the system:

Team viewer.png

1.3.1 Technical details about Teamviewer

TeamViewer is extremely powerful and it also allows to transfer files from one system to other one.

These tools are connected with remote servers, and the security could be a "problem" if we are specially " demanding" with these concepts (due to legal questions and/or privacy of data. With the commercial version there are, obviously, some advantages regarding this point.

This is a list of the connections fixed in the server managed remotely with a fixed TeamViewer connection:

TCP    desktop:1379   ESTABLISHED
TCP    desktop:1380   ESTABLISHED
TCP    desktop:1381   ESTABLISHED
TCP    desktop:1382   ESTABLISHED

Teamviewer also supports direct connection between the client and the server.

We strongly recomment to all enterprise users to buy a licence of TeamViewer to manage their servers. VNC is nice, but Teamviewer has a very efficient on the fly compression, and you will experience an incredible remote access experience managing remote hosts.

1.4 Connecting remote systems using SSH/Telnet from Pandora FMS

Since 4.0.2 version, Pandora FMS has a new extension to let users connect directly with devices by telnet or SSH. This is done with the Remote Gateway extension. You need to do a special setup for this component, not usually installed "by default". This is an opensource feature, based on anytermd software, published under GPL2 licence.

Ssh snapshot1.png

Ssh snapshot2.png

Pandora FMS uses a tool called "anytermd" to create a "proxy" between user browser and remote destination. This tool launches as a daemon, listeting in a port, and executing a command, forwarding all output to the user browser. That means all the connections are done FROM the pandora server and it has to be installed the telnet and ssh client. This is a basic architecture schema:


1.4.1 Install and setup

Sources are placed in extras/anytermd.

Make sure you have installed gnu c++ compiler (gcc-c++), make, boost-devel and zlib-devel.



Later, install manually the binary to /usr/bin

cp anytermd /usr/bin

To run the server daemons, you need to do manually, Pandora FMS server / console doesn't start up automatically. Pandora FMS SSH/Telnet extension will search for a different instance of anyterd running in 8023 for Telnet connections and 8022 for SSH connections.

You have a start/stop daemon in contrib/anytermd. Copy to /etc/init.d/anytermd and execute it like this:

/etc/init.d/anytermd start

By default uses "pandora" user for execution, if you want to change it, alter the script file for any other httpd based user your system may have.


This will use ports 8023 and 8022, be sure that ports are "open and clear" from the user browser to the console webserver system. No firewalls there


Now you're free to use the extension and connect remote servers by telnet or SSH.

Go back to Pandora FMS documentation index