This tutorial will discuss how you can install and run Collectd-web interface, which is a front-end web monitoring tool for Collectd daemon, in conjunction with Apache CGI interface in order to produce graphical html outputs in order to monitor Linux boxes.
data:image/s3,"s3://crabby-images/8c1cf/8c1cfe71d830cb98aaaea1e26bccdee539099df6" alt="Monitor Linux Server Resources"
At the end of the article we will, also, present how you can protect Collectd-web interface using .hpasswd Apache Authentication mechanism.
Requirements
The requirement of this article is, you must have Collectd and Collectd-Web installed on your Linux system. To install these packages, you must follow Steps #1 and #2 from the previous article of this series at:
Only Follow following two steps from the above link:
Step 1: Install Collectd Service Step 2: Install Collectd-Web and Dependencies
Once these two required things completed successfully, you can continue further instructions in this article to configure Collectd-web with Apache CGI.
Step 1: Installing Apache Web Server
1. Assuming that you already have installed Apache web server on your system, if not you can install using following command according to your Linux distribution.
# apt-get install apache2 [On Debian based Systems] # yum install httpd [On RedHat based Systems]
2. After Apache installed, change the directory to your default web server document root (which is located under /var/www/html/ or /var/www system path and clone the Collectd-web Github project by issuing the below commands:
# cd /var/www/html # git clone https://github.com/httpdss/collectd-web.git
Also, make the following Collectd-web script executable by issuing the following command:
# chmod +x /var/www/html/collectd-web/cgi-bin/graphdefs.cgi
Step 2: Enable Apache CGI (.cgi scripts) for Default Host
3. In order for Apache to run the CGI scripts located under the default host HTML Collectd-web cgi-bin directory, you need to explicitly enable Apache CGI interface for Bash scripts (with .cgi extension) by altering the sites-available default host and adding the below statements block.
On Debian Systems
First open Apache default host configuration file for editing with nano editor:
# nano /etc/apache2/sites-available/000-default.conf
While the file is opened for editing add the following directive block below the Document Root directive as illustrated on the below image:
<Directory /var/www/html/collectd-web/cgi-bin> Options Indexes ExecCGI AllowOverride All AddHandler cgi-script .cgi Require all granted </Directory>
data:image/s3,"s3://crabby-images/f9cc9/f9cc910de875040bdbb026a736b8b9576ab7e1cb" alt="Enable CGI in Debian"
After you’re done editing the file, close it with CTRL + o and exit nano editor (CTRL+x), then enable Apache CGI module and restart the server in order to apply all the changes made so far by issuing the below commands:
# a2enmod cgi cgid # service apache2 restart OR # systemctl restart apache2.service [For systemd init scripts]
data:image/s3,"s3://crabby-images/185a1/185a19597a16d708a542493eab43ac37820d061f" alt="Enable Apache CGI"
On RedHat Systems
4. To enable Apache CGI interface for CentOS/RHEL, open httpd.conf Apache configuration file and add the following lines at the bottom of the file:
# nano /etc/httpd/conf/httpd.conf
Add following excerpt to httpd.conf file.
ScriptAlias /cgi-bin/ “/var/www/html/collectd-web/cgi-bin" Options FollowSymLinks ExecCGI AddHandler cgi-script .cgi .pl
In order to apply changes, restart httpd daemon by issuing the following command:
# service httpd restart OR # systemctl restart httpd [For systemd init scripts]
Step 3: Browse Collectd-web Interface
5. In order to visit Collectd-web interface and visualize statistics about your machine collected so far, open a browser and navigate to your machine IP Address/collectd-web/ URI location using the HTTP protocol.
http://192.168.1.211/collect-web/
data:image/s3,"s3://crabby-images/6eef4/6eef40617115ed6a2ba2267e9286dfbd25805327" alt="Collectd-Web Dashboard"
Step 4: Password Protect Collectd-web URL using Apache Authentication
6. In case you want to limit access to Collectd-web interface by protecting it using Apache Authentication mechanism (.htpasswd), which requires visitors to enter a username and a password in order to access a web resource.
To do so, you need to install apache2-utils package and create a set of credentials for local authentication. To achieve this goal, first issue the following command to install apache2-utils package:
# apt-get install apache2-utils [On Debian based Systems] # yum install httpd-tools [On RedHat based Systems]
7. Next, generate a username and a password which will be stored on a hidden local .htpass file located under Apache default host Collectd-web path by issuing the below command:
# htpasswd -c /var/www/html/collectd-web/.htpass your_username
Try to protect this file by assigning the following permissions:
# chmod 700 /var/www/html/collectd-web/.htpass # chown www-data /var/www/html/collectd-web/.htpass
8. On the next step, after you have generated .htpass file, open Apache default host for editing and instruct the server to use htpasswd basic server-side authentication by adding the following directive block as illustrated on the below screenshot:
<Directory /var/www/html/collectd-web > AuthType Basic AuthName "Collectd Restricted Page" AuthBasicProvider file AuthUserFile /var/www/html/collectd-web/.htpass Require valid-user </Directory>
data:image/s3,"s3://crabby-images/ab3b8/ab3b8e849b814af9d704a7b6fe57aca00eed4f61" alt="Apache Password Protect Directory"
9. The last step in order to reflect changes is to restart Apache server by issuing the below command and visit the Coollectd-web URL page as described above.
A pop-up should appear on the web page requesting for your authentication credentials. Use the username and password created earlier to access Collectd web interface.
# service apache2 restart [On Debian based Systems] # service httpd restart [On RedHat based Systems] OR ---------------- For systemd init scripts ---------------- # systemctl restart apache2.service # systemctl restart http.service
data:image/s3,"s3://crabby-images/85c91/85c91eb26ffa1c348d18d1f3f4cf6e230835a018" alt="Apache Password Authentication"
data:image/s3,"s3://crabby-images/9770e/9770eef3fc9fdcd90ae4fe76e02b0f0994d56cc6" alt="Collectd-Web Panel"
Your problem look like you don’t have a correct PHP version to support the app.
Another issue could cause by your php mode does not enable yet. to enable php mode you should use this command:
@Naseath,
Thanks a ton for helping our fellow readers, keep it up and stay connected to TecMint and looking forward for your support in future..
Hi,
Configured the Collectd-web for Apache2.4.7 but when i open the url as: http:///collectd-web/ instead of graphical page displaying the html source and http:///collectd-web/index.html the ui is scattered around the browser nothing is displaying..
iam using the following broswers
Firefox version 42.0
chrome Version 46.0.2490.86 m
explorer version 9.0.8112
kindly do the needfull.