原文链接:http://www.leleblog.top/daily/more?id=6

Zabbix源码编译

环境:

centOS7、mysql5.6.21(已存在)。

任务简述:

服务器搭建zabbix运维检测工具,监控服务器CPU、内存等参数,因为服务器已存在5.6版本的mysql,版本冲突,不能使用zabbix官方提供的安装流程。只能选择源码安装。

步骤:

1、下载zabbix源码包

wget http://sourceforge.net/projects/zabbix/files/ZABBIX%20Latest%20Stable/3.4.2/zabbix-3.4.2.tar.gz/download

2、安装编译环境

(1)、安装yum仓库可以安装的

yum -y install libxml2-devel libcurl-deve libevent libevent-devel

(2)、net-snmp-devel要求数据库的版本,因此这个也需要源码编译安装。

3、net-snmp-devel源码安装

(1)、下载源码

wget http://downloads.sourceforge.net/project/net-snmp/net-snmp/5.7.3/net-snmp-5.7.3.tar.gz

(2)、解压源码包

tar -xzvf net-snmp-5.7.3.tar.gz

(3)、配置编译

./configure --prefix=/usr/local/net-snmp

遇到选择项全部直接回车。

(4)、编译

make && make install

可能有问题,cloud not find perl。下载perl:

yum install perl

(5)、配置snmpd.conf

先将EXAMPLE.conf文件复制到/usr/local/net-snmp/share/snmp,并重命名为snmpd.conf

sudo cp EXAMPLE.conf /usr/local/net-snmp/share/snmp/snmpd.conf

(6)、启动snmp,进入snmp的sbin目录下。

./snmpd -c ../share/snmp/snmpd.conf

4、配置zabbix编译选项

./configure --prefix=/usr/local/zabbix --enable-server --enable-agent --with-mysql=/usr/local/mysql57/bin/mysql_config --enable-ipv6 --with-net-snmp --with-libcurl --with-libxml2

--prefix设置zabbix安装目录,--with-mysql设置mysql的mysql_config

出现问题:mysqlclinet.so找不到。

5、软连接mysqlclinet到公用lib下面。

A、使用locate或者find命令找到mysqlclinet.so文件

例如:locate mysqlclinet.so

若提示locate命令不存在,安装一下 yum install locate

B、软连接上面找到的路径到/usr/local/lib/下面

ln -s /data/aicmp/reviewboard-2.5.16-0/mysql/lib/libmysqlclient.so /usr/local/lib//libmysqlclient.so

6、编译zabbix

回到zabbix源码包目录下,执行

make && make install

编译完成。

7、启动命令设置为service进程

(1)、cp misc/init.d/fedora/core/zabbix_server /etc/init.d/

(2)、chkconfig --add zabbix_server

(3)、chkconfig zabbix_server on

(4)、cp misc/init.d/fedora/core/zabbix_agentd /etc/init.d/

(5)、chkconfig --add zabbix_agentd

(6)、chkconfig zabbix_agentd on

8、配置zabbix-server r 配置文件zabbix-server.conf

vi /etc/zabbix/zabbix_server.conf

修改如下选项:

DBHost=localhost          # 数据主机名

DBName=zabbix            # 数据库实例

DBUser=zabbix              # 用户名

DBPassword=zabbix      # 密码

9、启动zabbix服务

(1)、service zabbix_server start

(2)、service zabbix_agentd start

10、拷贝WEB应用程序,/data/html为nginx或者Apache的运行PHP程序的目录,这里使用apache服务器

mv zabbix/frontends/php/ /var/www/html/zabbix

11、配置apache服务器的php页面解析。(尚未安装php,先写了配置文件)

这时发现zabbix的web服务是php编写的,所以需要安装php以及配置apahce服务器的php页面解析。

vi /etc/httpd/conf/httpd.conf

加入以下选项:

AddType application/x-compress .Z

AddType application/x-gzip .gz .tgz

AddType application/x-httpd-php .php

12、安装php。

直接安装php是不可行的,centOS7自带的php版本为5.4,对于php-mysql的支持有问题,这里选择安装5.6。

(1)、升级软件仓库

rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm

rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

(2)、安装php及其组件

yum install -y php56w php56w-opcache php56w-xml php56w-mcrypt php56w-gd php56w-devel php56w-intl php56w-mbstring php56w-fpm

这里的php56w-mysql 因为mysql版本原因无法安装,自己去找相应的php-mysql下载。

13、rpm安装php-mysql、php-mysqlnd、php-mysqli

http://rpmfind.net是一个rpm包链接提供网站。

wget下载一些rpm依赖包:

Wget http://rpmfind.net/linux/mageia/distrib/5/x86_64/media/core/updates/lib64php5_common5-5.6.20-1.mga5.x86_64.rpm

Rpm -ivh命令安装

rpm -ivh lib64php5_common5-5.6.20-1.mga5.x86_64.rpm

以此类推,安装php-mysql、php-mysqlnd、php-mysqli

14、php -v命令检查php是否运行正常

报错:

PHP Warning:  PHP Startup: Unable to load dynamic library '/usr/lib64/php/modules/mysqlnd.so' - /usr/lib64/php/modules/mysqlnd.so: cannot open shared object file: No such file or directory in Unknown on line 0

PHP Warning:  PHP Startup: Unable to load dynamic library '/usr/lib64/php/modules/mysql.so' - /usr/lib64/php/modules/mysql.so: cannot open shared object file: No such file or directory in Unknown on line 0

显然不正常,这是再说mysql.so和mysqlnd.so这两个东西不在 /usr/lib64/php/modules目录下,mysqli.so也是没有的,信息没有贴出来。

这三个so文件是在 /usr/lib64/php/extensions/下面的,将三个文件全部软连接到usr/lib64/php/modules下就ok了。

例如:

ln -s /usr/lib64/php/extensions/mysql.so /usr/lib64/php/modules/mysql.so

剩下两个举一反三。

这时候php-v就发现运行正常了。

15、启动apache服务器

Service httpd start

16、访问http://ip:prot/zabbix/

出现问题:

需要设置一些参数。

17、设置php参数

vim /etc/php.ini

选项如下:

PHP option memory_limit

128M

PHP option post_max_size

16M

PHP option upload_max_filesize

2M

PHP option max_execution_time

300

PHP option max_input_time

300

PHP time zone

Asia/Shanghai

如果还有其他的,按照红字提示设置选项。

如果提示没有可支持的数据库,则说明之前安装php-mysql或php-mysqli有问题,回头重新检查。

18、顺序设置,设置完成后登录。

默认账户:admin  密码:zabbix

19、开启对本机的监控

默认是关闭对本机监控

手动开启:Configuration —> Hosts —> Status --> 点击Not monitored

然后在上方菜单栏Graphs中就可以查看CPU、内存等图表了。

日常工作之Zabbix源码编译,兼容mysql5.6的更多相关文章

  1. centos6.5环境源码编译安装mysql5.6.34

    centos6.5环境源码编译安装mysql5.6.34 源码下载地址http://dev.mysql.com/downloads/mysql/5.6.html#downloads 选择Generic ...

  2. 源码编译安装mysql5.5.33

    源码编译安装mysql5.5.33 一.安装cmake编译工具 跨平台编译器 # yum install -y gcc* # yum install -y cmake 解决依赖关系 # yum ins ...

  3. Zabbix 源码编译安装

    简介: Zabbix 分布式监控系统,源码编译安装记录 ( 记不得是第多少次了 ) 下载地址:http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX ...

  4. zabbix源码编译安装以及添加第一台host监控

    基础准备 硬件需求 数据库需求   软件需求 其他软件需求 安装 安装方式 source code 编译好的二进制包 rpm或者deb 源码编译安装部署zabbix以及附件 前提准备 最小化安装操作系 ...

  5. Linux源码编译安装MySQL5.7

    目录[-] 一.环境准备: 二.升级系统: 三.做一些准备工作(以下Linux命令均在su到root用户操作): 四.开始编译安装mysql-5.7.9: 一.环境准备: 我尝试过以下环境都是能成功的 ...

  6. ubuntu上源码编译安装mysql5.7.27

    一.查看操作系统环境和目录结构,并创建mysql用户和组,以及规划安装mysql所需要的目录. #cat /etc/issue 查看发行版本信息: #cat  /proc/version 查看正在运行 ...

  7. CentOS7.5源码编译安装mysql5.7.29

    #查看系统版本 [root@ctos3 ~]# cat /etc/redhat-release CentOS Linux release (Core) #下载源码包,需要注意的是mysql5.7 编译 ...

  8. 源码编译安装MySQL-5.6/mysql-5.6.39------踩了无数坑,重装了十几次服务器才会的,不容易啊!

    1.切换到src目录 cd /usr/local/src/ 2. 下载mysql免编译二进制包 免编译的mysql二进制包5.6源码包: wget http://mirrors.163.com/mys ...

  9. 源码编译安装MySQL5.7

    一.数据库 概述 什么是数据库?简单来说就是存储数据的仓库.这个仓库它会按照一定的数据结构来对数据进行组织和存储.我们可通过数据库提供的多种方法来管理其中的数据 说比较通俗一点就是计算机中的数据库就是 ...

随机推荐

  1. OSGEarth加载 geoserver 发布 TMS

    geoserver配好数据并用自带的gwc切片好后, 访问 http://localhost:9999/geoserver/gwc/service/tms/1.0.0/ 在OsgEarth的earth ...

  2. tensorflow: a Implementation of rotation ops (旋转的函数实现方法)

    tensorflow 旋转矩阵的函数实现方法 关键字: rot90, tensorflow 1. 背景 在做数据增强的操作过程中, 很多情况需要对图像旋转和平移等操作, 针对一些特殊的卷积(garbo ...

  3. 【Python】Sublime text 3 搭建Python IDE

    背景: 最经遇到一件很苦恼的事情,就是在Sublime text 3中写的Python代码直接挪到python原生的ide中老是报格式的错误(有时让人讨厌的缩进),没有办法,看到Sublime tex ...

  4. nodejs + redis/mysql 连接池问题

    nodejs + redis/mysql 连接池问题 需不需要连接池 连接池的作用主要是较少每次临时建立连接所带来的开销.初步一看,nodejs运行单线程上,它不能同时使用多个连接,乍一看是不需要连接 ...

  5. SQL Server ->> 更改服务器时区对SQL Server Agent服务器的影响

    昨天在把服务器的时区从PST改成UTC后,发现Job都不跑了.因为SQL Server Agent记录Job的历史运行时间是不区分时区的,也就是意味着我改后出现了最后一条运行记录比倒数第二条时间还要早 ...

  6. mongodb使用mongos链接复制集

    我们知道mongodb现在生产环境大部分还是使用的复制集来作为主流,据我了解.很多公司现在都是使用复制集的方式,而我们通过mongos可以巧妙的解决链接的问题,我们先从环境说起: 首先我们要模仿搭建的 ...

  7. drag与drop事件

    为了支持网页上一些元素的拖动效果,可以使用drag和drog事件. 目前ie 5.0+, firefox 3.5+等都支持这些事件,ECMA Script第5版正式将其纳入标准. 对于被拖动的元素来说 ...

  8. Oracle GoldenGate 详解

    一.Oracle GoldenGate介绍 GoldenGate软件是一种基于日志的结构化数据复制软件.GoldenGate 能够实现大量交易数据的实时捕捉.变换和投递,实现源数据库与目标数据库的数据 ...

  9. JAVA中的那些名词解释!

    1.JDO: (Java Data Object )是Java对象持久化的新的规范,也是一个用于存取某种数据仓库中的对象的标准化API.作用:用于存取某种数据仓库中的对象 2.JPA: JPA是Jav ...

  10. Python初学者第七天 字符串及简单操作

    7day 数据类型:字符串 1.定义 字符串是一个有序的字符的集合,用于储存和表示基本的文本信息.单.双.三引号之间的内容称之为字符串: a = ‘hello world!’ b = "你好 ...