Simple steps to setup munin to monitor ubuntu server including nginx requests, memory and status
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Type Name Latest commit message Commit time
Failed to load latest commit information.



How's your server doing? Encharge your new rails server with stats from munin. This steps will take you through installing munin and the munin nginx plugins. Unless you haven't installed nginx follow the steps at rails-nginx-passenger-ubuntu. But in the configure add --with-http_stub_status_module argument.

alt "CPU Load"

If you already installed nginx, check the latest configure argument with the -V flag and recompile it with --with-http_stub_status_module

$ /opt/nginx/sbin/nginx -V
nginx version: nginx/0.7.63
configure arguments: --prefix=/opt/nginx --add-module=/opt/ruby/lib/ruby/gems/1.8/gems/passenger-2.2.5/ext/nginx --with-http_ssl_module --with-pcre=/home/deploy/src/pcre-8.00/

About Munin

Munin the monitoring tool surveys all your computers and remembers what it saw. It presents all the information in graphs through a web interface. Its emphasis is on plug and play capabilities. After completing a installation a high number of monitoring plugins will be playing with no more effort.

Using Munin you can easily monitor the performance of your computers, networks, SANs, applications, weather measurements and whatever comes to mind. It makes it easy to determine "what's different today" when a performance problem crops up. It makes it easy to see how you're doing capacity-wise on any resources.

Munin website | MuninExchange plugin catalog

Out of the box it comes with a lot of useful stats for a rails developer (and system administrator). For example cpu, forks, interrupts. iostat. irqstats. load. memory, mysql_bytes, mysql_queries. mysql_slowqueries. mysql_threads. netstat, open_files, open_inodes, processes, sendmail_mailqueue, sendmail_mailstats, sendmail_mailtraffic, swap amd vmstat


mkdir -p src
cd src

# PCRE Library
wget && tar xvfz pcre-8.00.tar.gz && rm pcre-8.00.tar.gz

# Nginx source
wget && tar xvfz nginx-0.X.YY.tar.gz && rm nginx-0.X.YY.tar.gz
cd nginx-0.X.YY
./configure --prefix=/opt/nginx [--add-module=/opt/ruby/lib/ruby/gems/1.8/gems/passenger-2.2.5/ext/nginx] [--with-http_ssl_module] --with-pcre=~/src/pcre-8.00/ --with-http_stub_status_module
sudo make install

Munin and Munin-node

We will install both munin master and munin node on the same machine.

sudo apt-get install munin munin-node

Edit the file /etc/munin/munin.conf and after the comment # a simple host tree change the follwing lines

    use_node_name yes

This will tell munin to connect to munin-node at on the same machine.

Edit the file /etc/munin/munin-node.conf and change # Which port to bind to set


Make sure that this is present in the file

allow ^127\.0\.0\.1$


Configure stub status

# Nginx status
server {
  listen 80;
  server_name localhost;
  location /nginx_status {
    stub_status on;
    access_log off;
    deny all;

Restart nginx and make sure this works with

telnet localhost 80
# and write
GET /nginx_status
# Should respond with
Active connections: X 
server accepts handled requests
 X X X
Reading: X Writing: X Waiting: X 

links http://localhost/nginx_status

Add a new vhosts for the munin-graph

server {
 listen 80;
 location / {
   deny all;
   root /var/www/munin;

Munin nginx plugins

cd /usr/share/munin/plugins
sudo wget -O nginx_request
sudo wget -O nginx_status
sudo wget -O nginx_memory 

sudo chmod +x nginx_request
sudo chmod +x nginx_status
sudo chmod +x nginx_memory    

sudo ln -s /usr/share/munin/plugins/nginx_request /etc/munin/plugins/nginx_request
sudo ln -s /usr/share/munin/plugins/nginx_status /etc/munin/plugins/nginx_status
sudo ln -s /usr/share/munin/plugins/nginx_memory /etc/munin/plugins/nginx_memory

Edit /etc/munin/plugin-conf.d/munin-node and add the lines

env.url http://localhost/nginx_status

Restart munin-node with

sudo /etc/init.d/munin-node restart

CentOS Note

Everything seems to work on Centos 5.5 with one small exception: pidof lives in /sbin and the nginx_memory plugin expects it to be in the PATH. There are several solutions: 1. symlink pidof to /bin 2. add /sbin to PATH (not recommended) 3. edit the plugin and change pidof to be /sbin/pidof

Browse to

Wait 5 minutes so munin will generate the graphs then go to