CentOS8系统下zabbix4.4离线安装

要完成离线安装需要先准备一台与离线服务器装有相同操作系统的电脑联网下载安装包。

1、登陆zabbix官网,选择要安装的zabbix版本。地址:https://www.zabbix.com/cn/download?zabbix=4.4&os_distribution=centos&os_version=8&db=mysql&ws=nginx。这里我们选择zabbix4.4版本, CentOS8、mysql数据库、Nignx。

选择对应版本

2、用能上网的主机下载安装包

参考官网安装步骤:

参考的官网步骤

用能上网的主机安装zabbix-release-4.4-1.el8.noarch.rpm,下载对应的安装包。在执行rpm -Uvh https://repo.zabbix.com/zabbix/4.4/rhel/8/x86_64/zabbix-release-4.4-1.el8.noarch.rpm进行安装时如果碰上网络不好会出现以下情况:

网络原因导致安装失败

这时我们可以考虑使用国内的镜像进行安装,这里采用阿里云的镜像。步骤如下:

1)rpm -Uvh https://mirrors.aliyun.com/zabbix/zabbix/4.4/rhel/8/x86_64/zabbix-release-4.4-1.el8.noarch.rpm

执行成功后的结果

2)因为我们是通过阿里云镜像进行下载,此处需要修改此次下载使用的软件仓库文件,地址/etc/yum.repos.d路径下zabbix.repo文件,需要修改为阿里云的镜像地址,具体修改如下:

修改后的zabbix.repo文件

3)在/root目录下创建zabbix目录(因为我使用的root用户进行安装,如果选用其它用户可以自己定义下载路径),存放下载的安装包。

mkdir zabbix 

通过dnf命令下载对应的安装包,此处只下载不安装,指定的下载路径为/root/zabbix

dnf install --downloadonly --downloaddir=/root/zabbix zabbix-server-mysql zabbix-web-mysql zabbix-nginx-conf zabbix-agent

执行的命令
执行成功后的结果

4)执行成功后zabbix目录下会下载27个.rpm结尾的安装文件,把这些文件拷贝到需要离网的服务器。

5)在最终的离网服务器上安装zabbix4.4.登录到安装文件目录执行安装命令。

rpm -Uvh ***.rpm  #其中U表示更新,v表示显示安装过程,h表示显示进度

安装成功后显示的结果

6)在mysql数据库上创建zabbix用户和zabbix数据库并导入数据。

创建zabbix用户

create user 'zabbix'@'localhost' identified by '123456zabbix';

为zabbix用户赋权,zabbix用户对所有数据库中文件可以做任何操作

grant all privileges  on *.*  to "zabbix"@'localhost';

创建zabbix数据库,此处一定要指定utf8字符集,而且必须是utf8字符集,如果是别的字符集在配置zabbix的时候肯定要报错。

create database zabbix character set utf8 collate utf8_bin;

向zabbix数据库导入数据,执行以下命令:

zcat /usr/share/doc/zabbix-server-mysql/create.sql.gz | mysql -u zabbix -p

此处肯定会出现以下错误:

出现没有数据库选择错误

这里需要通过vim命令修改create.sql.gz文件。执行以下命令:

vim /usr/share/doc/zabbix-server-mysql/create.sql.gz

在打开的文件中点击"i"键,在文件的最上面插入use zabbix;。然后点击esc键,:wq!保存退出。此处就是在加载数据文件的时候首先切换到zabbix数据库。然后再执行zcat /usr/share/doc/zabbix-server-mysql/create.sql.gz | mysql -u zabbix -p命令,加载数据。最后会在zabbix数据库离创建149个表的数据。

导入数据时如果出现以下错误:

ERROR 1045 (28000): Access denied for user 'zabbix'@'localhost' (using password: YES)

需要登录数据库执行:

ALTER USER 'zabbix'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456zabbix';

赋予本地访问权限。

执行完的效果

参考官网安装步骤:

参考的官网步骤

7)为Zabbix server配置数据库。执行以下命令

vi /etc/zabbix/zabbix_server.conf

将DBPassword前面的注释删除并填上zabbix用户的密码

8)修改nginx配置文件,为Zabbix前端配置PHP

修改/etc/nginx目录下的nginx.conf文件,修改方法就是用/etc/nginx/conf.d/zabbix.conf文件中的内容替换/etc/nginx/nginx.conf文件中server括号内的内容。

vi /etc/nginx/nginx.conf

要将listen和server_name前面的注释删掉。

9)编辑配置文件 /etc/php-fpm.d/zabbix.conf,修改时区,前面的“;”一定要去掉。中国只能改为Asia/Shanghai,不能是Asia/Beijing。

修改时区
参考的官网步骤

10)关闭SElinux,firewalld,具体的执行命令参考以下信息:

#查看selinux状态

[root@localhost zabbix]# getenforce

Enforcing  #开启状态

#设置selinux为被动模式

[root@localhost zabbix]# setenforce 0

[root@localhost zabbix]# getenforce

Permissive  #被动模式

[root@localhost zabbix]# vi /etc/selinux/config

SELINUX=disable

#查看firewall是否开机启动

[root@localhost zabbix]# systemctl list-unit-files | grep fire

firewalld.service                          enabled

#查看firewall是否正在运行

[root@localhost zabbix]# systemctl status firewalld.service

[root@localhost zabbix]# systemctl list-units | grep fire

#停掉firewall,并禁止开机启动

[root@localhost zabbix]# systemctl stop firewalld.service

[root@localhost zabbix]# systemctl disable firewalld.service

关闭firewall
修改selinux的配置文件
改为disable

11)启动zabbix进程

systemctl restart zabbix-server zabbix-agent nginx php-fpm

设置为开机启动

systemctl enable zabbix-server zabbix-agent nginx php-fpm

如果启动失败肯定是SElinux,firewalld没有关闭的原因,检查是否关闭。

12)通过前端页面进行zabbix设置,访问http://localhost/setup.php地址。

zabbix设置界面

数据库设置界面需要输入zabbix用户的密码,同时容易出现字符集错误,所以创建的zabbix数据库必须使用SET utf8 COLLATE utf8_bin;如果设置错误,数据导入后再修改字符集也会报错,只能删除数据库重新创建。所以一定要保证使用的字符集正确。

字符集错误

数据库设置时还需要在数据库中执行以下ALTER USER 'zabbix_username'@'localhost' IDENTIFIED WITH mysql_native_password BY 'zabbix_password';(需要修改对应的用户名和密码),这样zabbix服务才能在本地访问mysql数据库。

数据库配置可能出现以下问题,如果日志/var/log/zabbix/zabbix_server.log中看到以下错误

肯定是导入数据表有问题,实际操作中出现过导入表数量没问题,但是表无法打开的问题。需要重新执行表导入操作。

以下错误可以通过再次修改密码解决

query failed: [1053] Server shutdown in progress [select taskid,type,clock,ttl from task where status in (1,2) order by taskid]

  7039:20200915:204305.347 [Z3001] connection to database 'zabbix' failed: [2002] Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

配置完成

通过Admin/zabbix 用户名/密码登录系统。

安装完成!

问题:

10258:20201105:044732.399 __mem_malloc: skipped 4 asked 6296 skip_min 352 skip_max 5840

10258:20201105:044732.399 [file:dbconfig.c,line:94] __zbx_mem_realloc(): out of memory (requested 6296 bytes)

10258:20201105:044732.399 [file:dbconfig.c,line:94] __zbx_mem_realloc(): please increase CacheSize configuration parameter

10258:20201105:044732.399 === memory statistics for configuration cache ===

解决方法:

找到zabbix_server.conf文件

在zabbix_server.conf文件搜索CacheSize=8M或者VMwareCacheSize=8M,将其修改为CacheSize=1024M

重启:

systemctl restart zabbix-server zabbix-agent nginx php-fpm

参考摘录文档:

https://www.zabbix.com/download?zabbix=4.4&os_distribution=centos&os_version=8&db=mysql&ws=nginx

https://www.cnblogs.com/forlive/p/9358605.html

https://blog.csdn.net/yulei_qq/article/details/83713472

https://www.cnblogs.com/opsprobe/p/10812274.html

https://www.cnblogs.com/wangyueping/p/11258028.html

https://blog.csdn.net/u013948852/article/details/99842484

https://blog.csdn.net/zhaowenzhong/article/details/83753946

https://www.cnblogs.com/wangyueping/p/11258028.html

https://www.cnblogs.com/will--1213/p/11824550.html

https://blog.csdn.net/abcdu1/article/details/89471790

zabbix图形展现中文乱码解决方法

https://blog.csdn.net/qq43748322/article/details/85676511

上传的字体可以随便放一个目录内,指定的位置正确就可以

你可能感兴趣的:(CentOS8系统下zabbix4.4离线安装)