An agent that polls supported backend systems and submits the results to the NewRelic platform. Currently supported backend systems are:
- Alternative PHP Cache
- Apache HTTP Server
- CouchDB
- Edgecast CDN "Realtime" API
- Memcached
- MongoDB
- Nginx
- pgBouncer
- PostgreSQL
- RabbitMQ
- Redis
- Riak
- uWSGI
Version 1.0.12 has a SERIOUS uninstallation bug in the file manifest that will remove all the files on your filesystem if you try and do a pip remove newrelic_plugin_agent.
Version 1.0.13 and greater will attempt to fix the issue when doing a pip upgrade BUT you should also run the script "fix_nrp_manifest.py" (or the older fix_removal.py) to clean up the erroneous entries in the installed-files.txt manifest file in your python site-packages directory.
You can run this script manually using using curl and python:
curl --insecure https://gist.github.com/gmr/6031454/raw/fix_nrp_manifest.py | python
If you do not see "Fixed a serious uninstallation problem in previous version" in the output, then it did not find a problem, which means more diagnosing is required. Before opening a ticket, you can run the following commands to try and find the problem:
ls -al `python -c "from distutils import sysconfig; print sysconfig.get_python_lib()"` |grep newrelic_plugin
cat `python -c "from distutils import sysconfig; print sysconfig.get_python_lib()"`/newrelic_plugin_agent-1.0.12-*.egg-info/installed-files.txt
If those do not provide output, you will need to look for your Python site-packages directory. You can manually uninstall newrelic_plugin_agent if you find the appropriate site packages directory where it was installed and remove the newrelic_plugin_agent directory and the newrelic_plugin_agent-1.0.12-*.egg-info directory.
The agent requires Python 2.6 or 2.7 and pip for installation. Individual plugin backends may require additional libraries and are detailed below.
The configuration file uses YAML as its format. Most tickets for non-working installs are due to configuration file formatting errors. Please make sure you are properly formatting your configuration file prior to submitting a ticket. YAML is a whitespace dependent markup format. More information on writing proper YAML can be found at http://yaml.org.
-
Install via pip*:
pip install newrelic-plugin-agent
- See pip installation instructions at http://www.pip-installer.org/en/latest/installing.html
-
Copy the configuration file example from /opt/newrelic_plugin_agent/newrelic_plugin_agent.cfg to /etc/newrelic/newrelic_plugin_agent.cfg and edit the configuration in that file.
-
Make a /var/log/newrelic directory and make sure it is writable by the user specified in the configuration file
-
Make a /var/run/newrelic directory and make sure it is writable by the user specified in the configuration file
-
Run the app:
newrelic_plugin_agent -c PATH-TO-CONF-FILE [-f]
Where -f is to run it in the foreground instead of as a daemon.
Sample configuration and init.d scripts are installed to /opt/newrelic_plugin_agent in addition to a PHP script required for APC monitoring.
To use the MongoDB the mongodb library is required. For the pgBouncer or PostgreSQL plugin you must install the psycopg2 library. To easily do this, make sure you have the latest version of pip installed (http://www.pip-installer.org/). This should be done after installing the agent itself.
Once installed, from inside the source directory run the following command:
pip install -e .[mongodb]
or
pip install -e .[pgbouncer]
or
pip install -e .[postgresql]
Each plugin can support gathering data from a single or multiple targets. To support multiple targets for a plugin, you create a list of target stanzas:
plugin_name:
- name: target_name
host: localhost
foo: bar
- name: target_name
host: localhost
foo: bar
While you can use the multi-target format for a plugins configuration stanza like:
plugin_name:
- name: target_name
host: localhost
foo: bar
You can also use a single mapping like follows:
plugin_name:
name: target_name
host: localhost
foo: bar
The fields for plugin configurations can vary due to a plugin's configuration requirements. The name value in each stanza is only required when using multiple targets in a plugin. If it is only a single target, the name will be taken from the server's hostname.
Copy the apc-nrp.php script to a directory that can be served by your web server or php-fpm application. Edit the newrelic_plugin_agent configuration to point to the appropriate URL.
Enable the HTTPd server status page in the default virtual host. The following example configuration snippet for Apache HTTPd 2.2 demonstrates how to do this:
<Location /server-status>
SetHandler server-status
Order deny,allow
Deny from all
Allow from all
</Location>
For HTTPd 2.4, it should look something like:
<Location /server-status>
SetHandler server-status
Require ip 127.0.0.1
</Location>
The agent requires the extended information to parse metrics. If you are not seeing any metrics on your graphs for Apache verify that you have enable ExtendedStatus, the default is off so you must enable it. In your global Apache HTTP configuration you need to enable exetended status using:
ExtendedStatus On
If you are monitoring Apache HTTPd via a HTTPS connection you can use the verify_ssl_cert configuration value in the httpd configuration section to disable SSL certificate verification.
The memcached plugin can communicate either over UNIX domain sockets using the path configuration variable or TCP/IP using the host and port variables. Do not include both.
You need to install the pymongo driver, either by running "pip install pymongo" or by following the "Installing Additional Requirements" above. Each database you wish to collect metrics for must be enumerated in the configuration.
There are two configuration stanza formats for MongoDB. You must use one or the other, they can not be mixed. For non-authenticated polling, you can simply enumate the databases you would like stats from as a list:
mongodb:
name: hostname
host: localhost
port: 27017
databases:
- database_name_1
- database_name_2
If your MongoDB server requires authentication, you must provide both admin credentials and database level credentials and the stanza is formatted as a nested array:
mongodb:
name: hostname
host: localhost
port: 27017
admin_username: foo
admin_password: bar
databases:
database_name_1:
username: foo
password: bar
database_name_2:
username: foo
password: bar
Enable the nginx stub_status setting on the default site in your configuration. The following example configuration snippet for Nginx demonstates how to do this:
location /nginx_stub_status {
stub_status on;
}
If you are monitoring Nginx via a HTTPS connection you can use the verify_ssl_cert configuration value in the httpd configuration section to disable SSL certificate verification.
The user specified must be a stats user.
By default user specified must superuser to get PostgreSQL directory listings. If you want to
use this plugin without need of superuser permissions use superuser: False
setting in
configuration file e.g.:
postgresql:
host: localhost
port: 5432
user: newrelic
dbname: postgres
password: newrelic
superuser: False
The user specified must have access to all virtual hosts you wish to monitor and should have either the Administrator tag or the Monitor tag.
If you are monitoring RabbitMQ via a HTTPS connection you can use the verify_ssl_cert configuration value in the httpd configuration section to disable SSL certificate verification.
As of 1.0.13 there is "detailed" mode which adds consumer counts by hostname for queues. This is a slow inspection and should be avoided on RabbitMQ clusters with large queue counts.
For Redis daemons that are password protected, add the password configuration value, otherwise omit it. The Redis configuration section allows for multiple redis servers. The syntax to poll multiple servers is in the example below.
The Redis plugin can communicate either over UNIX domain sockets using the path configuration variable or TCP/IP using the host and port variables. Do not include both.
If you are monitoring Riak via a HTTPS connection you can use the verify_ssl_cert configuration value in the httpd configuration section to disable SSL certificate verification.
The UWSGI plugin can communicate either over UNIX domain sockets using the path configuration variable or TCP/IP using the host and port variables. Do not include both.
%YAML 1.2
---
Application:
license_key: REPLACE_WITH_REAL_KEY
poll_interval: 60
#proxy: http://localhost:8080
apache_httpd:
- name: hostname1
scheme: http
host: localhost
port: 80
path: /server-status
#verify_ssl_cert: true
- name: hostname2
scheme: http
host: localhost
port: 80
path: /server-status
#verify_ssl_cert: true
couchdb:
- name: localhost
host: localhost
port: 5984
#verify_ssl_cert: true
#username: foo
#password: bar
- name: localhost
host: localhost
port: 5984
#verify_ssl_cert: true
#username: foo
#password: bar
edgecast:
- name: My Edgecase Account
account: ACCOUNT_NUMBER
token: API_TOKEN
mongodb:
name: hostname
host: localhost
port: 27017
admin_username: foo
admin_password: bar
databases:
database_name_1:
username: foo
password: bar
database_name_2:
username: foo
password: bar
memcached:
- name: localhost
host: localhost
port: 11211
path: /path/to/unix/socket
- name: localhost
host: localhost
port: 11211
path: /path/to/unix/socket
nginx:
- name: hostname
host: localhost
port: 80
path: /nginx_stub_status
#verify_ssl_cert: true
- name: hostname
host: localhost
port: 80
path: /nginx_stub_status
#verify_ssl_cert: true
pgbouncer:
- host: localhost
port: 6000
user: stats
php_apc:
scheme: http
host: localhost
port: 80
path: /apc-nrp.php
#username: foo
#password: bar
#verify_ssl_cert: t
postgresql:
- host: localhost
port: 5432
user: postgres
dbname: postgres
superuser: True
rabbitmq:
- name: rabbitmq@localhost
host: localhost
port: 15672
username: guest
password: guest
#verify_ssl_cert: true
redis:
- name: localhost
host: localhost
port: 6379
db_count: 16
password: foobar
#path: /var/run/redis/redis.sock
- name: localhost
host: localhost
port: 6380
db_count: 16
password: foobar
#path: /var/run/redis/redis.sock
riak:
- name: localhost
host: localhost
port: 8098
#verify_ssl_cert: true
Daemon:
user: newrelic
pidfile: /var/run/newrelic/newrelic_plugin_agent.pid
Logging:
formatters:
verbose:
format: '%(levelname) -10s %(asctime)s %(process)-6d %(processName) -15s %(threadName)-10s %(name) -25s %(funcName) -25s L%(lineno)-6d: %(message)s'
handlers:
file:
class : logging.handlers.RotatingFileHandler
formatter: verbose
filename: /var/log/newrelic/newrelic_plugin_agent.log
maxBytes: 10485760
backupCount: 3
loggers:
newrelic_plugin_agent:
level: INFO
propagate: True
handlers: [console, file]
requests:
level: ERROR
propagate: True
handlers: [console, file]
-
If the installation does not install the "newrelic_plugin_agent" application in /usr/bin then it is likely that setuptools or distribute is not up to date. The following commands can be run to install distribute and pip for installing the application:
curl http://python-distribute.org/distribute_setup.py | python curl https://raw.github.com/pypa/pip/master/contrib/get-pip.py | python
-
If the application installs but doesn't seem to be submitting status, check the logfile which at /tmp/newrelic_plugin_agent.log if the default example logging configuration is used.
-
If the agent starts but dies shortly after ensure that /var/log/newrelic and /var/run/newrelic are writable by the same user specified in the daemon section of the configuration file.
-
If the agent has died and won't restart, remove any files found in /var/run/newrelic/
-
If using the Apache HTTP plugin and your stats are blank, ensure the ExtendedStatus directive is on.