源码包:
httpd-2.2.24.tar.gz
php-5.2.17.tar.gzcd
mysql-5.1.73-linux-x86_64-glibc23.tar.gz
其余依赖程序均通过yum源来安装,推荐EPEL和CentOS
163镜像
http://mirrors.163.com/
http://mirror.centos.org/
epel镜像
http://mirrors.fedoraproject.org
操作步骤:
mysql安装:
tar zxf mysql-5.1.73-linux-x86_64-glibc23.tar.gz -C /usr/local/
mv mysql-5.1.73-linux-x86_64-glibc23/ mysql
chown -R mysql.root mysql/ # 修改mysql目录的权限
chown -R mysql. mysql/data/ # 修改mysql数据目录的权限
初始化mysql
./scripts/mysql_install_db --basedir=/usr/local/mysql \ --datadir=/usr/local/mysql/data \ --defaults-file=/usr/local/mysql/my.cnf \ --skip-name-resolve --user=mysql
拷贝自启动脚本:
cp mysql.server /etc/init.d/mysqld
修改启动脚本中的内容,明确告诉启动脚本mysql的运行路径
basedir=/usr/local/mysql #46行
datadir=/usr/local/mysql/data #47行
pid_file=/usr/local/mysql/mysql_v51.pid #59行
conf=/usr/local/mysql/my.cnf #218行
my.cnf配置文件主要部分
[mysqld] port = 3306 socket = /usr/local/mysql/mysql.sock skip-external-locking key_buffer_size = 16M max_allowed_packet = 1M table_open_cache = 64 sort_buffer_size = 512K net_buffer_length = 8K read_buffer_size = 256K read_rnd_buffer_size = 512K myisam_sort_buffer_size = 8M
/etc/init.d/mysqld start
Starting MySQL.[ OK ]
源码编译安装http:
先安装apr-1.5.1,编译安装时指定:
./configure --prefix=/usr/local/apr --disable-ipv6 LDFLAGS=-L/usr/lib64
apr-util-1.5.3,编译安装时指定:
./configure --prefix=/usr/local/apr \ --with-apr=/usr/local/apr/bin/apr-1-config \ --with-mysql=/usr/local/mysql \ LDFLAGS=-L/usr/lib64
编译安装apache
./configure --prefix=/usr/local/apache2 \- -enable-so \ --enable-modules=all \ --enable-mods-shared=all \- -with-mpm=worker --with-apr=/usr/local/apr/bin/apr-1-config \ --with-apr-util=/usr/local/apr/bin/apu-1-config \ --with-pcre \ --enable-disk-cache \ --enable-mem-cache \ --enable-file-cache \ --enable-cache \ --enable-cgi \ --enable-authn-alias \ --enable-proxy \ --enable-proxy-ftp \ --enable-proxy-http \ --enable-proxy-scgi \ --enable-proxy-connect \ --enable-proxy-balancer \ --enable-suexec \ LDFLAGS=-L/usr/lib64
make && make install
chown -R apache.root apache2/
http配置主要部分:篇幅问题无法写全
ServerRoot "/usr/local/apache2"
Listen 8085
ServerName 10.28.7.127:8085
DocumentRoot "/usr/local/apache2/htdocs"
<IfModule dir_module>
DirectoryIndex index.html index.php
</IfModule>
编译安装php:
编译参数参照yum源安装的PHP包时使用的选项
./configure --build=x86_64-redhat-linux-gnu \ --host=x86_64-redhat-linux-gnu \ --target=x86_64-redhat-linux-gnu \ --prefix=/usr/local/php \ --with-libdir=lib64 \ --with-config-file-path=/usr/local/php/etc \ --with-apxs2=/usr/local/apache2/bin/apxs \ --disable-debug \ --with-pic \ --disable-rpath \ --with-bz2 \ --with-exec-dir=/usr/bin \ --with-freetype-dir=/usr \ --with-png-dir=/usr \ --with-xpm-dir=/usr \ --enable-gd-native-ttf \ --without-gdbm \ --with-gettext \ --with-gmp \ --with-iconv \ --with-jpeg-dir=/usr \ --with-openssl \ --with-pcre-regex=/usr \ --with-zlib \ --with-layout=GNU \ --enable-exif \ --enable-ftp \ --enable-magic-quotes \ --enable-sockets \ --enable-sysvsem \ --enable-sysvshm \ --enable-sysvmsg \ --with-kerberos \ --enable-ucd-snmp-hack \ --enable-shmop \ --enable-calendar \ --without-sqlite \ --with-libxml-dir=/usr \ --enable-xml \ --enable-force-cgi-redirect \ --enable-pcntl \ --with-imap=shared \ --with-imap-ssl \ --enable-mbstring=shared \ --enable-mbregex \ --with-gd=shared \ --enable-bcmath=shared \ --enable-dba=shared \ --with-db4=/usr \ --with-xmlrpc=shared \ --with-ldap=shared \ --with-ldap-sasl \ --with-mysql=shared,/usr/local/mysql \ --with-mysqli=shared,/usr/local/mysql/bin/mysql_config \ --enable-dom=shared \ --enable-wddx=shared \ --with-snmp=shared,/usr \ --enable-soap=shared \ --with-xsl=shared,/usr \ --enable-xmlreader=shared \ --enable-xmlwriter=shared \ --with-curl=shared,/usr \ --enable-fastcgi \ --enable-pdo=shared \ --with-pdo-odbc=shared,unixODBC,/usr \ --with-pdo-mysql=shared,/usr/local/mysql/bin/mysql_config \ --with-pdo-sqlite=shared,/usr \ --enable-json=shared \ --enable-zip=shared \ --without-readline \ --enable-sysvmsg=shared \ --enable-sysvshm=shared \ --enable-sysvsem=shared \ --enable-posix=shared \ --with-unixODBC=shared,/usr \ --with-mysql-sock=/usr/local/mysql/mysql.sock \ --with-iconv-dir
make的时候加上ZEND_EXTRA_LIBS防止过程中报错
make ZEND_EXTRA_LIBS='-liconv'
php配置:
extension_dir = "/usr/local/php/lib/php/20060613-zts/"
extension=pdo_mysql.so # 此处为范例,多个模块需要添加多个extension
date.timezone = Asia/Shanghai
LAMP环境完成后,检查php加载状况,在/usr/local/apache2/htdocs/下创建index.php文件语法:
<?php
phpinfo();
?>
通过访问http://domainname//index.php访问可以发现php插件是否正常加载
Apache : cat /usr/local/apache2/build/config.nice #查看编译参数
apachectl -t -D DUMP_MODULES #查看加载模块
MySQL: grep configure /usr/local/mysql/bin/mysqlbug #查看mysql编译参数
PHP: /usr/local/php/bin/php -i |grep configure #查看PHP编译参数
为了方便调用命令把Apache、Mysql、PHP 三个软件的执行文件路径写入环境变量~/.bash_profile
PATH=$PATH:$HOME/bin:/usr/local/mysql/bin:/usr/local/apache/bin:/usr/local/php/bin
LD_LIBRARY_PATH=/lib:/lib64:/usr/lib:/usr/lib64:/usr/local/mysql/lib:/usr/local/lib:/usr/local/lib64 #64位环境下添加该环境变量,方便编译安装时查看库文件。
source ~/.bash_profile 使当前环境变量生效
CACTI搭建:
搭建前先通过YUM安装net-snmp,net-snmp-libs,net-snmp-utils,net-snmp-devel,elfutils-libelf-devel-static,elfutils-devel,lm_sensors-devel,lm_sensors,beecrypt-devel包,Cacti主要依赖snmp协议获取备监控主机的信息。
Cacti下载地址:http://www.cacti.net/downloads/
tar zxf cacti-0.8.8b.tar.gz
mv cacti-0.8.8b /usr/local/apache2/htdocs/cacti
mysql -u root -p mysql> create database cactidb; mysql> grant all privileges on cactidb.* to 'cacti'@'10.0.0.127' identified by 'cacti' with grant option; mysql> flush privileges; mysql> use cactidb mysql> source /usr/local/apache2/htdocs/cacti/cacti.sql #导入cacti表结构
修改cacti配置文件
include/config.php include/global.php $database_type = "mysql"; $database_default = "cacti"; $database_hostname = "10.0.0.127"; $database_username = "cacti"; $database_password = "cacti"; $database_port = "3306"; $database_ssl = false; $url_path = "/cacti/"; chmod -R 775 rra/ log/ scripts/ #修改cacti目录中的文件执行权限
http://10.0.0.127:8085/cti/install/index.php 通过页面安装cacti
配置时注意执行命令路径是否被找到,如路径不对后续也可以再设置。
安装部分插件:
thold-v0.5.0.tgz
monitor-v1.3-1.tgz
settings-v0.71-1.tgz
解压后移至插件目录下
mv settings monitor thold /usr/local/apache2/htdocs/cacti/plugins/
激活插件
安装cacti-spine插件
cacti-spine-0.8.8b
./configure --with-mysql \ --with-snmp=/usr/include/net-snmp \ LDFLAGS=-L/usr/local/mysql/lib
编译过程中遇到 Cannot find UCD-SNMP libraries(snmp)报错,查看configure文件,里面把snmp库路径指向--with-snmp所指的路径之后,而snmp默认的库安装路径是/usr/lib64,因此通过软链方式解决:
ln -s /usr/lib64/libsnmp* /usr/include/net-snmp/lib64/
还有一类据说是spine-0.8.7c文档提供的编译方式
[root@SH-021Y-DBAP cacti-spine-0.8.8b] aclocal
[root@SH-021Y-DBAP cacti-spine-0.8.8b] libtoolize
[root@SH-021Y-DBAP cacti-spine-0.8.8b] autoconf && autoheader && automake
这类编译过程需要借助 autoconf,automake工具。直接从GNU上下载最近版本的就可以了。发现yum来的或者低版本的会遇到些问题。
GNU软件下载地址,另外GNU现在在募集免费软件基金。毕竟一直在使用,大家能支援的就支援点吧。
http://www.gnu.org/software
安装完成后进spine行配置
vi /usr/local/spine/etc/spine.conf DB_Host 10.x.x.127 DB_Database cactidb DB_User cacti DB_Pass cacti DB_Port 3306 DB_PreG 0
Cacti搭建完成以后,出现无法生成图片的方式,观察cacti.log正常执行poller.php脚本生产数据,查看
查看apache的error日志,一直出现如下报错:
ERROR: opening '*.rrd': No such file or directory
很明显是没有在rra下创建文件图片数据文件,但是rra的权限已经给到777了啊,对于这类头疼的问题只能一点点的试
在数据源目录下选择一台主机,选择其中一个数据模板内容,打开debug模式
看到那行rrdtool的命令,粘贴到主机上运行,确认错误的原因。查看生产图形数据的语句
检查是否运行正常!
插件的错误访问http://forums.cacti.net网站寻找解决方式
安装Nagios
下载地址:
http://sourceforge.jp/projects/sfnet_nagios/releases/
最新nagios-plugin地址:
http://www.nagios.org/download/plugins/
nrpe下载地址:
wget http://sourceforge.net/projects/nagios/files/nrpe-2.x/nrpe-2.9/nrpe-2.9.tar.gz
目前能获取的最新版本:
nagios-4.0.8.tar.gz
nagios-plugins-2.0.3.tar.gz
nrpe-2.9.tar.gz
tar zxf nagios-4.0.8.tar.gz ./configure --with-nagios-user=nagios \ --with-nagios-group=nagios \ --with-command-user=nagios \ --with-command-group=nagios \ --with-httpd-conf=/usr/local/apache2/conf make all
make install - This installs the main program, CGIs, and HTML files make install-init - This installs the init script in /etc/rc.d/init.d make install-commandmode - This installs and configures permissions on the directory for holding the external command file make install-config - This installs *SAMPLE* config files in /usr/local/nagios/etc You'll have to modify these sample files before you can use Nagios. Read the HTML documentation for more info on doing this. Pay particular attention to the docs on object configuration files, as they determine what/how things get monitored! make install-webconf - This installs the Apache config file for the Nagios web interface make install-exfoliation - This installs the Exfoliation theme for the Nagios web interface make install-classicui - This installs the classic theme for the Nagios web interface
tar zxf nagios-plugins-2.0.3.tar.gz ./configure --with-nagios-user=nagios --with-nagios-group=root --enable-redhat-pthread-workaround make && make install
./configure --with-nrpe-user=nagios \ --with-nrpe-group=nagios \ --with-nagios-user=nagios \ --with-nagios-group=nagios \ --enable-command-args General Options: ------------------------- NRPE port: 5666 #默认端口为5666 make all make install-plugin make install-daemon make install-daemon-config make install-xinetd
ScriptAlias /nagios/cgi-bin "/usr/local/nagios/sbin" <Directory "/usr/local/nagios/sbin"> Options ExecCGI AllowOverride None Order allow,deny Allow from all AuthName "Nagios Access" AuthType Basic AuthUserFile /usr/local/nagios/etc/htpasswd.users Require valid-user </Directory> Alias /nagios "/usr/local/nagios/share" <Directory "/usr/local/nagios/share"> Options None AllowOverride None Order allow,deny Allow from all AuthName "Nagios Access" AuthType Basic AuthUserFile /usr/local/nagios/etc/htpasswd.users Require valid-user </Directory> Alias /pub/images "/usr/local/nagios/share/docs/images" <Directory "/usr/local/nagios/share/docs/images"> Options None AllowOverride None Order allow,deny Allow from all AuthName "Nagios Access" AuthType Basic AuthUserFile /usr/local/nagios/etc/htpasswd.users Require valid-user </Directory>
在http的配置文件中添加上面的内容后,通过http的秘钥命令在nagios配置目录中生产秘钥文件。
htpasswd -c /usr/local/nagios/etc/htpasswd.users nagiosadmin
修改NRPE配置
vi /usr/local/nagios/etc/nrpe.cfg allowed_hosts=10.x.0.0/24 vi /etc/xinetd.d/nrpe service nrpe { flags = REUSE socket_type = stream port = 5666 wait = no user = nagios group = nagios server = /usr/local/nagios/bin/nrpe server_args = -c /usr/local/nagios/etc/nrpe.cfg --inetd log_on_failure += USERID disable = no only_from = 127.0.0.1 10.28.7.127 } vi /etc/services nrpe 5666/tcp # NRPE service xinetd restart netstat -anltp | grep 5666 /usr/local/nagios/libexec/check_nrpe -H 10.x.x.127 #测试 NRPE v2.15
在启动nagios之后发现部分监控报警没启动,启动时发现如下报错:
Error: Could not open command file '/usr/local/nagios/var/rw/nagios.cmd' for update!
在nagios.cfg中对该命令进行解释,参考了网上的解决方式,发现修改命令权限为777时,无报错,判断一定是权限的问题。但此方法仅临时解决问题,当nagios重启后,该命令重新创建,问题依然存在。看到解释中提到 “It is also where the command CGI will write commands that are submitted by users”,觉得应该是apache的用户需要有对该文件具有写的权限,因此修改apache的所属可选组为nagios,问题彻底解决。
usermod -G apache,nagios nagios
关于nagios的配置内容,需要另开篇详述。这里就不在说明
双剑合璧Nagios+Cacti
Cacti通过npc(Nagios plugin for Cacti)插件将Nagios集成在一起。
wget http://prdownloads.sourceforge.net/sourceforge/nagios/ndoutils-2.0.0.tar.gz
tar xvf ndoutils-2.0.0.tar.gz ./configure --prefix=/usr/local/nagios \ --mandir=/usr/local/share/man \ --enable-mysql \ --disable-pgsql \ --with-ndo2db-user=nagios \ --with-ndo2db-group=nagios \ --with-mysql 这里需要特别注意的是,仔细观察编译内容,当出现如下情况时说明mysql的库文件没有找到,虽然可以正常安装该软件,但启动时最终会导致"Support for the specified database server is either not yet supported, or was not found on your system."这样的错误信息: *** MySQL library could not be located... ************************** You chose to compile NDOutils with MySQL support, but I was unable to locate the MySQL library on your system. If the library is installed, use the --with-mysql-lib argument to specify the location of the MySQL library. installed, use the --with-mysql=DIR argument to specify the location of the MySQL library, We assume mysql_config is in DIR/dir NOTE: After you install the necessary libraries on your system: 1. Make sure /etc/ld.so.conf has an entry for the directory in which the MySQL libraries are installed. 2. Run 'ldconfig' to update the run-time linker options. 3. Run 'make devclean' in the NDBXT distribution to clean out any old references to your previous compile. 4. Rerun the configure script. TIP: Try the following.... ./configure --with-mysql=/usr/lib/mysql ******************************************************************** 如果出现如下报错信息: In file included from io.c:11: ../include/config.h:261:25: error: mysql/mysql.h: No such file or directory ../include/config.h:262:26: error: mysql/errmsg.h: No such file or directory 修改include/config.h中第261行的内容去掉mysql/,这是因为生产的编译文件路径指定错误。 make && make install cd config cp ndo2db.cfg-sample /usr/local/nagios/etc/ndo2db.cfg cp ndomod.cfg-sample /usr/local/nagios/etc/ndomod.cfg vi /usr/local/nagios/etc/ndo2db.cfg socket_name=/usr/local/nagios/var/ndo.sock db_name=cactidb db_prefix=npc_ db_user=cacti db_pass=cacti debug_level=1 debug_file=/usr/local/nagios/var/ndo2db.debug vi /usr/local/nagios/etc/nagios.cfg broker_module=/usr/local/nagios/bin/ndomod.o config_file=/usr/local/nagios/etc/ndomod.cfg
到这步需要做个小改动,因为ndoutils的数据库脚本中定义的表名为nagios_,而配置文件中定义为npc_,需要手动改一下脚本nstalldb,upgradedb及mysql.sql的内容将nagios替换为npc。替换的方式用vi在command模式下:
%s/nagios_/npc_/
除此之外还有perl的相关包也需要安装,主要是DBI,Data::ShowTables,DBD::mysql,一般通过perl的CPAN项目(类似YUM)安装。涉及的相关包如lynx,ncftp,ftp
cpan源地址使用 http://mirrors.163.com/cpan/
CPAN> o conf urllist push http://mirrors.163.com/cpan/ CPAN> o conf prerequisites_policy follow CPAN> o conf commit CPAN> install DBD::mysql
一切就绪后运行ndoutil的升级库脚本:
cd ndoutils-2.0.0/db ./installdb -u cacti -p cacti -h 10.x.x.127 -d cactidb #for a new installation ./upgradedb -u cacti -p cacti -h 10.x.x.127 -d cactidb #for an existing one
解压NPC移置cacti的plugins目录下修改cacti配置文件
vi /usr/local/apache/htdocs/cacti/include/plugins.php $plugins[] = 'npc'; #第30行,$plugins = array();下方添加该语句(目前看该步骤非必要)
一切就绪开启ndoutils服务:
/usr/local/nagios/bin/ndo2db -c /usr/local/nagios/etc/ndo2db.cfg
查看一下nagios的日志记录
tail -100 /usr/local/nagios/var/nagios.log ndomod: Successfully connected to data sink. 4160 queued items to flush. #出现如下提示表示ndo正常连接数据库,把nagios的数据写入到cactidb库中了。
Dec 13 00:55:37 021Y-SH-BKAP ndo2db: Error: max retries exceeded sending message to queue. Kernel queue parameters may neeed to be tuned. See README
ALTER TABLE `npc_hostchecks` MODIFY COLUMN `long_output` varchar(8192) NOT NULL default '' AFTER `output`; ALTER TABLE `npc_hoststatus` MODIFY COLUMN `long_output` varchar(8192) NOT NULL default '' AFTER `output`; ALTER TABLE `npc_servicechecks` MODIFY COLUMN `long_output` varchar(8192) NOT NULL default '' AFTER `output`; ALTER TABLE `npc_servicestatus` MODIFY COLUMN `long_output` varchar(8192) NOT NULL default '' AFTER `output`; ALTER TABLE `npc_statehistory` MODIFY COLUMN `long_output` varchar(8192) NOT NULL default '' AFTER `output`; ALTER TABLE `npc_eventhandlers` MODIFY COLUMN `long_output` varchar(8192) NOT NULL default '' AFTER `output`; ALTER TABLE `npc_systemcommands` MODIFY COLUMN `long_output` varchar(8192) NOT NULL default '' AFTER `output`; ALTER TABLE `npc_notifications` MODIFY COLUMN `long_output` varchar(8192) NOT NULL default '' AFTER `output`;
参考:
http://os.51cto.com/art/201411/458006_all.htm
http://blog.chinaunix.net/uid-24727220-id-3025015.html
http://yahoon.blog.51cto.com/13184/49722/