docker快速部署zabbix的方法

容器技術極大的簡化瞭應用部署速度,而且現在大部分的開源應用均提供瞭容器的版本。因此今天就分享下通過docker快速部署zabbix。zabbix標準組件是分佈式的,因此部署過程中需要創建多個容器,當然zabbix-application(all-in-one)也有容器版本,官方已經宣佈停止更新,推薦使用虛擬機的鏡像方式。

1、創建docker自定義網絡

docker需要使用容器的名稱互訪需要使用自定義的網絡類型,容器必須接入自定義的網絡方可。因為接下來我們要部署多個組件,組件之間互訪通過容器名稱。

docker network create --subnet 172.20.0.0/24 zabbix-net

2、部署數據庫

部署mariadb作為zabbix的數據庫,註意安全第一件數據庫的密碼要加固,不要太簡單。

docker run --name mysql-server  \
-e MYSQL_DATABASE=zabbix \
-e MYSQL_USER=zabbix \
-e MYSQL_PASSWORD="123456789"  \
-e TZ="Asia/Shanghai" \
-e MYSQL_ROOT_PASSWORD="123456789"  \
-v mariadb_data:/var/lib/mysql  \
--restart unless-stopped  \
--network=zabbix-net \
-itd mariadb  \
--character-set-server=utf8  \
--collation-server=utf8_bin  \
--default-authentication-plugin=mysql_native_password

TZ=“Asia/Shanghai” 為設置容器的時區,否則告警時間會有問題。
mariadb_data:/var/lib/mysql 將數據庫掛載到容器卷,這有容器銷毀後可以繼續掛這個卷,保持數據持不丟失。

3、啟動java api容器

docker run --name zabbix-java-gateway -t  --restart unless-stopped -d zabbix/zabbix-java-gateway

4、啟動zabbix-server

docker run --name zabbix-server-mysql -t  \
      -e DB_SERVER_HOST="mysql-server" \
      -e MYSQL_DATABASE="zabbix" \
      -e MYSQL_USER="zabbix" \
      --network=zabbix-net \
      -e TZ="Asia/Shanghai" \
      -e MYSQL_PASSWORD="123456789" \
      -e MYSQL_ROOT_PASSWORD="123456789" \
      -e ZBX_JAVAGATEWAY="zabbix-java-gateway" \
     -e  ZBX_CACHESIZE="1024M" \
     -e  ZBX_DEBUGLEVEL="3" \
     -e  ZBX_STARTDISCOVERERS='5' \
      -p 10051:10051 \
      --restart unless-stopped \
     -v zabbix_conf:/etc/zabbix/ \
      -d zabbix/zabbix-server-mysql

當監控主機過多的時候zabb進程容易掛死,需要在啟動容器的時候設置環境變量ZBX_CACHESIZE=“1024M” ,默認參數為8M。
ZBX_STARTDISCOVERERS=“5” 解決zabbix discover進程經常告警利用率過高;
需要監控VMware環境需在環境變量中加入下面參數。

  -e ZBX_VMWAREFREQUENCY="10" \
      -e ZBX_VMWAREPERFFREQUENCY="60" \
     -e ZBX_VMWARECACHESIZE="1024M" \
     -e ZBX_VMWARETIMEOUT="30" \

註意:zabbix-server的配置文件修改後會,容器重啟後會還原,因此需要在創建容器的時候設置環境變量對配置文件進行修改。

5、啟動zabbix前端web容器;

docker run --name zabbix-web-nginx-mysql -t \
      -e ZBX_SERVER_HOST="zabbix-server-mysql" \
      -e DB_SERVER_HOST="mysql-server" \
      -e MYSQL_DATABASE="zabbix" \
      -e MYSQL_USER="zabbix" \
      -e PHP_TZ="Asia/Shanghai"\
      -e MYSQL_PASSWORD="123456789" \
      -e MYSQL_ROOT_PASSWORD="123456789" \
      -p 8000:8080 \
     --network=zabbix-net \
      --restart unless-stopped \
      -d zabbix/zabbix-web-nginx-mysql

6、其他註意事項

a、zabbix郵件告警支持126郵箱和163郵箱,使用qq郵箱會失敗,原因不詳。
b、zabbix-agent部署分主動模式和被動模式,跟進新建主機選擇的模板覺得,模板有主動和被動。
c、啟動容器務必要設置時區;
d、數據庫數據要掛載到容器卷;

到此這篇關於docker快速部署zabbix的方法的文章就介紹到這瞭,更多相關docker部署zabbix內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: