一.简介

zabbix-server主要分为2部分:

  • zabbix程序 程序根据客户端的监控项,从客户端获取数据并写入到数据库,再根据触发器/动作等配置进行操作。
  • 展示页面 使用php编写,php脚本从数据库获得信息,用httpd或者nginx等网页服务器展示出来。

根据上述说明,zabbix需要部署在lamp或者lnmp上面,对于php页面来说,用apache好一些。

二.环境

[zabbix-server]
主机名 = host-1
系统 = centos-7.3
地址 = 1.1.1.1
软件 =
httpd-2.4 80
mariadb-5.5 3306
php-fpm-5.4 9000
zabbix-server-3.4 10051 [zabbix-agent]
主机名 = host-2
系统 = centos-7.3
地址 = 1.1.1.2
软件 =
zabbix-agent-3.4 10050 

三.配置

配置服务端程序

操作服务器(host-1)

1.yum部署lamp

♠.安装LAMP和依赖

yum -y install httpd php php-fpm php-mysql mariadb mariadb-server mariadb-devel

♠.启动并加入到自启动中

systemctl restart httpd mariadb php-fpm
systemctl enable httpd mariadb php-fpm

♠.创建一个简单的php脚本,测试httpd是否支持php,php是否可以连接mysql,mysql是否已启动

vim /var/www/html/linkdb.php

<?php
$db=mysql_connect("localhost","root","");
if($db){
echo "ok";
}else{
echo "no";
}
?>

返回ok则正常,返回no则检查数据库是否可以不用密码就登录,如果有默认密码,需要修改php脚本

curl http://127.0.0.1/linkdb.php

2.安装依赖包

yum -y install gcc gcc-c++ libevent-devel php-bcmath php-gd php-xml php-mbstring

3.创建账号,为安全起见禁止登录

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

4.下载源码包

wget https://shell-auto-install.oss-cn-zhangjiakou.aliyuncs.com/package/zabbix-3.4.1.tar.gz
tar -xf zabbix-3.4.1.tar.gz
cd zabbix-3.4.1

5.选择参数,当前只开启了服务端,其余编译参数如下

./configure --prefix=/usr/local/zabbix --enable-server --with-mysql

第一行是添加这个参数,需要安装的yum包,第二行是参数名

net-snmap-devel
--with-net-snmp libcurl-devel curl-devel
--with-libcurl libxml2-devel
--with-libxml2 OpenIPMI-devel
--with-openipmi unixODBC-devel
--with-unixodbc

6.编译安装

make install

7.将php脚本复制到html目录下

cp -r frontends/php/* /var/www/html/

8.添加所有权限到php脚本,当然这种方式比较危险,具体在zabbix前端页面会说明对哪些脚本要权限,逐个改

chmod -R 777 /var/www/html

9.登陆mariadb并创建zabbix用户,当前mariadb无密码

MariaDB [(none)]> create database zabbixdb character set utf8;
MariaDB [(none)]>grant all on zabbixdb.* to zabbixuser@"localhost" identified by "123456";
MariaDB [(none)]>quit

10.按顺序导入zabbix自带的数据库

mysql -uzabbixuser -p123456 zabbixdb < database/mysql/schema.sql
mysql -uzabbixuser -p123456 zabbixdb < database/mysql/images.sql
mysql -uzabbixuser -p123456 zabbixdb < database/mysql/data.sql

11.修改php参数,符合zabbix要求

vim /etc/php.ini

post_max_size = 16M
max_execution_time = 300
max_input_time = 300
date.timezone = Asia/Shanghai

12.重启服务

systemctl restart httpd php-fpm

配置服务端网页

操作服务器(host-1)

1.访问http://1.1.1.1

2.LDAP是特殊配置,不用管

3.数据库:zabbixdb 账号:zabbixuser 密码:123456

4.地址和端口都默认,Name可以不写或者随便写

5.确定信息后下一步即可

6.若遇到这一步,是因为zabbix对/var/www/html/conf/没有权限或者没写写进去。需要手动将文件下载,然后传入到服务器的/var/www/html/conf/zabbix.conf.php中刷新即可

7.登录,设置为中文。管理员:admin 密码:zabbix

更改为中文后,update更新

最下面或提示zabbix-server未启动,下面将启动zabbix服务端

启动zabbix-server

操作服务器(host-1)

1.复制并修改启动脚本,将安装目录替换为设置目录

cp misc/init.d/fedora/core/zabbix_server /etc/init.d/
chmod +x /etc/init.d/zabbix_server vim /etc/init.d/zabbix_server BASEDIR=/usr/local/zabbix

2.修改配置文件,填写数据库信息,前端页面是告诉php脚本从哪个数据库获得信息展示,这里告诉后端程序将收集的信息写入哪个数据库

vim /usr/local/zabbix/etc/zabbix_server.conf

DBName=zabbixdb #数据库名
DBUser=zabbixuser #数据库用户名
DBPassword=123456 #数据库用户密码

3.启动并检查端口是否正常,因为很多时候显示启动但并没有真正启动

/etc/init.d/zabbix_server start
netstat -utnalp | grep :10051

4.查看前端页面,会发现正常了

配置客户端

操作服务器(host-2)

1.zabbix客户端可以有版本小差异,服务端3.4版本,客户端3.2版本也可以

wget https://shell-auto-install.oss-cn-zhangjiakou.aliyuncs.com/package/zabbix-agent-3.4.1-1.el7.x86_64.rpm

2.安装

yum -y install zabbix-agent-3.4.1-1.el7.x86_64.rpm

3.清空配置后,编写配置,其它参数后面安装文档再加

> /etc/zabbix/zabbix_agentd.conf

4.当前配置是被动与主动模式都开启,方便后期调节

vim /etc/zabbix/zabbix_agentd.conf

#指定pid文件位置
PidFile=/var/run/zabbix/zabbix_agentd.pid #指定日志文件位置
LogFile=/var/log/zabbix/zabbix_agentd.log #设置为被动模式,将开启端口
StartAgents=3 #当前的主机名,要写正确,否则服务端会不识别
Hostname=host-2 #服务端的地址,用逗号(,)可以隔开写多个
Server=1.1.1.1 #服务端的地址,用逗号(,)可以隔开写多个
ServerActive=1.1.1.1 #自定义的脚本超时时间,
Timeout=8 #允许自定义脚本
UnsafeUserParameters=1 #加载其它配置文件
Include=/etc/zabbix/zabbix_agentd.d/*.conf

5.启动效验

systemctl start zabbix-agent
systemctl enable zabbix-agent
netstat -unltp | grep 10050

四.测试

操作服务器(host-1)

1.添加

2.配置主机信息

3.添加模板,连接模板后,主机将被模板所带的监控项监控

4.一般选择Template OS Linux,先点击添加,再添加,不然模板连接不上

5.等一分钟,ZBX灯亮

五.附录

导入其余数据库

1.postgresql导入
psql -U username
psql> create database zabbix;
psql > \q
cd database/postgresql
psql -U username zabbix < database/postgresql/schema.sql
psql -U username zabbix < database/postgresql/images.sql
psql -U username zabbix < database/postgresql/data.sql 2.oracle导入
sqlplus zabbix/password@host/ORCL
sqlplus>@database/oracle/schema.sql
sqlplus>@database/oracle/images.sql
sqlplus>@database/oracle/data.sql

zabbix源码安装 令人窒息的操作的更多相关文章

  1. zabbix源码安装实例

    环境 系统                 Centos7 zabbix版本      Zabbix 3.4.15 (revision 86739) zabbix源码安装 .tar.gz cd zab ...

  2. zabbix源码安装后,设置为服务启动和关闭

    zabbix源码安装,使用service启动与关闭服务 1. zabbix客户端的系统服务脚本 1.1 拷贝启动脚本 zabbix的源码提供了系统服务脚本,在/usr/local/src/zabbix ...

  3. Zabbix源码安装部署

    zabbix源码部署安装 参考文档:https://www.zabbix.com/documentation/4.0/manual/installation/install ​ https://www ...

  4. zabbix源码安装

    Zabbix通过C/S模式采集数据,通过B/S模式在web端展示和配置. 被监控端:主机通过安装agent方式采集数据,网络设备通过SNMP方式采集数据 Server端:通过收集SNMP和agent发 ...

  5. 简单说说Ubuntu利用bzr源码安装OpenERP7.0的操作步骤

    1.修改Ubuntu国内更新源,具体方法自己baidu.google. 修改更新源后,更新系统 sudo apt-get update sudo apt-get upgrade 复制代码 2.安装Po ...

  6. zabbix 源码安装

    操作系统:CentOS IP地址:192.168.21.127 Web环境:Nginx+MySQL+PHP zabbix版本:Zabbix 2.2 LTS 备注:Linux下安装zabbix需要有LA ...

  7. Zabbix源码安装,使用service命令管理zabbix进程

    1.       前期环境: Zabbix源代码解压包:/root/zabbix-3.0.27 Zabbix安装路径:/usr/local/zabbix-3.0.27 2.       复制启动脚本到 ...

  8. CentOS6.7源码安装MySQL5.6

    1.源码安装MySQL5.6 # CentOS6操作系统安装完成后,默认会在/etc目录下存在一个my.cnf, # 强制卸载了mysql-libs之后,my.cnf就会消失 rpm -qa | gr ...

  9. linux中的源码安装

    前两天自己在笔记本上装了CentOs版本的虚拟机,接着要装Python3,是源码安装的挺费劲,个人总结了一些源码安装的经验,今天在这里给大家分享一下. 1. 首先准备环境,安装必要的编译工具gcc g ...

随机推荐

  1. shell高级特性-4

    1.shell模块 shell脚本中可以加载配置文件或调用已经完成函数或脚本. a.加载配置文件 新建配置文件config,插入以下代码: reboot_mode=True 在同一路径下,新建文件mo ...

  2. [C# 设计模式] Adapter - 适配器模式(两种)

    Adapter - 适配器模式 序 现实生活中,我们常用到适配器. 你当前打开我这篇文章的笔记本电脑,电源的另一边不正连着一块适配器吗? 你平时想将三口插座插进二口插座里面,不也需要一个适配器吗? 整 ...

  3. Java开发笔记(四十二)日历工具的常见应用

    前面介绍了日历工具Calendar的基本用法,乍看起来Calendar与Date两个半斤八两,似乎没有多大区别,那又何苦庸人自扰鼓捣一个新玩意呢?显然这样小瞧了Calendar,其实它的作用大着呢,接 ...

  4. MySQL查询执行的基础——查询优化处理

    查询的生命周期的下一步是将一个SQL转换成一个可执行计划,MySQL再按照这个计划和存储引擎进行交互 语法解析器和预处理 首先,MySQL通过关键词将SQL语句进行解析,并生成一颗对应的"解 ...

  5. js 常用

    js设置 div高度和宽度 function autoHeight() { var h = $(window).height(); var w = $(window).width(); $(" ...

  6. 《React设计模式与最佳实践》笔记

    书里的demo都是15.3.2以下版本的,有些demo用最新的react 16.x版本会报错,安装包的时候记得改一下版本   第一章 React 基础 命令式编程描述代码如何工作,而声明式编程则表明想 ...

  7. elementui el-upload 在v-for里使用时 如何获取index

    <div v-for = 'item in list'> <div @click="getImageTypeIndex(index)"> <el-up ...

  8. Python爬取地图瓦片

    由于要在内网开发地图项目,不能访问在线的地图服务了,就想把地图瓦片下载下来,网上找了一些下载器都是需要注册及收费的,否则下载到的图都是打水印的,如下: 因为地图瓦片就是按照层级.行.列规则组织的一张张 ...

  9. 【Vue 2.x】计算属性

    Vue对象,按照现在的学习进度,可以分为: 其中el代表作用的HTML元素: data代表el中的所有数据: methods代表el中所有元素上的事件: computed代表计算属性,用于计算data ...

  10. 【Dojo 1.x】笔记1 入门

    Dojo是个框架 ,是个js框架,现在除了这一点什么都不知道,就这么上手了. ps:不建议Web初学者看我的笔记,这个要有一定积累才能看. 在<body>标签内写这么一点代码: <b ...