部署前须知:
一般情况下,我们是将其中Zabbix-Server、Zabbix-Proxy、Zabbix-Web、Zabbix-Database专门部署在一台独立服务器上,Zabbix-Agent一般部署在需要被监控的网站的服务器上。
由于资金限制,本人只有一台阿里云服务器,所以就在一台上做了。
首先确定自己的网站的LNMP已经部署完毕!,此处不作讲解!
wget https://sourceforge.net/projects/zabbix/files/ZABBIX%20Latest%20Stable/3.2.6/zabbix-3.2.6.tar.gz/download
yum -y install curl curl-devel net-snmp net-snmp-devel perl-DBI mariadb-devel mysql-devel
groupadd zabbix
useradd -s /sbin/nologin -M zabbix -g zabbix
create database zabbix charset=utf8;
grant all privileges on zabbix.* to 'zabbix'@'localhost' identified by 'zabbix';
flush privileges;
解压zabbix:
mv download /usr/local/
cd /usr/local;tar xzf download
./configure --prefix=/usr/local/zabbix/ --enable-server --with-mysql --enable-ipv6 --with-net-snmp --with-libcurl
make -j4&&make install
mkdir /usr/local/nginx/html/zabbix
cd /usr/local/zabbix-3.2.6/frontends/
\cp php/* /usr/local/nginx/html/zabbix/ -a
cd /usr/local/nginx/conf/vhost/
vim www.zabbix.com.conf
这里我采用的是基于端口的虚拟主机:
server {
listen 8080;
server_name localhost;
location / {
root html/zabbix;
index index.html index.php;
}
location ~*\.php$ {
root html/zabbix;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
注意:起初这里是会有很多红色的错误地方,需要你配置以下将其变更正确:
yum install php-mbstring php-bcmath php-gd php-xml -y
yum install gd gd-devel -y
sed -i '/post_max_size/s/8/16/g;/max_execution_time/s/30/300/g;/max_input_time/s/60/300/g;s/\;date.timezone.*/date.timezone \= PRC/g;s/\;always_populate_raw_post_data/always_populate_raw_post_data/g' php.ini
我进行到这一步依然有下面这个是红色的:
这里添加一个gettext.so模块就好了。
以上做完之后,重启php-fpm即可!
注:因为我数据库做的多实例,所以端口不是3306.
上面这些信息在第3步就做了。请看第3步。
点击下一步,发现报错:
无法匹配到数据库,这里我们需要导入一些sql语句把zabbix数据库给"格式化"一下:
cd /usr/local/zabbix-3.2.6/database/mysql/
mysql -uzabbix -pzabbix -S /data/mysql/3307/mysql3307.sock zabbix < schema.sql
mysql -uzabbix -pzabbix -S /data/mysql/3307/mysql3307.sock zabbix < images.sql
mysql -uzabbix -pzabbix -S /data/mysql/3307/mysql3307.sock zabbix < data.sql
注:上面这个因为我是多实例所以需要加-S
下面这种情况有可能会遇到。反正我没遇到。
nginx报错:
在nginx.conf文件中加入:
worker_processes 1;
events {
use epoll;
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log main;
#client_max_body_size 200M;
#limit_conn_zone $binary_remote_addr zone=addr:10m;
#limit_req_zone $binary_remote_addr zone=one:10m rate=5r/s;
//fastcgi_buffer_size 128k;
//fastcgi_buffers 4 256k;
//fastcgi_busy_buffers_size 256k;
include /usr/local/nginx/conf/vhost/*.conf;
}
上面//注释的内容就是需要添加的内容。
这里可以看出zabbix server没有起来,也没有监听10051端口。
所以我们需要起服务,并让它监听10051端口。
cd /usr/local/zabbix-3.2.6
cp misc/init.d/tru64/zabbix_server /etc/init.d/zabbix_server
chmod o+x /etc/init.d/zabbix_server
/etc/init.d/zabbix_server start
又报错:
在/usr/local/sbin目录下找不到zabbix_server这个文件。
ln -s /usr/local/zabbix/sbin/zabbix_server /usr/local/sbin/
做个软链接到/usr/local/zabbix/sbin/zabbix_server。
注意:千万不要把/etc/init.d/zabbix_server文件拿来做软连接,这个zabbix_server和sbin下的那个zabbix_server内容是不一样的。
/etc/init.d/zabbix_server start
lsof -i:10051
我们可以看到进程虽然是起来了,但是依然没有监听10051端口。
查看zabbix日志:
因为我做的是多实例,所以mysql位置并没有在yum安装的默认位置,做个软链接就行了。
ln -s /data/mysql/3307/mysql3307.sock /var/lib/mysql/mysql.sock
重启zabbix即可。
再lsof:
这样就好了。网页上刷新一下,也就好了。
出现不能监听端口10051,还有一种情况就是:
vim /usr/local/zabbix/etc/zabbix_server.conf
看看DBpassword,DBuser,DBname是否正确。
解压zabbix-3.2.6.tar.gz源码文件,切换至解压目录,编译安装Zabbix,命令如下:
./configure --prefix=/usr/local/zabbix_agent --enable-agent
make
make install
注:因为我是在一台云服务器上做的,所以注意不要和zabbix-server冲突。
启动zabbix-agent:
ln -s /usr/local/zabbix_agent/sbin/zabbix_agentd /usr/local/sbin/
cp /usr/local/zabbix-3.2.6/misc/init.d/tru64/zabbix_agentd /etc/init.d/
chmod o+x zabbix_agentd
/etc/init.d/zabbix_agentd start
cd /usr/local/zabbix_agent/etc/
cp zabbix_agentd.conf zabbix_agentd.conf.bak //先备份配置文件
vim zabbix_agentd.conf //添加如下内容
LogFile=/tmp/zabbix_agentd.log
Server=39.97.176.117
ServerActive=39.97.176.117
//上面两个都是配置zabbix_server所在的地址
Hostname=39.97.176.117 //这里配置zabbix_agent的地址
再添加云服务器的安全组规则,打开10050端口
再重启zabbix_agent即可!
/etc/init.d/zabbix_agentd stop
/etc/init.d/zabbix_agentd start
这个默认字体,有些地方并不能显示出来。所以我们需要换字体。
在网上下载simkai.ttf字体到自己的主机,然后如果是云服务器用scp远程拷贝到自己的云服务器上。如果是虚拟机还可以采用rz上传。
由于我是云服务器所以:
在云服务器上:mv DejaVuSans.ttf DejaVuSans.ttf.bak
在macbook主机的终端上:
scp /Users/shijiandingyiqingchun/Desktop/simkai.ttf root@39.97.176.117:/usr/local/nginx/html/zabbix/fonts/DejaVuSans.ttf
//windows直接rz上传即可。
因为它需要给数据库传输收集到的监控数据!
通过socket文件,定义是那个数据库。
数据库找到了,就看是这个数据库中名为什么的database,需要以什么身份去登录这个database。
我们这个其实还不算是分布式监控系统,因为没有zabbix-proxy,proxy和server差不多,是给server分担压力,但比server组件要小巧。我们前面zabbix-server新建了一个zabbix数据库,server负责给它提供数据,zabbix-proxy也可以添加数据库,proxy组件负责给它传输数据。
举个例子:
某公司整个四川有一个zabbix-server,四川各个市都有一个proxy,每个市可以查看自己的监控数据,总部还可以通过server的数据库zabbix看到总的监控数据。
8080、9000、3307、3308、4040、4041、10050、10051
8080:zabbix的web界面对外访问(nginx侦听端口)
9000:将php文件交给后台php解析。
3307和3308:主从库,zabbix-database就在其中。
4040:mysql-proxy读写分离软件开启的端口,主要用于网站请求的接收,并将其转发给后端mysql数据库,实现和mysql3307、3308端口的交互。
4041:mysql-proxy读写分离软件开启的端口,主要用于管理查看读写分离状态。
10050:zabbix-agent开启的端口,主要用于和server或者proxy进行交互和数据传输。
10051:zabbix-server开启的端口,主要用于和agent或者proxy、database交互。zabbix-proxy也是开启这个端口,负责和server、proxy、database。