Skip to content

Latest commit

 

History

History
183 lines (113 loc) · 8.04 KB

INSTALL.md

File metadata and controls

183 lines (113 loc) · 8.04 KB

Metalnx RMD Installation Guide

Revision 2.0

6/2016


Copyright © 2015-17 Dell EMC

Copyright © 2018 The University of North Carolina at Chapel Hill

This software is provided under the Software license provided in the LICENSE file.


TABLE OF CONTENTS

  1. Introduction
  2. Overview
  3. Metalnx RMD Installation
  4. Metalnx RMD Commands

INTRODUCTION

The Metalnx Web interface contains a dashboard that provides real-time information about the machines on the grid. For the UI to retrieve all this information, it uses the RMD (Remote Monitoring Daemon) which should be installed on each server in the iRODS grid.

RMD is a lightweight webserver that accepts limited HTTP requests and responds with JSON data. There are a few pre-defined requests to which RMD is programmed to respond to. It runs as a Linux-service with the server name: rmd.

RMD requires Python (version 2.6 or later) be installed on the iRODS provider and each iRODS consumer server. Please, note that iRODS should be setup on the server prior to RMD installation.

Metalnx will run without the RMD package. However, RMD is necessary to allow for complete dashboard and server detail page functions in Metalnx. With this package installed disk, memory, and CPU usage data of each server will be available.

In this installation guide we will explain how to install the Metalnx Remote Monitor Daemon (RMD) package on the Provider and each Consumer iRODS server in the iRODS grid.

[Back to: Table of Contents]


Metalnx RMD Overview

Metalnx RMD is a small, lightweight daemon which is installed (via .rpm or .deb package) on the iRODS Provider and each iRODS Consumer server in the grid. Metalnx RMD provides, on demand, basic availability information of each server in the iRODS grid which allows Metalnx to report on the overall health of the grid on its dashboard page to iRODS administrators.

RMD runs as the user iRODS and listens for a request on a port of the customer’s choosing via a configuration file (port 8000 is the default). When an iRODS admin views the dashboard page on Metalnx it issues update requests to the RMD daemon in the grid which will report memory, disk, and iRODS application status via JSON packets back to Metalnx.

The Metalnx application parses the information to build the dashboard and drill down pages. ( Note: Metalnx RMD is not required for the application to work, but without it the Dashboard page will have incomplete information and show each iRODS server without RMD to be in a Warning state.)

[Back to: Table of Contents]


Metalnx RMD Installation

Installation Process Overview

  • Verify the minimum system requirements for RMD are met. This may include installing Python 2.6 or later on each server.
  • Install the appropriate version of the Metalnx remote monitor daemon (RMD) on the iRODS Provider and each iRODS Consumer server.
  • Configure RMD on each server if the default configuration does not meet the requirements of your environment.

System Requirements

Python 2.6 or later version is required to run the RMD service and must be installed on the iRODS Provider server and each iRODS Consumer server that will run RMD.

For information on how to install Python, refer to: https://www.python.org/

Metalnx RMD Installation

RMD can be built as distribution-specific installation packages using the build instructions.

Install the RMD package on CentOS as root via the command:

# rpm -ivh emc-metalnx-rmd-2.0-0.noarch.rpm

Install the RMD package on a Debian distribution as root via the command:

 # dpkg -i emc-metalnx-rmd-2.0-0.deb
Controlling Metalnx RMD

By default, the RMD runs on port 8000. This property is editable in the configuration file of the daemon, located at /etc/rmd/rmd.conf:

 [daemon]
 ip=0.0.0.0
 port=8000

 [irods]
 server_logs_dir=/var/lib/irods/iRODS/server/log
 log_lines_to_show=20

The lines in this file correspond as follows:

  • ip: The IP address should not be changed. The value 0.0.0.0 is set for the machine to be visible by outside requests.
  • port: the port on where RMD should listen to requests. This can be changed to meet any firewall or security needs of your environment.
  • server_logs_dir: the directory where iRODS server logs are kept.
  • log_lines_to_show: the number of lines to get from the end of the iRODS server log to show in the Metalnx UI on the server details page. This is set initially to the last 20 lines

NOTE: If you change the port number for RMD in the file /etc/rmd/rmd.conf you must ALSO change the port number that Metalnx uses to communicate with RMD by editing the Metalnx properties file (metalnx.properties) in /etc/irods-ext. This must be done after Metalnx is installed. Look for and edit the line rmd.connection.port=8000.

[Back to: Table of Contents]


Metalnx RMD Commands

Metalnx RMD responds to the following commands sent to is over the listen port.

Request

Result

/ Returns all the other commands in a single JSON-like object. For development purposes, this call should be avoided due to its long response time.
/cpu CPU related information.
/cpustat CPU usage statistics.
/disk Disk and partition information of the system.
/irodslogs The last pre-defined number of lines of the iRODS server log. This number is set in the RMD configuration file. (see Controlling section above)
/irodsstatus Status of the iRODS process.
/memory Memory-related data.
/mounts Lists all the file systems mounted on the current machine.
/serverstatus System-wide status, taking into consideration all the others specific status listed above.
/version Returns a JSON-like object containing the version and release numbers for the current instance of RMD.
Confirm RMD Acccess

Once RMD is installed and configured, a quick test can be done to ensure that RMD is correctly working.

Open a browser window and access: http://<IP_OF_THE_RMD_MACHINE>:<PORT>/disk It should list all the disk-related information of your machine in JSON format. For example:

http://192.168.1.157:8000/disk
RMD Troubleshooting

If a firewall is set up on the iRODS server, make sure that the port where RMD listens is opened. On IPTables it can be done by adding the following line to the iptables.conf file for port 8000 and reloading iptables:

-A INPUT -m state --state NEW -m tcp -p tcp --dport 8000 -j ACCEPT

If the RMD process get stuck, remove the PID file located at /var/run/rmd.pid and kill the process.

[Back to: Table of Contents]