Skip to content

Cacti/rrdproxy

Repository files navigation

rrdproxy

Cacti RRDtool Proxy Server is a standalone proxy interface to Tobi Oetiker's great RRDtool.

The main focus of this project is to allow the relocation of RRD files, data replication, support of Cacti Boost and, if needed, the RRDcached daemon. It allows system administrators to split Cacti's access resources across machines without the need for NFS.

Due the fact that updates to files may contain sensitive data and to prevent undesired updates, RRDtool proxy utilizes high encrypted connections (RSA2048 and AES192) with continuously changing keys. This ensures a secured connection between the proxy and registered clients and/or other proxies.

A local service port is provided to allow administrators are able to access a separate command line interface which provides easy access to configure and debug the proxy.

Contribute

Get involved in development by participating in active development on GitHub.

Requirements

RRDtool Proxy Server runs on any Unix-based operating system that can meet the minimum requirements, though it will perform better with the recommended (or higher).

Minimum Requirements

  • PHP Version 7.2 or higher Installation must include and enable the following modules:

    • Sockets

    • Posix

    • PCntl

    • GMP

    • ZLIB

  • RRDtool Version 1.5 or higher

  • Cacti Version 1.2.7 or higher

Recommended Requirements

All minimum requirements must be met, though the following are more optional:

  • PHP Version 7.3 or higher Include all minimum recommendation modules

  • RRDtool 1.7 or higher

  • Cacti 1.2.7

Usage

Before using the RRDtool Proxy Server, you must install the system using the setup wizard which can be run at any point using the -w parameter.

 php rrdtool-proxy.php --help

 RRDtool Proxy v1.2.17
 Copyright (C) 2004-2024 The Cacti Group
 usage: rrdtool-proxy.php [--wizard] [-w] [--version] [-v]
 Optional:
 -v --version   - Display this help message
 -w --wizard    - Start Configuration Wizard

When running through the wizard, the status of items will appear on the right hand side of the screen. When an item is successfully completed, the status of [OK] will be shown in green (when color is supported) as seen below:

Checking System Requirements...
[0.00001] test: operation system supported                                  [OK]
[0.00007] test: php module 'sockets'                                        [OK]
[0.00011] test: php module 'posix'                                          [OK]

Should any item have an issue, the status will be displayed as something other than [OK] such as [FAILED]:

[0.40270] read: RRDproxy configuration file                             [FAILED]

Status Color | Description : --- | : --- Green | Success and without issue Yellow | Warnings and will be ignored, correct the problem if needed Red | Errors and will not be ignored, may prevent continuation

When the wizard prompts for the various settings that are available, you can accept the default value simply by pressing return to accept it. Below are a few of these settings and the default values that can be accepted:

Setting | Default | Comment : --- | : --- | : --- CLI System Prompt | rrdp | Max 8 chars IPv4 Listen Addr | 0.0.0.0 | Listen all addr Client Proxy Port | 40301 | Connections from a client Proxy Proxy port | 40302 | Connections from another proxy Dedicated CLI port | 40303 | Connections to the proxy cli

If the wizard displays a prompt that requires a response and it has no default, you will be prompted again until a valid response has been entered.

Command Line Interface

Use '?' or 'help' to get a list of all commands being supported by the proxy or hints about missing parameters. The following shows an example of using the CLI to list the available commands to find the version of RRDtool Proxy Server.

Note: that most commands require that the CLI is in privileged mode and this password is encrypted in the configuration so cannot be guessed. If the password has been forgotten, it can be reset using the RRDtool Proxy Server Wizard but the background process will need to be manually terminated.

telnet localhost 40303
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
rrdp>?
  enable          Turn on privileged commands
  help            Display help
  show            Show running system information
  quit            Close terminal session

rrdp>ena Tester12

rrdp# help
  clear           Clear functions for internal buffers
  disable         Turn off privileged commands
  reset           Reset terminal screen
  set             Configure proxy settings
  show            Show running system information
  shutdown        Close all connections and shut down proxy
  quit            Close terminal session

rrdp# show ?
  clients         List all trusted client connections
  counters        Return all system counters
  cluster         List all trusted cluster peers
  logging         Display state of logging
  msr             Display replication state
  processes       Display running child processes
  rsa             Show Encryption setup
  threads         Display currently open connections
  variables       Show Current Operating configuration
  version         System software status

rrdp#sh version

#     ___           _   _     __    __    ___     ___
#    / __\__ _  ___| |_(_)   /__\  /__\  /   \   / _ \_ __ _____  ___   _
#   / /  / _` |/ __| __| |  / \// / \// / /\ /  / /_)/ '__/ _ \ \/ / | | |
#  / /__| (_| | (__| |_| | / _  \/ _  \/ /_//  / ___/| | | (_) >  <| |_| |
#  \____/\__,_|\___|\__|_| \/ \_/\/ \_/___,'   \/    |_|  \___/_/\_\__, |
#                                                                   |___/

 RRDtool Proxy v1.2.17
 Copyright (C) 2004-2024 The Cacti Group
 rrdp uptime is 14 days, 0 hours, 4 minutes, 14 seconds
 Memory usage 0.18872917 % (2026464/1073741824 in bytes)
 a8:29:6a:b7:5d:be:c3:8a:be:13:7a:61:ee:0c:8b:d3
 Process ID: 13996
 Session usage (1/399)

 Server IP [192.168.10.10]
 Administration: [localhost       :40303]
 Replication:    [192.168.10.10   :40302]
 Clients:        [192.168.10.10   :40301]

rrdp#

Planned features

  • Data replication

    This is currently being written and has been mostly completed, but it is still being tested and so hasn't been made available yet.

  • Proxy stats via SNMP

    A NET-SNMP persistent daemon and MIB needs to written to enabled support of proxy stats via SNMP. This could lead to an interesting loop of Cacti storing stats for RRDproxy within RRDproxy.

  • International language support

    Currently, the RRDproxy wizard and command line interface port are both offering only english as the default language.