# 1.安装存储库
rpm -Uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
yum clean all
# 2.安装Server及Agent
yum install -y zabbix-server-pgsql zabbix-agent
# 3.启用软件集并安装Web及
yum install -y centos-release-scl
# Edit file /etc/yum.repos.d/zabbix.repo and enable zabbix-frontend repository.
vim /etc/yum.repos.d/zabbix.repo
[zabbix-frontend]
enabled=1
# Install Zabbix frontend package
yum install -y zabbix-web-pgsql-scl zabbix-nginx-conf-scl
# 安装完成后
[root@tcloud ~]# rpm -qa | grep zabbix
zabbix-agent-5.0.32-1.el7.x86_64
zabbix-web-5.0.32-1.el7.noarch
zabbix-web-deps-scl-5.0.32-1.el7.noarch
zabbix-release-5.0-1.el7.noarch
zabbix-server-pgsql-5.0.32-1.el7.x86_64
zabbix-web-pgsql-scl-5.0.32-1.el7.noarch
zabbix-nginx-conf-scl-5.0.32-1.el7.noarch
2.2 数据库初始化

官方文档会根据不同的数据库给出不同的初始化脚本:

更换了zabbix数据库如何重新连接数据库_php


更换了zabbix数据库如何重新连接数据库_数据库_02

以下过程为PostgreSQL数据库:

# 1.(官网指导)创建用户和数据库
sudo -u postgres createuser --pwprompt zabbix
sudo -u postgres createdb -O zabbix zabbix

#(真实操作)这个过程可以在 Navicat 上进行

更换了zabbix数据库如何重新连接数据库_分布式_03


更换了zabbix数据库如何重新连接数据库_zabbix_04

# 2.(官网指导)初始化数据库
zcat /usr/share/doc/zabbix-server-pgsql*/create.sql.gz | sudo -u zabbix psql zabbix
 
#(真实操作)解压 create.sql.gz
gzip -d create.sql.gz
# 在 Navicat 里执行 create.sql

更换了zabbix数据库如何重新连接数据库_数据库_05


更换了zabbix数据库如何重新连接数据库_分布式_06

# 3.(官网指导)Edit file /etc/zabbix/zabbix\_server.conf
DBPassword=password

# (真实操作)修改配置文件(主要是数据库相关)使用的是非localhost的库
vim /etc/zabbix/zabbix_server.conf
DBHost=xxx.xx.x.x[云服务器的内网IP]
DBName=zabbix[根据初始化的数据库名称设置]
DBUser=zabbix[根据实际情况设置]
DBPassword=zabbix[根据设置的密码设置]
DBPort=5432[根据数据库的端口填写]
2.3 前端配置

由于项目使用的是 Nginx,这里展示的是使用 Nginx 的配置:

# 1.(官网指导)
Edit file /etc/opt/rh/rh-nginx116/nginx/conf.d/zabbix.conf uncomment and set 'listen' and 'server\_name' directives.
# listen 80;
# server\_name example.com;

# (真实操作)
cat /etc/opt/rh/rh-nginx116/nginx/conf.d/zabbix.conf

复制/etc/opt/rh/rh-nginx116/nginx/conf.d/zabbix.conf的内容并进行修改,添加到Nginx的配置/usr/local/nginx/conf/nginx.conf内:

# 修改内容为 listen 和 server\_name 和 fastcgi\_pass
server {
        listen          8081;
        server_name     localhost;

        root    /usr/share/zabbix;

        index   index.php;

        location = /favicon.ico {
                log_not_found   off;
        }

        location / {
                try_files       $uri $uri/ =404;
        }

        location /assets {
                access_log      off;
                expires         10d;
        }

        location ~ /\.ht {
                deny            all;
        }

        location ~ /(api\/|conf[^\.]|include|locale|vendor) {
                deny            all;
                return          404;
        }

        location ~ [^/]\.php(/|$) {
                fastcgi_pass    localhost:9000;
                fastcgi_split_path_info ^(.+\.php)(/.+)$;
                fastcgi_index   index.php;

                fastcgi_param   DOCUMENT_ROOT   /usr/share/zabbix;
                fastcgi_param   SCRIPT_FILENAME /usr/share/zabbix$fastcgi\_script\_name;
                fastcgi_param   PATH_TRANSLATED /usr/share/zabbix$fastcgi\_script\_name;

                include fastcgi_params;
                fastcgi_param   QUERY_STRING    $query\_string;
                fastcgi_param   REQUEST_METHOD  $request\_method;
                fastcgi_param   CONTENT_TYPE    $content\_type;
                fastcgi_param   CONTENT_LENGTH  $content\_length;

                fastcgi_intercept_errors        on;
                fastcgi_ignore_client_abort     off;
                fastcgi_connect_timeout         60;
                fastcgi_send_timeout            180;
                fastcgi_read_timeout            180;
                fastcgi_buffer_size             128k;
                fastcgi_buffers                 4 256k;
                fastcgi_busy_buffers_size       256k;
                fastcgi_temp_file_write_size    256k;
        }
}

# 将内容复制出来修改后复制到 /usr/local/nginx/conf/nginx.conf 内
vim /usr/local/nginx/conf/nginx.conf

修改 /etc/opt/rh/rh-php72/php.ini 否则会出现,Check of pre-requisites:

更换了zabbix数据库如何重新连接数据库_zabbix_07

  • Minimum required size of PHP post is 16M (configuration option “post_max_size”).
  • Minimum required limit on execution time of PHP scripts is 300 (configuration option “max_execution_time”).
  • Minimum required limit on input parse time for PHP scripts is 300 (configuration option “max_input_time”).
  • Time zone for PHP is not set (configuration parameter “date.timezone”).

更换了zabbix数据库如何重新连接数据库_数据库_08

# 修改 /etc/opt/rh/rh-php72/php.ini
vim /etc/opt/rh/rh-php72/php.ini
# 默认值8M
post\_max\_size=16M
# 默认值30
max\_execution\_time=300
# 默认值60
max\_input\_time=300
# 默认未设置 ;date.timezone =
date.timezone = Asia/Shanghai
# 2.(官网指导)
Edit file /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf add nginx to listen.acl_users directive.
listen.acl_users = apache,nginx
# Then uncomment and set the right timezone for you.
; php_value[date.timezone] = Europe/Riga

# (真实操作)
vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
# 修改user和group
user = nginx
group = nginx
# 修改listen.acl\_users
listen.acl_users = nginx


**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以点击这里获取]()**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**