云网牛站
所在位置:首页 > Linux云服务器 > 在Ubuntu 18.04.1下安装zabbix 3.4的方法

在Ubuntu 18.04.1下安装zabbix 3.4的方法

2018-09-13 11:36:03作者:Chinkedout工作室稿源:linux站

本文主讲在Ubuntu 18.04.1下安装zabbix 3.4的方法,实测成功。其实配置zabbix可以基于LNMP,也可以用apache代理方式,两者区别在于Nginx和apache的配置。最开始我是基于Ubuntu18.04.1的LNMP环境搭建,由于我也是初学Linux系统,各种问题,反正就是配置不成功。最后发现项目上用的是apache而不是Nginx做代理,就放弃了LNMP搭建。然而即便是使用apache做代理,网上的教程质量也是参差不齐,最后整理了教程才配置成功,特此整理成文。

 

操作系统及软件版本:

1.zabbix下载地址

2.Ubuntu18.04.1 desktop LST(zabbix3.4的官方安装手册中,写的是Ubuntu14和Ubuntu16,实测18也可以)

3.MySQL5.7

3.PHP7.2 (网上有些教程是基于php5.x,都是Ubuntu14/16的教程,此处使用Ubuntu18,官方说明只支持PHP5.4及其以上,加上Ubuntu18默认安装的PHP7,所以此处是PHP7.2)

4.PHP扩展包(自行安装。PS:这些包有些是其他数据库使用的,如果你用MySQL,没必要安装与MySQL无关的扩展。PPS:实际上这些包我也没安全,但也可以运行:

gd 2.0或以上 PHP GD扩展包必须支持PNG图片 (--with-png-dir), JPEG (--with-jpeg-dir) images and FreeType 2 (--with-freetype-dir).
bcmath   php-bcmath (--enable-bcmath)
ctype   php-ctype (--enable-ctype)
libXML 2.6.15或以上 php-xml or php5-dom,由分发者提供单独的部署包。
xmlreader   php-xmlreader,由分发者提供单独的部署包。
xmlwriter   php-xmlwriter,由分发者提供单独的部署包。
session   php-session,由分发者提供单独的部署包。
sockets   php-net-socket (--enable-sockets). 用户脚本支持所需要的组件。
mbstring   php-mbstring (--enable-mbstring)
gettext   php-gettext (--with-gettext). 用于翻译的运行。
ldap   php-ldap.只有当在前端使用LDAP认证时才需要。
ibm_db2   使用IBM DB2作为Zabbix后端数据库所需要的组件。
mysqli   使用MySQL作为Zabbix后端数据库所需要的组件。
oci8   使用Oracle作为Zabbix后端数据库所需要的组件。
pgsql   使用PostgreSQL作为Zabbix后端数据库所需要的组件。
sqlite3   使用SQLite作为Zabbix后端数据库所需要的组件。

附上我的PHP及扩展:

在Ubuntu 18.04.1下安装zabbix 3.4的方法

注:你会发现我安装好的扩展和表里的对不上,有些包安装不了,我能安的都在这里了,反正zabbix最后可以运行的。

 

一、准备工作

出于安全考虑, zabbix 只使用普通用户运行,假如你当前用户叫 dog,运行zabbix后,便以 dog 身份运行。但是如果你在 root 环境下运行 zabbix,那么 zabbix 将会主动尝试以 zabbix 身份来运行。所以这里需要创建zabbix 的用户,如下:

groupadd zabbix

useradd -g zabbix zabbix

passwd zabbix 

PS:网上的教程中,有的写需要创建账户,有的没这一步骤;在有创建账户的教程里,有的又有密码,有的又没密码。这里我创建了账户并设置了密码,最终部署成功。

 

二、安装apache、mysql、php

sudo apt-get update

sudo apt-get install apache2

sudo apt-get install mysql-server

sudo apt-get install php php-mbstring php-gd php-xml php-bcmath php-ldap php-mysql

这里有问题:实际安装MySQL的时候,网上几乎所有教程都要说顺便设置MySQL的账号密码,然而在Ubuntu18.04.1中,安装MySQL确实不需要输入密码(多次试验结果,我用的root账户安装,root默认无密码),这样安装好的后的MySQL直接用root登录,不需要密码。当然你也可以自己给root设置一个密码。

PS:安装PHP及其依赖这一步我必须说明一下,这段指令我是复制网上的,很明显,和前文给出的依赖相比,少了一些,但即便如此,在后面的web端配置中,检测PHP依赖时,都显示OK。后来回忆了一下,应该是这样的,我用上面的指令安装php及其依赖后,对照了官方网站的依赖需求,我手动也安装过部分依赖,读者们可以根据官方给出的依赖自己安装,如果提示已经安装,就不管,没提示的直接安装就好。遇到安装不了的,暂时不管(我非常确定我没全部安装,有些是真心安不上,即便如此,后面的检测都正常)。

 

三、修改php时区

vim /etc/php/PHP_VERSION/apache2/php.ini

PS:我的PHP版是7.2。所以是这样的:

#vim /etc/php/7.2/apache2/php.ini 

修改如下内容:

; http://php.net/date.timezone

date.timezone = 'Asia/Shanghai'

 

四、zabbix安装

PS:官方手册里给的案例是基于Ubuntu16,我用的是Ubuntu18.04.1,同样可以安装。

# wget http://repo.zabbix.com/zabbix/3.4/ubuntu/pool/main/z/zabbix-release/zabbix-release_3.4-1+xenial_all.deb

# dpkg -i zabbix-release_3.4-1+xenial_all.deb

# apt-get update

1.安装Zabbix:

sudo apt-get update

apt-get install zabbix-server-mysql zabbix-frontend-php

2.只安装Zabbix Agent的示例:

# apt-get install zabbix-agent

 

五、数据库配置

进入MySQL:

mysql -u root -p

如果你和我一样,默认的root没有密码,那么此时数据库也不需要密码,回车后直接进入。如果你设置了密码,用你设置的密码登录MySQL即可。

1、创建zabbix数据库

shell> mysql -uroot -p<password>

mysql> create database zabbix character set utf8 collate utf8_bin;

mysql> grant all privileges on zabbix.* to zabbix@localhost identified by 'password';

mysql> flush privileges; 

mysql> quit;

脚本功能描述:

①.进入数据库(密码根据实际情况看,我安装的时候是没有密码的,直接回车进入,如果你有密码,password替换为你的密码)

②.创建名称为zabbix的库,编码格斯为utf8(必须是utf8,否则后面的web端会乱码)

③.创建一个zabbix用户,允许登录MySQL数据库,登录账户就是zabbix,密码可以自行设置,此处为password,这个密码很重要,后面要用到,记下来。

④.更新授权信息,很多教程里没这一步,包括官方,反正我是加了

2、初始化zabbix数据库

# cd /usr/share/doc/zabbix-server-mysql

# zcat create.sql.gz | mysql -uroot zabbix

如果正常安装了zabbix-server,就会有这个目录,导入数据库就可以了,注意,这里没说需要密码,是因为我的过程里没有密码,如果你有密码,可能需要这样:zcat create.sql.gz | mysql -u root -p ‘password’。PS:在其他教程中,导入数据库的操作可能和本教程有所不同,我也在这一步折腾了很久。有些教程是导入了3个数据库,我也尝试想这样做,但老是失败。后来才知道,如果是安装的3.4版本,只需要这一步就可以了。

 

六、配置和启动zabbix

在zabbix_server.conf中编辑数据库配置,编辑zabbix_server.conf:

vim /etc/zabbix/zabbix_server.conf

修改如下配置:

DBHost=localhost

DBName=zabbix

DBUser=zabbix

DBPassword=zabbix

PS:DBPassword这一项,理论上应该是设置的数据库密码,我在操作的时候也知道这一点,所以最开始设置的时候,先随便将DBPassword设置为zabbix,想着如果不对,大不了再改为数据库密码。但后来发现,好像这里没起到作用。

配置好后,重启zabbix进程:

# service zabbix-server start

只要没报错,就是启动成功了。

 

七、编辑Zabbix前端的PHP配置

Zabbix前端的Apache配置文件位于 /etc/apache2/conf.d/zabbix 或者 /etc/apache2/conf-enabled/zabbix.conf。

php_value max_execution_time 300

php_value memory_limit 128M

php_value post_max_size 16M

php_value upload_max_filesize 2M

php_value max_input_time 300

php_value always_populate_raw_post_data -1

php_value date.timezone Asia/Shanghai

对比可知,其实就是修改了时区。PS:实际上打开配置文件后,会发现php5和php7两个配置选项,因为Ubuntu18.04.1里默认安装的PHP7版本(Ubuntu18.04.1是7.2),所以修改php7里的配置就可以了。在实际的配置文件里,我发现还多了一个配置项目,可能是版本不同导致的。

PS:LNMP环境下搭建zabbix其实就是这里不一样,网上的教程很多,但全面可靠、按部就班配置就可以正常工作的我没见到过(基于Ubuntu18+zabbix3.4真心找不到,有的都是CentOS+zabbix3.0或其他低版本)。

最后重启Apache Web服务器:

# service apache2 restart

 

八、进入web端

如果前面的步骤都没问题,就可以进入到web端了,浏览器输入地址 http://localhost/zabbix 会出现web页面:

在Ubuntu 18.04.1下安装zabbix 3.4的方法

直接Next step:

在Ubuntu 18.04.1下安装zabbix 3.4的方法

这里要检查一下依赖是不是都显示ok。如果有不OK的,要自己安装依赖。关于图示方面,当时只是显示的PHP版本不对,结果是一样的:

在Ubuntu 18.04.1下安装zabbix 3.4的方法

这里的host地址我实际上写的是localhost(等价于127.0.0.1),当时填这个地址也可以,你可以参考。密码就是MySQL下你创建zabbix用户时的密码。端口什么的都保持默认。填写完后点击next:

在Ubuntu 18.04.1下安装zabbix 3.4的方法

这里都是默认就好,Name当时我随便写的zabbix,然后next:

在Ubuntu 18.04.1下安装zabbix 3.4的方法

最后成功,就会到这个页面,默认用户是Admin,密码zabbix,点击Sign in:

在Ubuntu 18.04.1下安装zabbix 3.4的方法

我这里已经设置为中文了,第一次进入这个页面,是英文的,配置中文显示很简单,点击右上角的小人:

在Ubuntu 18.04.1下安装zabbix 3.4的方法

在弹出的页面里,找到Language,选择Chinese(zh_CN),最后更新即可。

在Ubuntu 18.04.1下安装zabbix 3.4的方法

到这里,安装zabbix 3.4就完成了。

 

相关主题

Ubuntu 18.04系统中安装mysql 5.7数据库

精选文章
热门文章