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!
推薦閱讀:
- zabbix 代理服務器的部署與 zabbix-snmp 監控問題
- 構建雙vip的高可用MySQL集群
- zabbix-agent在麒麟V10上的安裝過程
- 搭建zabbix監控以及郵件報警的超級詳細教學
- 關於Zabbix忘記admin登錄密碼重置密碼的問題