阿里云服务器及数据库RDS 部署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?uri/ /index.php?</span><span class="katex-html"><span class="base"><span class="strut" style="height: 1em; vertical-align: -0.25em;"></span><span class="mord mathdefault">u</span><span class="mord mathdefault" style="margin-right: 0.02778em;">r</span><span class="mord mathdefault">i</span><span class="mord">/</span><span class="mord">/</span><span class="mord mathdefault">i</span><span class="mord mathdefault">n</span><span class="mord mathdefault">d</span><span class="mord mathdefault">e</span><span class="mord mathdefault">x</span><span class="mord">.</span><span class="mord mathdefault">p</span><span class="mord mathdefault">h</span><span class="mord mathdefault">p</span><span class="mclose">?</span></span></span></span></span>args;<br> }</p>

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;

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

}
编辑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’
  • 1

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

阿里云服务器安装zabbix v3.2.3的步骤相关推荐

  1. access2003安装包百度云_阿里云服务器安装JDK与配置环境详细步骤

    一.根据自己需求购买阿里云服务器 第一步:购买链接:阿里云-上云就上阿里云 第二步:设置自己服务器的登录密码 二.下载服务器操作系统版本的JDK 这里我以Linu系统JDK1.8.0版本来示范,官网下 ...

  2. 阿里云服务器安装python3.7.3,解决openssl问题

    阿里云服务器安装python3.7.3,解决openssl问题 参考文章: (1)阿里云服务器安装python3.7.3,解决openssl问题 (2)https://www.cnblogs.com/ ...

  3. 阿里云服务器安装docker开发环境

    前段时间在阿里云上买了个服务器,打算部署一下开发环境,想了一下就使用最近一年念念不忘的docker来部署吧!他的好处就去看看官方文档吧,这边在部署使用之后会总结到该导航文章中,这篇导航文章会随时更新, ...

  4. 阿里云服务器安装并配置nginx代理转发请求

    阿里云服务器安装并配置nginx代理转发请求 下载nginx安装包,或者上传nginx安装包,此处我用的是Xmanager工具从本地上传了一个nginx安装包. 安装依赖库 yum -y instal ...

  5. 阿里云服务器安装oracle11g——会用的到,建议收藏

    阿里云服务器安装oracle11g 一. 安装docker 二 . 开始拉取镜像 2.1.创建docker容器 2.2 启动容器 2.3 进入镜像进行配置 三. 环境配置 四. 数据库连接 4.1 使 ...

  6. 阿里云服务器安装WordPress,搭建自己的博客网站

    阿里云服务器安装WordPress,搭建自己的博客网站 很多人都想搭建自己的博客网站,如今要实现自己的博客网站已经很简单了.这几天我就尝试了一下,随便记录下来,方便后人. 一个自己的博客网站至少需要这 ...

  7. 阿里云服务器安装mysql数据库教程

    阿里云服务器怎么安装mysql数据库?阿里云服务器ECS如何安装mysql数据库教程.主机教程网下面就来分享一下阿里云服务器安装mysql数据库教程. 第一步 1.登录个人的阿里云服务管理终端 2.点 ...

  8. 使用阿里云服务器安装宝塔面板搭建网站教程(图文全流程)

    阿里云服务器安装宝塔面板教程,云服务器吧以阿里云Linux系统云服务器安装宝塔Linux面板为例,先配置云服务器安全组开放宝塔所需端口8888.888.80.443.20和21端口,然后执行安装宝塔面 ...

  9. 阿里云服务器安装emqx和thingsboard

    <笔记> 阿里云服务器安装emqx和thingsboard 前言 最近把云服务器重装了系统,需要将以前的服务重新部署到新的服务器上. 服务器版本:CentOS 7.8 64位,为了以后的方 ...

最新文章

  1. java for 跳过_在for循环中跳过错误
  2. 在Ubuntu 16.04.5 LTS上利用python 2.7中的PIL模块智能等比例压缩过大的图片集实操
  3. c语言如何输出整串链表,大神帮我看一下怎么输入输出一个链表,我输入了但是没输出啊...
  4. 超越ResNet:南开提出Res2Net,不增计算负载,性能全面升级!
  5. mysql原生查询单条数据_原生查询数据库流程
  6. 【C++20】vs2019使用modules的实际操作
  7. 计算机网络之网络概述:1、基本概念
  8. 编译安装Mysql5.6.36
  9. CentOS8.1 搭建jenkins
  10. 怎么一秒钟给微信头像戴上圣诞帽,我教你啊
  11. 【从0开始机器学习】神经网络识别手写字符!
  12. 暴风影音3 Build version : 3.7.11.13 漏洞
  13. leetcode中文版python,Python 版 LeetCode 刷题笔记 #7 整数反转
  14. 在jsp代码添加背景图片
  15. LOAP引擎:clickhouse03:文件的导入导出方式
  16. 笔记本电脑插耳机后耳机无声音有外放情况,咋办??
  17. oracle recover database,【Oracle】探究recover database until scn
  18. linux安装启动openoffice和swftools
  19. ES 查询 —— match 和 match_prase
  20. 第四章:迭代器与生成器

热门文章

  1. 利用支持向量机进行癌症分类的基因选择
  2. Tigo推出具有增强光伏系统监控、设计布局和警报管理功能的下一代SMART网站
  3. Which在定语从句中做什么成分
  4. 掌上灵通退市:一个时代的终结
  5. 解决wordpress上传文件大小限制
  6. Linux系统移植EC20模块的方法
  7. Function Reference/the post thumbnail
  8. ionic popover、popu、scroll
  9. 邯郸网络服务器机柜型号,珠海服务器机柜批发
  10. 冲击蓝桥杯-并查集,前缀和,字符串