阿里云ECS部署zabbix v3.2.3

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: zabbix v3.2.3安装部署 阿里云ECS部署zabbix 3.2;并接入RDS 关于zabbix及相关服务软件版本: Linux: ECS_CentOS 7.2 nginx: 1.9.15 mysql: RDS或自建MySQL PHP:5.5.35 一、购买ECS & RDS 这里购买ECS和RDS最好买在一个区域,这样RDS就不用申请公网访问地址了,直接添加安装zabbix的ECS_IP白名单就OK了。

阿里云ECS部署zabbix v3.2.3


阿里云ECS部署zabbix 3.2;并接入RDS

关于zabbix及相关服务软件版本:


Linux: ECS_CentOS 7.2

nginx: 1.9.15

mysql: RDS或自建MySQL

PHP:5.5.35

一、购买ECS & RDS

这里购买ECS和RDS最好买在一个区域,这样RDS就不用申请公网访问地址了,直接添加安装zabbix的ECS_IP白名单就OK了。
如果购买ECS和RDS都不会,那就不用往下看了。

二、安装Nginx

安装依赖包:

yum -y install gcc gcc-c++ autoconf automake zlib zlib-devel openssl openssl-devel pcre* make gd-devel libjpeg-devel libpng-devel libxml2-devel bzip2-devel libcurl-devel

创建nginx用户:

useradd nginx -s /sbin/nologin -M

下载nginx软件包并进入到目录中:

wget http://nginx.org/download/nginx-1.9.15.tar.gz && tar xvf nginx-1.9.15.tar.gz && cd nginx-1.9.15

编译:

./configure --prefix=/usr/local/product/nginx1.9.14 --user=nginx --group=nginx --with-http_ssl_module --with-http_v2_module --with-http_stub_status_module --with-pcre

make && make install

ln -s /usr/local/product/nginx1.9.14 /usr/local/nginx    ==>创建软链接

参数解释:

--with-http_stub_status_module:支持nginx状态查询
--with-http_ssl_module:支持https
--with-http_spdy_module:支持google的spdy,想了解请百度spdy,这个必须有ssl的支持
--with-pcre:为了支持rewrite重写功能,必须制定pcre

三、安装PHP

下载PHP安装包:

wget http://cn2.php.net/get/php-5.5.35.tar.gz/from/this/mirror

解压并编译:

mv mirror php-5.5.35.tar.gz && tar xvf php-5.5.35.tar.gz && cd php-5.5.35

./configure --prefix=/usr/local/product/php-5.5.35 --with-config-file-path=/usr/local/product/php-5.5.35/etc --with-bz2 --with-curl --enable-ftp --enable-sockets --disable-ipv6 --with-gd --with-jpeg-dir=/usr/local --with-png-dir=/usr/local --with-freetype-dir=/usr/local --enable-gd-native-ttf --with-iconv-dir=/usr/local --enable-mbstring --enable-calendar --with-gettext --with-libxml-dir=/usr/local --with-zlib --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd --with-mysql=mysqlnd --enable-dom --enable-xml --enable-fpm --with-libdir=lib64 --enable-bcmath

make && make install
ln -s /usr/local/product/php-5.5.35 /usr/local/php

cp php.ini-production /usr/local/php/etc/php.ini
cd /usr/local/php/etc/

cp php-fpm.conf.default php-fpm.conf

修改php.ini参数:(zabbix环境需要修改的参数)

max_execution_time = 300 
memory_limit = 128M 
post_max_size = 16M 
upload_max_filesize = 2M 
max_input_time = 300 
date.timezone = PRC

四、MySQL(如果购买的是RDS就不用安装了)

4.1 使用RDS(MySQL)

这里就不需要安装MySQL了,但是需要创建一个zabbix的数据库和用户名,字符集为utf8;

4.2 安装MySQL

添加mysql用户,创建mysql的数据目录:

groupadd mysql
mkdir -pv /data/mysql

useradd -r -g mysql -d /data/mysql -s /sbin/nologin mysql

chown -R mysql.mysql /data/mysql

安装cmake及依赖:

yum install cmake gcc* ncurses-devel -y 

下载MySQL安装包:

wget http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.49.tar.gz

编译安装MySQL:

tar -xvf mysql-5.5.49.tar.gz && cd mysql-5.5.49

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/product/mysql5.5.49 -DDEFAULT_CHARSET=utf8 -DENABLED_LOCAL_INFILE=1 -DMYSQL_DATADIR=/data/mysql -DWITH_EXTRA_CHARSETS=all -DWITH_READLINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DMYSQL_TCP_PORT=3306 -DDEFAULT_COLLATION=utf8_general_ci

make && make install

ln -s /usr/local/product/mysql5.5.49 /usr/local/mysql

chown -R mysql.mysql /usr/local/mysql

拷贝mysql的配置文件:

cd /usr/local/mysql/support-files/

cp my-medium.cnf /data/mysql/my.cnf

cp mysql.server /etc/init.d/mysqld

chmod +x /etc/init.d/mysqld

初始化MySQL:

cd /usr/local/mysql/scripts
./mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/data/mysql/

修改MySQL配置文件my.cnf中数据目录:

datadir=/data/mysql/

启动MySQL:

[root@zabbix ~]# /etc/init.d/mysqld start
Starting MySQL... SUCCESS!

登录数据库,创建zabbix数据库及用户名和密码:

mysql> create database zabbix default charset utf8;
Query OK, 1 row affected (0.00 sec)

mysql> grant all privileges on zabbix.* to zabbix@'localhost' identified by 'zabbix';
Query OK, 0 rows affected (0.03 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
| zabbix |
+--------------------+
5 rows in set (0.00 sec)

如果登录数据库出现问题:

[root@zabbix ~]# mysql
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
解决办法:

[root@zabbix ~]# ln -s /tmp/mysql.sock /var/lib/mysql/

为数据库的root创建密码:

[root@zabbix zabbix-3.0.3]# mysqladmin -uroot password  "zabbix"

五、安装zabbix server:

安装zabbix:

下面链接为历史版本下载地址:
https://sourceforge.net/projects/zabbix/files/ZABBIX%20Latest%20Stable/
我们需要下载如下:
wget https://nchc.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/3.2.3/zabbix-3.2.3.tar.gz

[root@zabbix ~]# ls -l
-rw-r--r--   1 root root  15407273 5月  21 2016 zabbix-3.2.3.tar.gz
[root@zabbix ~]# tar zxf zabbix-3.2.3.tar.gz && cd zabbix-3.2.3

编译zabbix:
./configure --prefix=/usr/local/zabbix-3.2.3/ --enable-server --enable-agent --with-mysql --with-net-snmp --with-libcurl --with-libxml2

make && make install

编译过程中如果有报错:

故障:
checking for mysql_config... no
configure: error: MySQL library not found

解决:
yum install mysql-devel -y

故障:
checking for net-snmp-config... no
configure: error: Invalid Net-SNMP directory - unable to find net-snmp-config

解决:
yum install net-snmp-devel -y

创建zabbix用户:

[root@zabbix zabbix-3.2.3]# groupadd zabbix
[root@zabbix zabbix-3.2.3]# useradd zabbix -s /sbin/nologin -M -g

zabbix server需要导入3个sql文件:


[root@zabbix zabbix-3.0.3]# pwd
/root/zabbix-3.0.3

RDS、sql文件导入方法;首先要这台ECS可以访问到RDS。
[root@zabbix zabbix-3.0.3]# mysql -u<用户> -p<密码> <数据库名称> -h<连接地址> -P 3306 < database/mysql/schema.sql
[root@zabbix zabbix-3.0.3]# mysql -u<用户> -p<密码> <数据库名称> -h<连接地址> -P 3306 < database/mysql/images.sql
[root@zabbix zabbix-3.0.3]# mysql -u<用户> -p<密码> <数据库名称> -h<连接地址> -P 3306 < database/mysql/data.sql

本地sql导入方法:
[root@zabbix zabbix-3.0.3]# mysql -uroot -pzabbix zabbix < database/mysql/schema.sql 
[root@zabbix zabbix-3.0.3]# mysql -uroot -pzabbix zabbix < database/mysql/images.sql 
[root@zabbix zabbix-3.0.3]# mysql -uroot -pzabbix zabbix < database/mysql/data.sql 

六、zabbix管理网站配置(nginx):

创建项目目录:

[root@zabbix zabbix-3.2.3]# mkdir /data/web/zabbix.dtstack.com -p
[root@zabbix zabbix-3.2.3]# mkdir /data/logs/zabbix -p

将前端文件拷贝到项目目录下:

[root@zabbix zabbix-3.2.3]# cp -rp frontends/php/* /data/web/zabbix.dtstack.com/

编辑nginx虚拟主机:

[root@zabbix conf]# mkdir extra
[root@zabbix conf]# cd extra/
[root@zabbix extra]# vim zabbix.conf

server {
listen 8027;
server_name zabbix.dtstack.com;
access_log /data/logs/zabbix/zabbix.dtstack.com.access.log main;
index index.html index.php index.html;
root /data/web/zabbix.dtstack.com;

location /{
   try_files $uri $uri/ /index.php?$args;
}

location ~ ^(.+.php)(.*)$ {
   fastcgi_split_path_info ^(.+.php)(.*)$;
   include fastcgi.conf;
   fastcgi_pass 127.0.0.1:9000;
   fastcgi_index index.php;
   fastcgi_param PATH_INFO $fastcgi_path_info;
}

}

编辑nginx.conf配置文件:

[root@zabbix conf]# cat nginx.conf

user  nginx;
worker_processes  1;

#error_log  logs/error.log warning;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

pid        logs/nginx.pid;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;
    include extra/*.conf;

}

编辑zabbix_server.conf文件:

[root@zabbix etc]# pwd
  /usr/local/zabbix-3.0.2/etc

LogFile=/tmp/zabbix_server.log

PidFile=/tmp/zabbix_server.pid

DBHost=localhost

DBName=zabbix

DBUser=zabbix

DBPassword=zabbix

七、启动服务

启动nginx:

[root@zabbix conf]# /usr/local/nginx/sbin/nginx

启动PHP:

[root@zabbix conf]# /usr/local/php/sbin/php-fpm

启动zabbix server:

[root@zabbix conf]# /usr/local/zabbix-3.2.3/sbin/zabbix_server

如果启动的时候报错:
[root@zabbix ~]# /usr/local/zabbix-3.2.3/sbin/zabbix_server
/usr/local/zabbix-3.0.2/sbin/zabbix_server: error while loading shared libraries: libmysqlclient.so.18: cannot open shared object file: No such file or directory
[root@zabbix ~]# ln -s /usr/local/mysql/lib/libmysqlclient.so.18 /usr/lib64/

添加/etc/hosts文件:

192.168.119.140 zabbix.dtstack.com

查看服务端口:

[root@zabbix conf]# netstat -lntup
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name   
tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      1029/sshd           
tcp        0      0 0.0.0.0:8027                0.0.0.0:*                   LISTEN      3730/nginx          
tcp        0      0 0.0.0.0:10051               0.0.0.0:*                   LISTEN      3743/zabbix_server  
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      3736/php-fpm        
tcp        0      0 0.0.0.0:3306                0.0.0.0:*                   LISTEN      24922/mysqld        
tcp        0      0 :::22                       :::*                        LISTEN      1029/sshd           
udp        0      0 0.0.0.0:68                  0.0.0.0:*                               880/dhclient

将服务加入开机自启动:

[root@zabbix ~]# echo "/usr/local/nginx/sbin/nginx" >>/etc/rc.local 
[root@zabbix ~]# echo "/usr/local/php/sbin/php-fpm" >>/etc/rc.local 
[root@zabbix ~]# echo "/etc/init.d/mysqld start" >>/etc/rc.local
[root@zabbix ~]# echo "/usr/local/zabbix-3.0.3/sbin/zabbix_server" >>/etc/rc.local
[root@zabbix ~]# chmod +x /etc/rc.d/rc.local
[root@zabbix ~]# chmod +x rc.d/rc.local

八、web端配置zabbix

接下来的步骤是引导安装,我就已经文字描述
引导安装第一步:直接选择下一步就好了
引导安装第二步:检查PHP安装是否OK
引导安装第三步:选择数据库;如果是选择自建MySQL就输入自己创建的;如果是RDS,输入RDS(MySQL)地址、端口、数据库名、用户名,密码
引导安装第四步:这里保持默认即可
引导安装第五步:确认上面填写的信息是否OK
引导安装第六步:Install,<红色的框框,提示Unable to create the configuration file>,需要下载一个文件<zabbix.conf.php>,并上传到指定的服务器目录中
本文下载完成后上传到安装zabbix服务器/data/web/zabbix.dtstack.com/conf    chow -R 1000.1000 zabbix.conf.php
上传完成后。再在引导页面点击一下Finish,提示Congratulations! Yon have successfully installed Zabbix frontend;表示安装成功

以上完成后就登录了,默认用户密码、admin:zabbix

九、踩过的坑。


1、zabbix_server需要导入3个sql文件

    这三个文件,tar.gz的包里一般都有,默认都在zabbix-3.2.3/database/mysql/‘*.sql’

2、如果你是第一次安装是使用的是本地MySQL,想迁移数据库:
    需要把本地的MySQL的数据导出来(schema.sql、images.sql、data.sql),导入到RDS数据库中;当然,如果什么数据也没有就导入初始化的数据好了
    阿里云RDS的白名单需要设置ECS可以访问数据(读写权限);
    修改ZABBIX和PHP前端数据库地址和密码相关,如以下:
        PHP:
        /data/web/zabbix.dtstack.com/conf/zabbix.conf.php
        ZABBIX:
        /usr/local/zabbix-3.2.3/etc/zabbix_server.conf
相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
目录
相关文章
|
19天前
|
弹性计算 监控 负载均衡
|
13天前
|
弹性计算 开发工具 git
2分钟在阿里云ECS控制台部署个人应用(图文示例)
作为一名程序员,我在部署托管于Github/Gitee的代码到阿里云ECS服务器时,经常遇到繁琐的手动配置问题。近期,阿里云ECS控制台推出了一键构建部署功能,简化了这一过程,支持Gitee和GitHub仓库,自动处理git、docker等安装配置,无需手动登录服务器执行命令,大大提升了部署效率。本文将详细介绍该功能的使用方法和适用场景。
2分钟在阿里云ECS控制台部署个人应用(图文示例)
|
6天前
|
人工智能 弹性计算 编解码
阿里云GPU云服务器性能、应用场景及收费标准和活动价格参考
GPU云服务器作为阿里云提供的一种高性能计算服务,通过结合GPU与CPU的计算能力,为用户在人工智能、高性能计算等领域提供了强大的支持。其具备覆盖范围广、超强计算能力、网络性能出色等优势,且计费方式灵活多样,能够满足不同用户的需求。目前用户购买阿里云gpu云服务器gn5 规格族(P100-16G)、gn6i 规格族(T4-16G)、gn6v 规格族(V100-16G)有优惠,本文为大家详细介绍阿里云gpu云服务器的相关性能及收费标准与最新活动价格情况,以供参考和选择。
|
11天前
|
机器学习/深度学习 人工智能 弹性计算
什么是阿里云GPU云服务器?GPU服务器优势、使用和租赁费用整理
阿里云GPU云服务器提供强大的GPU算力,适用于深度学习、科学计算、图形可视化和视频处理等多种场景。作为亚太领先的云服务提供商,阿里云的GPU云服务器具备灵活的资源配置、高安全性和易用性,支持多种计费模式,帮助企业高效应对计算密集型任务。
|
13天前
|
存储 分布式计算 固态存储
阿里云2核16G、4核32G、8核64G配置云服务器租用收费标准与活动价格参考
2核16G、8核64G、4核32G配置的云服务器处理器与内存比为1:8,这种配比的云服务器一般适用于数据分析与挖掘,Hadoop、Spark集群和数据库,缓存等内存密集型场景,因此,多为企业级用户选择。目前2核16G配置按量收费最低收费标准为0.54元/小时,按月租用标准收费标准为260.44元/1个月。4核32G配置的阿里云服务器按量收费标准最低为1.08元/小时,按月租用标准收费标准为520.88元/1个月。8核64G配置的阿里云服务器按量收费标准最低为2.17元/小时,按月租用标准收费标准为1041.77元/1个月。本文介绍这些配置的最新租用收费标准与活动价格情况,以供参考。
|
11天前
|
机器学习/深度学习 人工智能 弹性计算
阿里云GPU服务器全解析_GPU价格收费标准_GPU优势和使用说明
阿里云GPU云服务器提供强大的GPU算力,适用于深度学习、科学计算、图形可视化和视频处理等场景。作为亚太领先的云服务商,阿里云GPU云服务器具备高灵活性、易用性、容灾备份、安全性和成本效益,支持多种实例规格,满足不同业务需求。
|
19天前
|
弹性计算
阿里云2核16G服务器多少钱一年?亲测价格查询1个月和1小时收费标准
阿里云2核16G服务器提供多种ECS实例规格,内存型r8i实例1年6折优惠价为1901元,按月收费334.19元,按小时收费0.696221元。更多规格及详细报价请访问阿里云ECS页面。
56 9
|
16天前
|
监控 Ubuntu Linux
使用VSCode通过SSH远程登录阿里云Linux服务器异常崩溃
通过 VSCode 的 Remote - SSH 插件远程连接阿里云 Ubuntu 22 服务器时,会因高 CPU 使用率导致连接断开。经排查发现,VSCode 连接根目录 ".." 时会频繁调用"rg"(ripgrep)进行文件搜索,导致 CPU 负载过高。解决方法是将连接目录改为"root"(或其他具体的路径),避免不必要的文件检索,从而恢复正常连接。
|
22天前
|
监控 数据可视化 BI
服务器监控软件Zabbix
【10月更文挑战第19天】
35 6
|
19天前
|
弹性计算 异构计算
2024年阿里云GPU服务器多少钱1小时?亲测价格查询方法
2024年阿里云GPU服务器每小时收费因实例规格不同而异。可通过阿里云GPU服务器页面选择“按量付费”查看具体价格。例如,NVIDIA A100的gn7e实例为34.742元/小时,NVIDIA A10的gn7i实例为12.710156元/小时。更多详情请访问阿里云官网。
64 2

推荐镜像

更多