编译安装zabbix3.2,LAMP

本文详细介绍如何在Red Hat 6.6环境下从零开始搭建Zabbix 3.2.1监控系统,包括环境准备、LAMP安装、zabbix编译安装等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

编译安装zabbix方式

1.1 环境准备

系统环境:
redhat 6.6 64位
mysql-5.6.34
php-5.6.28

zabbix-3.2.1


配置前先关闭iptables和SELINUX,避免安装过程中报错。
 
# service iptables stop
 
# setenforce 0
 
# vi /etc/sysconfig/selinux

---------------
 
SELINUX=disabled
 
——————————————————————————————
zabbix 3.2.0对环境的要求 
 
MySQL 5.1以上最好是 5.6或者更高的版本
 
PHP 5.4或者更高的版本


1.2 LAMP安装

1.2.1 yum安装httpd

安装Apahce, PHP, MySQL以及php连接mysql库组件。

1
#yum -y install httpd httpd-devel


1.2.2 编译安装mysql5.6

安装编译源码所需的工具和库

1
2
3
4
5
6
yum install \
make \
gcc \
gcc-c++ \
ncurses-devel \
cmake


新增mysql用户组:

1
groupadd mysql

新增mysql用户:

1
2
useradd -g mysql mysql -s /sbin/nologin
chmod 755 /home/mysql/

新建MySQL所需要的目录

新建mysql安装目录

1
mkdir -p /usr/local/mysql

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
cmake  \
-DCMAKE_INSTALL_PREFIX= /usr/local/mysql  \
-DMYSQL_DATADIR= /home/mysql/  \
-DMYSQL_UNIX_ADDR= /home/mysql/mysql .sock \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DEXTRA_CHARSETS=all \
-DWITH_SSL=system \
-DMYSQL_TCP_PORT=3306 \
-- enable -proxy \
-DWITH_SSL=bundled

 

注:重新运行配置,需要删除CMakeCache.txt文件
rm -f CMakeCache.txt
 
make
make install
 
修改mysql安装目录
chown -R mysql:mysql /usr/local/mysql
 

初始化配置

进入安装路径
# cd /usr/local/mysql
 
进入安装路径,执行初始化配置脚本,创建系统自带的数据库和表

1
# scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/home/mysql --user=mysql

 

注:在启动MySQL服务时,会按照一定次序搜索my.cnf,先在/etc目录下找,找不到则会搜索"$basedir/my.cnf"

注意:若在/etc目录下会存在一个my.cnf,需要将此文件更名为其他的名字,如:/etc/my.cnf.bak,否则,该文件会干扰源码安装的MySQL的正确配置,造成无法启动。

在使用"yum update"更新系统后,需要检查下/etc目录下是否会多出一个my.cnf,如果多出,将它重命名成别的。否则,MySQL将使用这个配置文件启动,可能造成无法正常启动等问题。


复制mysql服务启动配置文件

1
2
# mv /etc/my.cnf /etc/my.cnf.bak
# cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf

启动MySQL

添加服务,拷贝服务脚本到init.d目录,并设置开机启动

1
# cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

 
设置开机启动
chkconfig mysqld on
 
service mysqld start


配置用户

MySQL启动成功后,root默认没有密码,我们需要设置root密码。

设置之前,我们需要先设置PATH,要不不能直接调用mysql

修改/etc/profile文件,在文件末尾添加

1
2
PATH= /usr/local/mysql/bin :$PATH
export  PATH

关闭文件,运行下面的命令,让配置立即生效

source /etc/profile
 
 执行下面的命令修改root密码

1
2
mysql -uroot  
mysql> SET PASSWORD = PASSWORD( '123456' );

或是

1
2
3
# mysqladmin -uroot -p password 123qwe
Enter password:        这里直接回车
Warning: Using a password on the  command  line interface can be insecure.

 
若要设置root用户可以远程访问,执行
 
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'172.16.%' IDENTIFIED BY 'password' WITH GRANT OPTION;
 

红色的password为远程访问时,root用户的密码,可以和本地不同。


配置防火墙

防火墙的3306端口默认没有开启,若要远程访问,需要开启这个端口

打开/etc/sysconfig/iptables

在“-A INPUT –m state --state NEW –m tcp –p –dport 22 –jACCEPT”,下添加:


1
-A INPUT -m state --state NEW -m tcp -p -dport 3306 -j ACCEPT


然后保存,并关闭该文件,在终端内运行下面的命令,刷新防火墙配置:

service iptables restart
 
OK,一切配置完毕,你可以访问你的MySQL了~


1.2.3编译安装PHP5.6

添加依赖应用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
yum  install  -y gcc \
gcc-c++ \
autoconf \
libjpeg \
libjpeg-devel \
libpng \
libpng-devel \
freetype \
freetype-devel \
libpng \
libpng-devel \
libxml2 \
libxml2-devel \
zlib \
zlib-devel \
glibc \
glibc-devel \
glib2 \
glib2-devel \
bzip2  \
bzip2 -devel \
ncurses \
curl \
openssl-devel \
gdbm-devel \
db4-devel \
libXpm-devel \
libX11-devel \
gd-devel \
gmp-devel \
readline-devel \
libxslt-devel \
expat-devel \
xmlrpc-c \
xmlrpc-c-devel \
libcurl \
libcurl-devel

安装加密扩展库,先安装Libmcrypt

1
2
3
4
5
tar  zxvf libmcrypt-2.5.8. tar .gz 
cd  libmcrypt-2.5.8
. /configure
make
make  install


编译安装

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
. /configure  \
--prefix= /usr/local/php  \
--with-config- file -path= /etc  \
--with-apxs2= /usr/sbin/apxs  \
--with-mysql= /usr/local/mysql  \
--with-mysqli= /usr/local/mysql/bin/mysql_config  \
-- enable -inline-optimization \
-- enable -fpm \
-- enable -soap \
--with-libxml- dir  \
--with-xmlrpc \
--with-openssl \
--with-mcrypt \
--with-mhash \
--with-pcre-regex \
--with-sqlite3 \
--with-zlib \
-- enable -bcmath \
--with-iconv \
--with-bz2 \
-- enable -calendar \
--with-curl \
--with-cdb \
-- enable -dom \
-- enable -exif \
-- enable -fileinfo \
-- enable -filter \
--with-pcre- dir  \
-- enable - ftp  \
--with-gd \
--with-openssl- dir  \
--with-jpeg- dir  \
--with-png- dir  \
--with-zlib- dir   \
--with-freetype- dir  \
-- enable -gd-native-ttf \
--with-gettext \
--with-gmp \
--with-mhash \
-- enable -json \
-- enable -mbstring \
--disable-mbregex \
--disable-mbregex-backtrack \
--with-libmbfl \
--with-onig \
-- enable -pdo \
--with-pdo-mysql \
--with-zlib- dir  \
--with-pdo-sqlite \
--with-readline \
-- enable -session \
-- enable -shmop \
-- enable -simplexml \
-- enable -sockets \
-- enable -sysvmsg \
-- enable -sysvsem \
-- enable -sysvshm \
-- enable -wddx \
--with-libxml- dir   \
--with-xsl \
-- enable -zip \
-- enable -mysqlnd-compression-support \
--with-pear


注:

--with-mysql=/usr
--with-mysqli=/usr/bin/mysql_config
--with-apxs2=/usr/sbin/apxs
--enable-gd-jis-conv    会让中文乱码的不需要这个参数的

其中--with-apxs2是用来生成Apache的PHP模块libphp5.so的,不需要可以去掉。


php配置

php.ini是php运行核心配置文件
php-fpm.conf是php-fpm进程服务的配置文件

 

1
2
3
4
5
# cd php-5.6.28
# cp php.ini-production /etc/php.ini
# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
# chmod +x /etc/init.d/php-fpm
fpm测试php配置
1
2
3
4
5
6
7
8
9
10
11
# /usr/local/php/sbin/php-fpm -t
[23-May-2016 20:03:52] NOTICE: 
configuration  file  /usr/local/php/etc/php-fpm .conf  test  is successful
  
# chkconfig --add php-fpm
# chkconfig php-fpm on
# service php-fpm start
Starting php-fpm   done
  
netstat  –anpt
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      705 /php-fpm


修改默认端口:

vi /usr/local/php/etc/php-fpm.conf
listen = 127.0.0.1:8000


1.3配置apache访问PHP

配置 httpd.conf apache支持PHP

# vi /usr/local/apache/conf/httpd.conf
找到 AddType application/x-gzip .gz .tgz (369)在其下添加如下内容
 

1
2
3
4
5
AddType application /x-httpd-php  .php
AddType application /x-httpd-php-source  .phps
  
DirectoryIndex index.php index.html    // 调整首页文件设置
LoadModule php5_module         /usr/lib64/httpd/modules/libphp5 .so


测试页面:

1
2
3
4
vi  /var/www/html/test .php 
<?php
phpinfo();
?>


2.1 下载zabbix源码包

官网:http://www.zabbix.com/download.php
下载zabbix-3.2.1.tar.gz


安装zabbix所需的组件(server,agent)

1
yum -y  install  curl libcurl-devel net-snmp net-snmp-develperl-DBI libdbi-dbd-mysql mysql-devel gcc gcc++  make  libxml2 libxml2-devel

2.2 编译安装zabbix

server: 172.28.3.103)服务端

创建zabbix用户组与用户:

# groupadd zabbix
 
# useradd -g zabbix -s /sbin/nologin zabbix
 
# tar xzvf zabbix-3.2.1.tar.gz


编译安装:

1
2
3
# cd zabbix-3.2.1 
# ./configure --prefix=/usr/local/zabbix-server --enable-server --with-mysql --with-net-snmp --with-libcurl --with-libxml2 --enable-agent --enable-ipv6 
make  &&  make  install


编译时加 --prefix=/usr/local/zabbix-server 参数,则zabbix配置文件默认在/usr/local/zabbix-server/etc目录下。(若编译时没有指定路径,则zabbix配置文件使用的默认路径,在/usr/local/etc/下)

创建数据库和授权用户

说明:

数据文件导入的顺序不能变,也可以在命令行使用mysql命令导入数据文件

[root@test ~]# service mysqld start
 
修改数据库的root密码
[root@test ~]# mysqladmin -u root -p password 123qwe
Enter password:        这里不用填写直接回车即可
 

1
2
3
mysql> create database zabbix character  set  utf8; mysql> grant all on zabbix.* to zabbix@ 'localhost'  identified by  '123456'
mysql> flush privileges;
mysql> grant all on zabbix.* to zabbix@ '%'  identified by  'zabbix' ;


导入数据库sql脚本:

# cd zabbix-3.2.1
 
在解压的zabbix目录下,将database/mysql目录下三个sql文件导入到zabbix数据库里。(下面用的是zabbix用户来导入文件,这个用户在数据库是默认存在的)
 
# mysql -uzabbix -p123456 zabbix < database/mysql/schema.sql

# mysql -uzabbix -p123456 zabbix < database/mysql/images.sql

# mysql -uzabbix -p123456 zabbix < database/mysql/data.sql
 
或是

mysql> use zabbix;
Database changed

mysql> source /root/zabbix-3.2.1/database/mysql/schema.sql;    

mysql> source /root/zabbix-3.2.1/database/mysql/images.sql;

mysql> source /root/zabbix-3.2.1/database/mysql/data.sql;


修改配置文件并启动

mkdir -p /var/www/zabbix

cp -R frontends/php /var/www/zabbix

chmod 777 /var/www/zabbix/php/conf 


编辑配置文件(server,agent)

# cd /usr/local/zabbix-server/etc


去掉配置文件里的注释:

# cat zabbix_server.conf |grep -v"#" |grep -v "^$" > zabbix_server.conf.bak

# cp zabbix_server.conf.bak zabbix_server.conf

# cat zabbix_agentd.conf |grep -v"#" |grep -v "^$" > zabbix_agentd.conf.bak

# cp zabbix_agentd.conf.bak zabbix_agentd.conf


我们只需要关注DBHost、DBName、DBUser、DBPassword几项即可。这几项是配置zabbix server连接mysql数据库的参数。


服务端配置:

1
2
3
4
5
6
# vim /usr/local/zabbix-server/etc/zabbix_server.conf
   LogFile= /var/log/zabbix/zabbix_server .log
   DBHost=localhost
   DBName=zabbix
   DBUser=zabbix
   DBPassword=123456


客户端配置:

1
2
3
4
5
# vi /usr/local/zabbix-server/etc/zabbix_agentd.conf
LogFile= /var/log/zabbix/zabbix_agentd .log
Server=172.28.3.103
ServerActive=172.28.3.103
Hostname=172.28.3.103


创建日志文件存放位置:
mkdir /var/log/zabbix

chown -R zabbix:zabbix /var/log/zabbix
 
启动zabbix服务:
/usr/local/zabbix-server/sbin/zabbix_server



server来管理启动zabbix服务:

1
2
3
4
5
6
7
# cd zabbix-3.2.1
# cp misc/init.d/fedora/core/zabbix_server /etc/init.d/
# cp misc/init.d/fedora/core/zabbix_agentd /etc/init.d/
# chkconfig --add zabbix_server
# chkconfig --add zabbix_agentd
# chkconfig zabbix_server on
# chkconfig zabbix_agentd on

创建软链接:

1
2
3
ln  -s  /usr/local/zabbix/sbin/zabbix_server  /usr/local/sbin/
  
ln  -s  /usr/local/zabbix/sbin/zabbix_agentd  /usr/local/sbin/

 
启动服务:
service zabbix_server start
service zabbix_agentd start


agent:  172.28.3.100)客户端

创建zabbix用户组与用户:

# groupadd zabbix
 
# useradd -g zabbix -s /sbin/nologin zabbix


编译安装:

1
2
3
4
5
6
7
8
9
10
# cd zabbix-3.2.1
# ./configure --prefix=/usr/local/zabbix-agent  --enable-agent
make  &&  make  install
  
# cd /usr/local/zabbix-agent
# vi etc/zabbix_agentd.conf
LogFile= /var/log/zabbix/zabbix_agentd .log
Server=172.28.3.103
ServerActive=172.28.3.103
Hostname=172.28.3.100


server来管理启动zabbix服务:

1
2
3
4
# cd zabbix-3.2.1
# cp misc/init.d/fedora/core/zabbix_agentd /etc/init.d/
# chkconfig --add zabbix_agentd
# chkconfig zabbix_agentd on

创建软链接:

1
# ln -s /usr/local/zabbix/sbin/zabbix_agentd/usr/local/sbin/

 
启动服务:
service zabbix_agentd start


2.3 配置zabbix web页面

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
vim  /etc/httpd/conf .d /zabbix .conf
  
#
# Zabbix monitoring system php web frontend
#
  
#Alias /zabbix/usr/share/zabbix
Alias  /zabbix  /var/www/zabbix/php
  
<Directory "/var/www/zabbix/php" >
     Options FollowSymLinks
     AllowOverride None
     Order allow,deny
     Allow from all
     #Require all granted
  
     <IfModule mod_php5.c>
         php_value max_execution_time 300
         php_value memory_limit 128M
         php_value post_max_size 16M
         php_value upload_max_filesize 2M
         php_value max_input_time 300
         php_value always_populate_raw_post_data -1
         # php_value date.timezone Europe/Riga
         php_value  date .timezone Asia /Chongqing
     < /IfModule >
< /Directory >

其中php_value date.timezone Asia/Chongqing主要是定义php的时区。
 

最后重启apache,zabbix服务,如下:

services  httpd restart

services zabbix_server restart

然后访问http://172.28.3.103/zabbix/setup.php这个地址,如下进行安装:

wKioL1hBFCHQHoSCAAD_z0IPekQ118.png-wh_50

wKiom1hBFISC4UipAABq6MxKmkU669.jpg-wh_50

wKioL1hBFIbxxW-sAABWFbAqVek161.jpg-wh_50

wKiom1hBFIbzWz4OAABpEQBPUG8093.jpg-wh_50

wKioL1hBFIvRp9dNAABN51-mpPg207.jpg-wh_50


完成后即可登录:zabbix默认的用户名和密码是Admin/zabbix

wKiom1hBFIyxzmfYAAB1x1bk27Q866.jpg-wh_50

如果创建zabbix.conf.php文件这一步有报错话,可以手动下载好那个文件在相应目录创建zabbix.conf.php文件复制里面的内容即可:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
vi /var/www/zabbix/php/conf/zabbix.conf.php
<?php
// Zabbix GUI configuration file.
global $DB;
  
$DB['TYPE']     = 'MYSQL';
$DB['SERVER']   = '172.28.3.103';
$DB['PORT']     = '3306';
$DB['DATABASE'] = 'zabbix';
$DB['USER']     = 'zabbix';
$DB['PASSWORD'] = 'zabbix';
  
// Schema name. Used for IBM DB2 and PostgreSQL.
$DB['SCHEMA'] = '';
  
$ZBX_SERVER      = '172.28.3.103';
$ZBX_SERVER_PORT = '10051';
$ZBX_SERVER_NAME = '';
  
$IMAGE_FORMAT_DEFAULT = IMAGE_FORMAT_PNG;





      本文转自ling118 51CTO博客,原文链接:http://blog.51cto.com/meiling/1878579,如需转载请自行联系原作者




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值