docker快速部署zabbix的方法
容器技術極大的簡化了應用部署速度,而且現(xiàn)在大部分的開源應用均提供了容器的版本。因此今天就分享下通過docker快速部署zabbix。zabbix標準組件是分布式的,因此部署過程中需要創(chuàng)建多個容器,當然zabbix-application(all-in-one)也有容器版本,官方已經宣布停止更新,推薦使用虛擬機的鏡像方式。
1、創(chuàng)建docker自定義網(wǎng)絡
docker需要使用容器的名稱互訪需要使用自定義的網(wǎng)絡類型,容器必須接入自定義的網(wǎng)絡方可。因為接下來我們要部署多個組件,組件之間互訪通過容器名稱。
docker network create --subnet 172.20.0.0/24 zabbix-net
2、部署數(shù)據(jù)庫
部署mariadb作為zabbix的數(shù)據(jù)庫,注意安全第一件數(shù)據(jù)庫的密碼要加固,不要太簡單。
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” 為設置容器的時區(qū),否則告警時間會有問題。
mariadb_data:/var/lib/mysql 將數(shù)據(jù)庫掛載到容器卷,這有容器銷毀后可以繼續(xù)掛這個卷,保持數(shù)據(jù)持不丟失。
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當監(jiān)控主機過多的時候zabb進程容易掛死,需要在啟動容器的時候設置環(huán)境變量ZBX_CACHESIZE=“1024M” ,默認參數(shù)為8M。
ZBX_STARTDISCOVERERS=“5” 解決zabbix discover進程經常告警利用率過高;
需要監(jiān)控VMware環(huán)境需在環(huán)境變量中加入下面參數(shù)。
-e ZBX_VMWAREFREQUENCY="10" \
-e ZBX_VMWAREPERFFREQUENCY="60" \
-e ZBX_VMWARECACHESIZE="1024M" \
-e ZBX_VMWARETIMEOUT="30" \
注意:zabbix-server的配置文件修改后會,容器重啟后會還原,因此需要在創(chuàng)建容器的時候設置環(huán)境變量對配置文件進行修改。
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、啟動容器務必要設置時區(qū);
d、數(shù)據(jù)庫數(shù)據(jù)要掛載到容器卷;
到此這篇關于docker快速部署zabbix的方法的文章就介紹到這了,更多相關docker部署zabbix內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
docker network_mode: "host" 網(wǎng)絡配置方式
這篇文章主要介紹了docker network_mode: "host" 網(wǎng)絡配置方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05
docker容器數(shù)據(jù)卷之具名掛載和匿名掛載問題
容器數(shù)據(jù)卷就是目錄的掛載,將我們的容器的目錄掛載到宿主機上,從而實現(xiàn)打通宿主機和容器之間的文件共享功能,這篇文章主要介紹了docker容器數(shù)據(jù)卷 - 具名掛載和匿名掛載問題,需要的朋友可以參考下2021-11-11
docker根據(jù)已生成的容器生成docker-compose.yml文件的實現(xiàn)步驟
這篇文章主要給大家介紹了docker 如何根據(jù)已生成的容器生成docker-compose.yml 文件,文中有詳細的代碼示例和實現(xiàn)步驟,對大家的學習有一定的幫助,需要的朋友可以參考下2023-10-10

