zabbix v3.2.3安裝部署
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 https://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 https://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 https://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
最後更新:2017-06-06 10:01:35