1. 下載載MySQL鏡像mysql:5.7。在docker hub上有如下版本java
docker pull mysql:5.7
docker image ls
2. 下載zabbix-server鏡像,zabbix-server鏡像分兩種,支持MySQL數據庫zabbix-server-mysql,支持支持PostgreSQL數據庫zabbix/zabbix-server-pgsql。下面安裝的是支持MySQL數據庫的Server鏡像。node
打開zabbix-server-mysql的docker hub,你們會發現,zabbix-server-mysql有下面這些版本mysql
Zabbix server 3.0 (tags: alpine-3.0-latest, ubuntu-3.0-latest, centos-3.0-latest) Zabbix server 3.0.* (tags: alpine-3.0.*, ubuntu-3.0.*, centos-3.0.*) Zabbix server 3.2 (tags: alpine-3.2-latest, ubuntu-3.2-latest, centos-3.2-latest) Zabbix server 3.2.* (tags: alpine-3.2.*, ubuntu-3.2.*, centos-3.2.*) Zabbix server 3.4 (tags: alpine-3.4-latest, ubuntu-3.4-latest, centos-3.4-latest, alpine-latest, ubuntu-latest, centos-latest, latest) Zabbix server 3.4.* (tags: alpine-3.4.*, ubuntu-3.4.*, centos-3.4.*) Zabbix server 4.0 (tags: alpine-trunk, ubuntu-trunk)
由於個人服務器是centos7版本,因此選擇的是centos-latest版本。還有後面若是想本身重作鏡像的話,選擇centos版本,用着會更簡單一點。在linux終端使用linux
docker pull zabbix/zabbix-server-mysql:centos-latest
下載zabbix-server的鏡像。再經過nginx
docker image ls
查看下載的鏡像。以下圖:web
3. 下載Zabbix web鏡像,這裏使用的是基於Nginx web服務器及支持MySQL數據庫的Zabbix web接口zabbix/zabbix-web-nginx-mysql。這裏是用的是latest版本,在linux終端使用sql
docker pull zabbix/zabbix-web-nginx-mysql:latest
下載web鏡像。再經過 docker
docker image ls
查看下載的鏡像。以下圖: 數據庫
4. 下載zabbix-java-gateway鏡像, Zabbix自己不支持直接監控Java,而是使用zabbix-java-gateway監控jvm/tomcat性能。這裏咱們使用latest版本,在linux終端使用ubuntu
docker pull zabbix/zabbix-java-gateway:latest
下載zabbix-java-gateway鏡像。再經過
docker image ls
查看下載的鏡像。以下圖:
1. 啓動zabbix等鏡像以前,須要先建立一個新的 Docker 網絡。須要將後面的zabbix-server、mysql、web等容器都加入到此網絡中,方便互相訪問。在終端使用下面命令建立。
docker network create -d bridge zabbix_net
建立後,能夠查看是否建立成功。
docker network ls
2. 運行mysql 鏡像,建立mysql容器。
docker run -dit -p 3306:3306 --name zabbix-mysql --network zabbix_net --restart always -v /etc/localtime:/etc/localtime -e MYSQL_DATABASE="zabbix" -e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="zabbix_pwd" -e MYSQL_ROOT_PASSWORD="root_pwd" mysql:5.7
其中-p 是將容器中的3306端口映射到服務器的3306端口,
--network zabbix_net是將容器加入到zabbix_net網絡中,
-v /etc/localtime:/etc/localtime是同步服務器和容器內部的時區,
--restart always設置自啓動,
-e MYSQL_DATABASE="zabbix",建立環境變量。
--name zabbix-mysql,給容器命名。
3. 運行zabbix-java-gateway鏡像,建立zabbix-java-gateway容器。
docker run -v /etc/localtime:/etc/localtime -dit --restart=always --name=zabbix-java-gateway --network zabbix_net zabbix/zabbix-java-gateway:latest
4. 運行zabbix-server-mysql鏡像,建立zabbix-server-mysql容器。
首先建立數據卷zabbix-server-vol,經過命令
docker volume create zabbix-server-vol
啓動zabbix-server-mysql容器。
docker run -dit -p 10051:10051 --mount source=zabbix-server-vol,target=/etc/zabbix -v /etc/localtime:/etc/localtime -v /usr/lib/zabbix/alertscripts:/usr/lib/zabbix/alertscripts --name=zabbix-server-mysql --restart=always --network zabbix_net -e DB_SERVER_HOST="zabbix-mysql" -e MYSQL_DATABASE="zabbix" -e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="zabbix_pwd" -e MYSQL_ROOT_PASSWORD="root_pwd" -e ZBX_JAVAGATEWAY="zabbix-java-gateway" zabbix/zabbix-server-mysql:centos-latest
5. 運行zabbix-web-nginx-mysql鏡像,建立zabbix-web-nginx-mysql容器。
docker run -dit -p 80:80 -v /etc/localtime:/etc/localtime --name zabbix-web-nginx-mysql --restart=always --network zabbix_net -e DB_SERVER_HOST="zabbix-mysql" -e MYSQL_DATABASE="zabbix" -e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="zabbix_pwd" -e MYSQL_ROOT_PASSWORD="root_pwd" -e ZBX_SERVER_HOST="zabbix-server-mysql" zabbix/zabbix-web-nginx-mysql:latest
zabbix所需容器已經所有啓動,能夠通docker ps 查看容器狀態,以下圖:
6. 在瀏覽器中輸入http://IP/zabbix,打開zabbix首頁,其中用戶名密碼分別是admin/zabbix。
出現下面頁面,zabbix搭建成功。是否是比本身建立數據庫,搭建zabbix-server簡單不少。