日常工作之Zabbix源码编译,兼容mysql5.6
原文链接: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依赖包:
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的更多相关文章
- centos6.5环境源码编译安装mysql5.6.34
centos6.5环境源码编译安装mysql5.6.34 源码下载地址http://dev.mysql.com/downloads/mysql/5.6.html#downloads 选择Generic ...
- 源码编译安装mysql5.5.33
源码编译安装mysql5.5.33 一.安装cmake编译工具 跨平台编译器 # yum install -y gcc* # yum install -y cmake 解决依赖关系 # yum ins ...
- Zabbix 源码编译安装
简介: Zabbix 分布式监控系统,源码编译安装记录 ( 记不得是第多少次了 ) 下载地址:http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX ...
- zabbix源码编译安装以及添加第一台host监控
基础准备 硬件需求 数据库需求 软件需求 其他软件需求 安装 安装方式 source code 编译好的二进制包 rpm或者deb 源码编译安装部署zabbix以及附件 前提准备 最小化安装操作系 ...
- Linux源码编译安装MySQL5.7
目录[-] 一.环境准备: 二.升级系统: 三.做一些准备工作(以下Linux命令均在su到root用户操作): 四.开始编译安装mysql-5.7.9: 一.环境准备: 我尝试过以下环境都是能成功的 ...
- ubuntu上源码编译安装mysql5.7.27
一.查看操作系统环境和目录结构,并创建mysql用户和组,以及规划安装mysql所需要的目录. #cat /etc/issue 查看发行版本信息: #cat /proc/version 查看正在运行 ...
- CentOS7.5源码编译安装mysql5.7.29
#查看系统版本 [root@ctos3 ~]# cat /etc/redhat-release CentOS Linux release (Core) #下载源码包,需要注意的是mysql5.7 编译 ...
- 源码编译安装MySQL-5.6/mysql-5.6.39------踩了无数坑,重装了十几次服务器才会的,不容易啊!
1.切换到src目录 cd /usr/local/src/ 2. 下载mysql免编译二进制包 免编译的mysql二进制包5.6源码包: wget http://mirrors.163.com/mys ...
- 源码编译安装MySQL5.7
一.数据库 概述 什么是数据库?简单来说就是存储数据的仓库.这个仓库它会按照一定的数据结构来对数据进行组织和存储.我们可通过数据库提供的多种方法来管理其中的数据 说比较通俗一点就是计算机中的数据库就是 ...
随机推荐
- 【小记录】关于dojo中的on事件
今天碰到一个现象,若是一个函数中存在一个on事件(例如点击事件),在该函数连续触发两次之后在去触发里面的on事件,会发现改时间所对应的函数被调用了两次,若父函数被连续触发N次后再取触发on事件,其对应 ...
- 常见的浏览器兼容性问题与解决方案——CSS篇
1.不同的浏览器的标签默认的外补丁和内补丁不同 问题症状:随便写几个标签,不加样式控制的情况下,各自的margin和padding差异较大. 碰到频率:100% 解决方案:初始化CSS的默认样式,*{ ...
- android测试Code
<!--android:layout_alignParentTop="true"--><com.koooke.platform.View.CenterImage ...
- 记一次使用MemoryCache不能Get的问题
在.NET Core自带的Angular模板项目中,我想要做一个简单的登录认证. 所以想填写用户名密码,使用guid作为key,存储登录信息,每次页面刷新的时候check它. 思路觉得没有问题,但是一 ...
- Python学习---重点模块之xml
xml是实现不同语言或程序之间进行数据交换的协议,跟json差不多,但json使用起来更简单 数据准备 <?xml version="1.0"?> <data&g ...
- Hadoop学习---Hadoop的深入学习
Hadoop生态圈 存储数据HDFS(Hadoop Distributed File System),运行在通用硬件上的分布式文件系统.具有高度容错性.高吞吐量的的特点. 处理数据MapReduce, ...
- sparsity and density
转:http://searchdatamanagement.techtarget.com/definition/sparsity-and-density 查了一下定义,以免会写错 Sparsity a ...
- Sql的一些常规判断
sql server中如何判断表或者数据库的存在,但在实际使用中,需判断Status状态位:其中某些状态位可由用户使用 sp_dboption(read only.dbo use only.singl ...
- Hibernate映射Map属性2
Hibernate在映射Map属性时生成映射文件.需要注意的一些地方.下面是我的一个例子. Java类如下 public class NameAndNumber { private Integer i ...
- python 获取某个月的全部日期
import calendar print range(calendar.monthrange(year, month)[1]+1)[1:]