详解zabbix中文版安装部署 | 少将全栈
  • 欢迎访问少将全栈,学会感恩,乐于付出,珍惜缘份,成就彼此、推荐使用最新版火狐浏览器和Chrome浏览器访问本网站。
  • 吐槽,投稿,删稿,交个朋友
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏少将全栈吧

详解zabbix中文版安装部署

点滴 admin 10年前 (2015-01-04) 1667次浏览 已收录 扫描二维码

一、zabbix简介(摘自百度百科)

    zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。

zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供柔软的通知机制以让系统管理员快速定位/解决存在的各种问题。zabbix2部分构成,zabbix server与可选组件zabbix agentzabbix server可以通过SNMPzabbix agentping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它可以运行在Linux, Solaris, HP-UX, AIX, Free BSD, Open BSD, OS X等平台上。zabbix agent需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,CPU等信息的收集。zabbix agent可以运行在Linux ,Solaris, HP-UX, AIX, Free BSD, Open BSD, OS X, Tru64/OSF1, Windows NT4.0, Windows 2000/2003/XP/Vista)等系统之上。zabbix server可以单独监视远程服务器的服务状态;同时也可以与zabbix agent配合,可以轮询zabbix agent主动接收监视数据(trapping方式),同时还可被动接收zabbix agent发送的数据(trapping方式)。另外zabbix server还支持SNMP (v1,v2),可以与SNMP软件(例如:net-snmp)等配合使用。

zabbix的主要特点: – 安装与配置简单,学习成本低

  – 支持多语言(包括中文)

– 免费开源

– 自动发现服务器与网络设备

– 分布式监视以及WEB集中管理功能

– 可以无agent监视

– 用户安全认证和柔软的授权方式

– 通过WEB界面设置或查看监视结果

– email等通知功能等等

Zabbix主要功能: – CPU负荷

– 内存使用

– 磁盘使用

– 网络状况

– 端口监视

– 日志监视

由于zabbix是基于web界面将存储在数据库中的数据成图表显示出来,所以zabbix需要运行在web和数据库的平台上,在这里我们使用lemp环境。Linuxtone为我们提供了自动部署lemp的脚本,我们只需下载后解压运行里面的lemp.sh即可.

lemp下载地址:bbs.linuxtone.org/docs/autoinstall/lemp_auto_v1.0.6.tar.gz

部署lemp:

 

# tar zxf lemp_auto_v1.0.6.tar.gz

# cd lemp

# chmod 755 -R *

# ./lemp.sh              //安装lemp

 

二、zabbix下载安装

    1.下载zabbix

http://www.zabbix.com/download.php,在此我使用zabbix 1.8.2

#wget http://nchc.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/1.8.2/zabbix-1.8.2.tar.gz

    2.安装zabbix所需的组件

#yum -y install curl curl-devel net-snmp net-snmp-devel perl-DBI php-gd php-xml php-bcmath

    3.数据库创建并导入数据

#tar zxf zabbix 1.8.2.tar.gz

#cd zabbix 1.8.2

#mysql -uroot -p

>create database zabbix;

>grant all on zabbix.* to zabbix@localhost identified by ’123’;

>flush privileges;

#mysql -uroot zabbix<create/schema/mysql.sql

#mysql -uroot zabbix<create/data/data.sql

#mysql -uroot zabbix<create/data/images_mysql.sql

//zabbix创建自己的数据库,以便zabbix可以把收集到的数据信息存放在那里调用。

    4.编译安装

#./configure –prefix=/usr/local/zabbix –enable-server –enable-agent –enable-proxy –with-mysql=/usr/local/mysql-5.1.56/bin/mysql_config –with-net-snmp –with-libcurl

 

//–prefix指定zabbix安装目录,–enable-server 支持zabbix服务器,–enable-agent支持zabbix代理,–enable-proxy 支持zabbix代理服务器,–with-mysql 使用MySQL客户端库可以选择指定路径mysql_config–with-net-snmp 使用net – snmp软件包,择性地指定路径NET – SNMP配置, –with-libcurl 使用curl

        #make && make install

    5.添加zabbix服务对应的端口(可以省略,但是官方建议有)

         #cat >>/etc/services<<EOF

zabbix-agent 10050/tcp Zabbix Agent

zabbix-agent 10050/udp Zabbix Agent

zabbix-trapper 10051/tcp Zabbix Trapper

zabbix-trapper 10051/udp Zabbix Trapper

EOF

    6.拷贝zabbix的配置文件到etc,web相关文件拷贝到web目录下

        #cd zabbix-1.8.2

#mkdir /etc/zabbix

#cp misc/conf/*  etc/zabbix

#cp -r frontends/php /data/www/wwwroot/zabbix

        修改zabbix连接的数据库的用户名和密码

#vi /etc/zabbix/zabbix_server.conf

DBName=zabbix

DBUser=zabbix

DBUDBPassword=123

 

    7.zabbix的启动、关闭和重启的脚本文件做链接,方便系统可以找得到

#cd /usr/local/zabbix/bin/

#for i in *;do ln -s /usr/local/zabbix/bin/${i} /usr/bin/${i};done

#cd /usr/local/zabbix/sbin/

#for i in *;do ln -s /usr/local/zabbix/sbin/${i} /usr/sbin/${i};done

    8.mysqllib库文件添加到系统动态库配置文件中,方便系统可以找到mysqllib库。  

        #echo /usr/local/mysql-5.1.56/lib/mysql/ >>/etc/ld.so.conf

#ldconfig        //使上面的操作立即生效

    9.zabbix相关的启动脚本等文件拷贝的/etc/init.d/下,方便日后对zabbix的启动关闭操作

        #cp misc/init.d/redhat/8.0/zabbix_server /etc/init.d/

#chmod +x /etc/init.d/zabbix_server  //赋予可执行权限

#cp misc/init.d/redhat/8.0/zabbix_agentd /etc/init.d/

#chmod +x /etc/init.d/zabbix_agentd

         修改zabbix serveragentd程序目录的位置:

        #vi /etc/init.d/zabbix_server

progdir=”/usr/local/zabbix/sbin/”

#vi /etc/init.d/zabbix_agentd

progdir=”/usr/local/zabbix/sbin/”

    10.添加开机启动服务

#chkconfig –add zabbix_server

#chkconfig –add zabbix_agentd

#chkconfig –level 345 zabbix_server on

#chkconfig –level 345 zabbix_agentd on

    11.nginx配置文件中建立zabbix虚拟机的配置文件

         #cat> /usr/local/nginx/conf/vhosts/monitor.conf<<EOF

server {

listen       80;

server_name  zabbix.chanjet.com;

#access_log   logs/zabbix_access.log  main;

location / {

root   /data/www/wwwroot/zabbix;

index  index.html index.htm index.php;

}

location ~ .php$ {

root   /data/www/wwwroot/zabbix;

fastcgi_pass   127.0.0.1:9000;

fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;

fastcgi_index  index.php;

include        fastcgi_params;

}

}

    12.php配置文件做相应的调整,使其满足zabbix运行的最低环境要求

            #vim /usr/local/php-5.2.17/etc/php.ini

date_default_timezone_set(Asia/Shanghai)

post_max_size = 16M

max_execution_time = 300

max_input_time = 300

            cp /usr/local/php-5.2.17/sbin/php-fpm  /etc/init.d/

            chmod 755 /etc/init.d/php-fpm

            /etc/init.d/php-fpm restart          //使php更改后的参数生效

    13.进行zabbix的安装

       在地址栏里输入http://192.168.0.2/zabbix/,我的zabbix安装在192.168.0.2的服务器上。

 //用户名/密码为默认:admin/zabbix

                进入zabbix安装界面:

同意许可协议:

 

pre环境最低要求(前面对php配置文件的修改):

 

   数据库连接配置(连接mysql的用户名和密码在第3步中已配置):

 

 zabbix server信息:

Next:

Next:

 

完成安装:  

 

 

14.zabbix进行汉化,中文的监控界面才会显得亲切嘛:

点击下载:cn_zh.inc.php.tar,把解压后的文件复制到/data/www/wwwroot/zabbix/include/locales下覆盖原来的文件;重启zabbix

登陆zabbix监控界面:

 

 

点击zabbix 首页右上角porfile

 

language 中选择Chinese(CN)保存即可:

 

监控大屏幕:

 

 # useradd zabbix -s /sbin/nologin

 # /etc/init.d/zabbix_server start

启动 zabbix_server:                                       [确定]

 

 

 

 

 出处http://baiying.blog.51cto.com/1068039/609990

来新公司后.因为要进行以后大型网络erp的系统维护.所以必须要装1套网络监控的网管软件.所以我就参考了不少网络文章和请教1些前辈高人..在自己的电脑上测试安装zabbix这一套比较成熟的基于snmp和mysql的网管软件.现在写下部分的笔记.希望帮到有需要的人…(注.其实是自己怕健忘 -0-)

首先.先安装Linux系统.我选用了redhat 架构的免费版centos 5.3

先下载并安装mysql

下载最新版的源码

./configure  –enable-largefile  –with-max-indexes=64 –enable-assembler  –with-collation=utf8_general_ci –enable-shared –enable-thread-safe-client –with-charset=utf8  –with-extra-charsets=all  –with-big-tables –with-plugins=innobase,myisammrg,partition,heap,blackhole –with-pthread

以上是我个人的编译配置

make

make install

然后.建立1个用户给zabbix运行数据库

useradd -g zabbix zabbix

创建zabbix的数据库

mysql -u zabbix -p
>create database zabbix;
>quit;

找到zabbix源码的schema目录

cat schema.sql |mysql -u zabbix -p zabbix
找到源码中data.sql文件和images_mysql.sql

cat data.sql |mysql -u zabbix -p zabbix
cat images_mysql.sql |mysql -u zabbix -p zabbix

服务器端+客户端的编译:
./configure –with-mysql –with-net-snmp –enable-server –enable-agent –prefix=/usr/local/zabbix 
客户端只需执行:
./configure –prefix=/usr/local/zabbix –enable-agent
make
make install
cd /usr/local/zabbix/bin
修改/etc/ld.so.conf

添加

/usr/local/lib

/usr/lib/

/usr/local/sbin

/usr/local/bin

/usr/bin

/usr/sbin

/usr/local/lib64(如果你是64位系统就加上这行)

保存退出

ldconfig使之前的ld.so.conf生效

回到zabbix的编译目录,
vi frontends/php/include/db.inc.php
更改数据库相关内容:
$DB_TYPE =”MYSQL”; 
$DB_SERVER =”localhost”;
$DB_DATABASE =”zabbix”;
$DB_USER =”zabbix”;
$DB_PWD =””;(这里输入你的zabbix的mysql密码)
cp -rf frontends/php /usr/local/www/html/zabbix -R
chown zabbix /usr/local/www/html/zabbix/ -R
生成配置文件:
mkdir /etc/zabbix
cp misc/conf/* /etc/zabbix/
配置相关内容(以下内容请根据大家具体服务器的IP/MYSQL的账号情况做相应修改):
vi zabbix_agent.conf
Server=localhost
Timeout=3
UserParameter=mysql.ping,/usr/local/mysql/bin/mysqladmin -uzabbix -p ping|grep alive|wc -l
UserParameter=mysql.uptime,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f2 -d”:”|cut -f1 -d”T”
UserParameter=mysql.threads,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f3 -d”:”|cut -f1 -d”Q”
UserParameter=mysql.questions,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f4 -d”:”|cut -f1 -d”S”
UserParameter=mysql.slowqueries,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f5 -d”:”|cut -f1 -d”O”
UserParameter=mysql.qps,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f9 -d”:”
UserParameter=mysql.version,/usr/local/mysql/bin/mysql -V
vi zabbix_agentd.conf
Server=localhost(agent是安装在要监控的客户机上的.现在要把本机监控作为测试.所以填写server=localhost.否则这里填写你要汇报的服务器的ip)

Hostname=localhost
ListenPort=10050
ListenIP=localhost
StartAgents=5
RefreshActiveChecks=120
DisableActive=1
DebugLevel=3
PidFile=/var/tmp/zabbix_agentd.pid
LogFile=/var/log/zabbix_agentd.log
Timeout=3
UserParameter=mysql.ping,/usr/local/mysql/bin/mysqladmin -uzabbix -p ping|grep alive|wc -l
UserParameter=mysql.uptime,/usr/local/mysql/bin/mysqladmin -uzabbix-p status|cut -f2 -d”:”|cut -f1 -d”T”
UserParameter=mysql.threads,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f3 -d”:”|cut -f1 -d”Q”
UserParameter=mysql.questions,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f4 -d”:”|cut -f1 -d”S”
UserParameter=mysql.slowqueries,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f5 -d”:”|cut -f1 -d”O”
UserParameter=mysql.qps,/usr/local/mysql/bin/mysqladmin -uzabbix -p status|cut -f9 -d”:”
UserParameter=mysql.version,/usr/local/mysql/bin/mysql -V
vi zabbix_server.conf
Server=1
StartPollers=6
StartTrappers=5
ListenPort=10051
HousekeepingFrequency=1
SenderFrequency=30
DebugLevel=3
Timeout=5
UnreachablePeriod=45
UnavailableDelay=15
UnavailableDelay=60
PidFile=/var/tmp/zabbix_server.pid
LogFile=/var/log/zabbix_server.log
AlertScriptsPath=/home/zabbix/bin/
PingerFrequency=30
DBHost=localhost
DBName=zabbix
DBUser=root
DBPassword=
DBSocket=/usr/local/mysql/data/mysql.sock
zabbix_trapper.conf
grep -v ’^#’ zabbix_trapper.conf |grep -v ’^$’
DebugLevel=2
Timeout=3
LogFile=/var/log/zabbix_trapper.log
DBHost=localhost
DBName=zabbix
DBUser=root
DBPassword=
DBSocket=/usr/local/mysql/data/mysql.sock
生成启动服务
cp misc/init.d/redhat/zabbix_* /usr/local/zabbix/bin/
编辑zabbix_agentd_ctl 和 zabbix_server_ctl
BASEDIR=/usr/local/zabbix 为指定的zabbix安装目录.
zabbix_server_ctl文件中的
ZABBIX_SUCKERD=$BASEDIR/bin/zabbix_server
6.启动服务:
服务器端
/usr/local/zabbix/bin/zabbix_server_ctl start
客户端
/usr/local/zabbix/bin/zabbix_agentd_ctl start 
启动后.用ps查看服务是否启动.

ps aux|grep zabbix

正常应该会见到 zabbix的server和agent启动

 

然后.打开浏览器.输入主机地址的zabbix目录进行php等的设置就可以正常监控了

喜欢 (0)
[🍬谢谢你请我吃糖果🍬🍬~]
分享 (0)
关于作者:
少将,关注Web全栈开发、项目管理,持续不断的学习、努力成为一个更棒的开发,做最好的自己,让世界因你不同。