Using SNMP for administ PogoPlug
Oct 14, 2013Technology
###Preparation For using SNMP for administrating PogoPlug, we have to install following packages first:
# apt-get install snmpd smartmontools super
snmpd is the daemon process for snmp, smartmontools is the monitor tools for harddisk, super let you run daemon process in super priviledge.
###Configuration
Configure snmp firstly.
###Client Configuration Install the webserver using the following command:
$ pacman -S apache php php-apache mariadb
After install the packages, if you want to change the configuration file, directly edit the /etc/httpd/conf/httpd.conf or extra/httpd-default.conf, then using systemd to restart the httpd daemon.
Change priviledge of the public_html directory:
$ chmod o+x ~
$ chmod o_x ~/public_html
# A more safe way for controlling the safety
# usermod -aG groupname http
###SSL Configuration Generate a new self-signed certificate(key size and the number of days of validity will be customized):
# openssl genrsa -out server.key 2048
Generating RSA private key, 2048 bit long modulus
..........................+++
...........................................................................................................................................................+++
e is 65537 (0x10001)
[root@XXXyyy conf]# ls
extra httpd.conf magic mime.types server.key
[root@XXXyyy conf]# chmod 600 server.key
[root@XXXyyy conf]# openssl req -new -key server.key -out server.csr
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:
State or Province Name (full name) [Some-State]:
Locality Name (eg, city) []:
Organization Name (eg, company) [Internet Widgits Pty Ltd]:
Organizational Unit Name (eg, section) []:
Common Name (e.g. server FQDN or YOUR name) []:
Email Address []:
Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:
An optional company name []:
[root@XXXyyy conf]# openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt
Signature ok
subject=/C=AU/ST=Some-State/O=Internet Widgits Pty Ltd
Getting Private key
[root@XXXyyy conf]# ls
extra httpd.conf magic mime.types server.crt server.csr server.key
Then, uncomment the line containing following lines in /etc/httpd/conf/httpd.conf:
Include conf/extra/httpd-ssl.conf
Restart httpd to see the result.
###Enable php Place Following line after LoadModule dir_module modules/mod_dir.so in /etc/httpd/conf/httpd.conf:
LoadModule php5_module modules/libphp5.so
Place following line at the end of the Include list:
Include conf/extra/php5_module.conf
Make sure you uncommented following line:
TypesConfig conf/mime.types
# Optional uncomment:
MIMEMagicFile conf/magic
Add this line in /etc/httpd/conf/mime.types:
application/x-httpd-php php php5
Make sure libphp5.so is under /etc/httpd/modules, if not, you may forgot to install php-apache.
Test the php via following line under test.php:
<?php phpinfo(); ?>
###Configure MariaDB Uncomment at least one line under /etc/php/php.ini:
extension=pdo_mysql.so
extension=mysqli.so
extension=mysql.so
###Mysql Configuration
[root@XXXyyy http]# mysqld_safe --skip-grant-tables &
[1] 26315
[root@XXXyyy http]# 131014 16:55:07 mysqld_safe Logging to '/var/lib/mysql/XXXyyy.err'.
131014 16:55:07 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
[root@XXXyyy http]# mysql -u root mysql
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 6
Server version: 5.5.33a-MariaDB-log Source distribution
Copyright (c) 2000, 2013, Oracle, Monty Program Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [mysql]> UPDATE mysql.user SET Password=PASSWORD('******') WHERE User='root';
Query OK, 4 rows affected (0.00 sec)
Rows matched: 4 Changed: 4 Warnings: 0
MariaDB [mysql]> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)
MariaDB [mysql]> exit
Bye
[root@XXXyyy http]# systemctl start mysqld
###CACTI configuration Install cacti via:
$ pacman -S cacti
$ pacman -S php-snmp
uncomment the following lines in /ec/php/php.ini:
;extension=mysql.so
;extension=sockets.so
;extension=snmp.so
open_basedir=...
;date.timezone =
Start mysqld:
$ systemctl enable mysqld.service
$ systemctl start mysqld.service
Start snmpd:
$ systemctl enable snmpd
$ systemctl start snmpd
Change the configuration file /etc/httpd/conf/httpd.conf, inside <Directory “/srv/http"> block, ensure you have:
AllowOverride All
Create the mysql based db:
$ mysqladmin -u root -p create cacti
Enter password:
Generate the sql table using existing template:
[root@XXXyyy http]# mysql -u root -p cacti < /usr/share/webapps/cacti/cacti.sql
Enter password:
Update the configuration of the database, you can replace the password from “some_password” to your own password.
[root@XXXyyy http]# mysql -u root -p
Enter password:
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 10
Server version: 5.5.33a-MariaDB-log Source distribution
Copyright (c) 2000, 2013, Oracle, Monty Program Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> GRANT ALL ON cacti.* TO cacti@localhost IDENTIFIED BY 'some_password';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> exit
Bye
Change the username and password of the config.php of cacti:
$ vim /usr/share/webapps/cacti/include/config.php
$ database_username = "cacti";
$ database_password = "some_password";
Clean up the cacti directory:
chown -R http:http /usr/share/webapps/cacti/{rra,log}
rm /usr/share/webapps/cacti/.htaccess
chmod +x /usr/share/webapps/cacti/{cmd,poller}.php /usr/share/webapps/cacti/lib/ping.php
Install caccti-spine, a fast poller for cacti, from AUR. Change the db name and db password to:
$ vim /etc/spine.conf
DB_User cacti
DB_Pass some_password
Restart crontab:
$ systemctl restart cronie.service
$ systemctl restart httpd