docker (十一)-进阶篇-docker-compos最佳实践部署zabbix

这篇具有很好参考价值的文章主要介绍了docker (十一)-进阶篇-docker-compos最佳实践部署zabbix。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一 部署docker环境

关闭防火墙、selinux、开启docker,并设置开机自启动

注意点:docker部署的时候,bip要指定,不然会导致虚拟机ip和容器ip冲突,ssh连不上虚拟机

部署请参考   docker (二)-yum&二进制部署-CSDN博客

二 docker-compose的安装----github下载

curl -SL https://github.com/docker/compose/releases/download/v2.20.2/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
 
##测试
docker-compose version

三 编写docker-compose.yml文件 

##yml文件,缩进表示层级关系
 
 
##指定版本号
version: '3'
 
##配置服务
services:
##容器1
  zabbix-web-nginx-mysql:
##镜像:从中拉取镜像
    image: zabbix/zabbix-web-nginx-mysql:centos-5.2-latest
    restart: always
    environment:
      - DB_SERVER_HOST=zabbix-mysql
      - MYSQL_DATABASE=zabbix
      - MYSQL_USER=zabbix
      - MYSQL_PASSWORD=zabbix
      - MYSQL_ROOT_PASSWORD=123qwe
      - ZBX_SERVER_HOST=zabbix-server-mysql
    ports:
##端口映射 主机:容器
      - 8080:8080
    volumes:
      - /etc/localtime:/etc/localtime
      - /data2/zabbix/fonts/DejaVuSans.ttf:/usr/share/zabbix/assets/fonts/DejaVuSans.ttf
    networks:
      - zbx_net
    depends_on:
      - zabbix-server-mysql
      - zabbix-mysql
##容器2
  zabbix-mysql:
    image: mysql:8.0.23
    restart: always
    ports:
      - 3306:3306
    environment:
      - MYSQL_DATABASE=zabbix
      - MYSQL_USER=zabbix
      - MYSQL_PASSWORD=zabbix
      - MYSQL_ROOT_PASSWORD=123qwe
##容器启动的默认命令
    command:
      - mysqld
      - --default-authentication-plugin=mysql_native_password
      - --character-set-server=utf8
      - --collation-server=utf8_bin
    volumes:
##将容器中的数据或文件挂载到主机上,实现数据的持久化
      - /etc/localtime:/etc/localtime
      - /data2/zabbix/db:/var/lib/mysql
    networks:
      - zbx_net
##容器3
  zabbix-java-gateway:
    image: zabbix/zabbix-java-gateway:centos-5.2-latest
    restart: always
    volumes:
      - /etc/localtime:/etc/localtime
    networks:
      - zbx_net
##容器4
  zabbix-server-mysql:
    image: zabbix/zabbix-server-mysql:centos-5.2-latest
    restart: always
    volumes:
      -  /data/zabbix/zabbix-server:/etc/zabbix
      - /data2/zabbix/alertscripts:/usr/lib/zabbix/alertscripts
      - /etc/localtime:/etc/localtime
    ports:
      - 10052:10051
    environment:
      - DB_SERVER_HOST=zabbix-mysql
      - MYSQL_DATABASE=zabbix
      - MYSQL_USER=zabbix
      - MYSQL_PASSWORD=zabbix
      - MYSQL_ROOT_PASSWORD=123qwe
      - ZBX_JAVAGATEWAY=zabbix-java-gateway
      - ZBX_JAVAGATEWAY_ENABLE=true
      - ZBX_JAVAGATEWAYPORT=10052
    depends_on:
      - zabbix-mysql
    networks:
      - zbx_net
##容器5
  zabbix-agent:
    image: zabbix/zabbix-agent:centos-5.2-latest
    restart: always
    ports:
      - 10050:10050
    environment:
      - ZBX_HOSTNAME=Zabbix server
      - ZBX_SERVER_HOST=zabbix-server-mysql
      - ZBX_SERVER_PORT=10051
    networks:
      - zbx_net
 
##网络
networks:
##网络名
  zbx_net:
##指定驱动用于这个网络
    driver: bridge

创建相应映射目录
/data2/zabbix/zabbix-server                       用于存储 Zabbix 服务器容器的配置文件等相关数据
/data2/zabbix/alertscripts                           用于存储 Zabbix 服务器容器中的告警脚本
/data2/zabbix/fonts                                      用于存储 Zabbix Web 容器中的字体文件
/data2/zabbix/db                                          用于存储 MySQL 数据库容器的数据文件

中文简体文件添加
从主机(C:\Windows\Fonts)上传一个.ttf的字体文件到/data2/zabbix/fonts目录

可使用rz命令,或者ftp,或远程传输工具(如:xftp)

并将文件名称改成DejaVuSans.ttf(yml文件中有指明)

四 一键启动(注:在docker-compose.yml文件目录下启动)

 docker-compose up -d  # -d 后台运行

检验  在浏览器输入ip地址和映射的端口号(192.168.10.131:8080)即可到web界面,则安装完成 (Admin--zabbix)

五 出现报错

docker ps 看到 docker-zabbix-server-mysql-1 起来后就挂了,docker logs 查看日志发现

**** Configuration file '/etc/zabbix/zabbix_server.conf' does not exist
zabbix_server [7]: cannot open config file "/etc/zabbix/zabbix_server.conf": [2] No such file or directory

docker (十一)-进阶篇-docker-compos最佳实践部署zabbix,docker,java,容器

解决思路

  1. 确保主机上的 /data/zabbix/zabbix-server 目录中包含正确的 Zabbix Server 配置文件。

  2. 确保 Zabbix Server 容器具有正确的权限访问挂载的卷。你可以通过检查挂载点的权限来确保容器有权限访问挂载的卷。

  3. 如果配置文件位于主机上的其他位置,请确保在 docker-compose.yml 文件中正确指定了挂载的卷路径。

  4. 如果 Zabbix Server 镜像默认配置文件的路径不是 /etc/zabbix/zabbix_server.conf,你需要确保在容器内正确的路径上存在该配置文件,或者在容器启动时指定正确的配置文件路径

解决步骤 

1.将容器4中这行删掉,后直接docker-compose up -d

docker (十一)-进阶篇-docker-compos最佳实践部署zabbix,docker,java,容器

这样启动容器就没有报错,但是配置文件未持久化(若要持久化按以下步骤做) 

2.拷贝配置文件

mkdir -p /data/zabbix/zabbix-server
docker cp docker-zabbix-server-mysql-1:/etc/zabbix/zabbix_server.conf /data/zabbix/zabbix-server

3.再按照 三中的 docker-compose.yml 启动容器
启动后,没有报错

docker (十一)-进阶篇-docker-compos最佳实践部署zabbix,docker,java,容器

总结:使用volumes进行配置文件持久化,要保证宿主机的目录中包含对应的配置文件

六 docker-compose常用命令

以下是一些常用的 Docker Compose 相关命令:

1. docker-compose up

  • 启动 Docker Compose 定义的所有服务。
  • 如果需要构建镜像,它将会构建镜像。
  • 如果服务已经运行,则会尝试重新启动服务。

2. docker-compose down

  • 停止并删除所有 Docker Compose 定义的服务。
  • 如果指定 --volumes 参数,则还会删除相关的数据卷。

3. docker-compose build

  • 构建 Docker Compose 定义的所有服务的镜像。
  • 如果只需要构建特定服务的镜像,可以使用 docker-compose build <service_name>

4. docker-compose start

  • 启动 Docker Compose 定义的所有服务。
  • 如果服务已经启动,则不会执行任何操作。

5. docker-compose stop

  • 停止 Docker Compose 定义的所有服务。
  • 如果服务已经停止,则不会执行任何操作。

6. docker-compose restart

  • 重启 Docker Compose 定义的所有服务。
  • 如果服务未启动,则会启动服务。

7. docker-compose ps

  • 显示 Docker Compose 定义的所有服务的状态。
  • 包括服务名称、状态、端口映射等信息。

8. docker-compose logs文章来源地址https://www.toymoban.com/news/detail-833640.html

  • 显示 Docker Compose 定义的所有服务的日志输出。
  • 可以通过 -f 参数实时查看日志。

到了这里,关于docker (十一)-进阶篇-docker-compos最佳实践部署zabbix的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • smartdns 部署最佳实践

    软件下载: 操作系统 centos 7 smartdns 最新版: GitHub - pymumu/smartdns: A local DNS server to obtain the fastest website IP for the best Internet experience, 一个本地DNS服务器,获取最快的网站IP,获得最佳上网体验。 根据需要下载最新版的软件安装包 注意安装包的类型和操作系统的类型保持一致

    2024年02月08日
    浏览(26)
  • 【ASP.NET Core 基础知识】--最佳实践和进阶主题--微服务和容器化

    Tip:想要了解并学习微服务和容器化的知识,请跳转到《Docker极简教程》 一、微服务概述 1.1 什么是微服务? 微服务(Microservices)是一种软件架构风格,其中软件系统被划分为一组小型、自治的服务单元,这些服务单元围绕着业务能力进行组织,并通过轻量级的通信机制相

    2024年02月19日
    浏览(43)
  • Docker安全最佳实践

    目录 1、探测容器开放端口和服务漏洞 2、宿主机、网络、镜像、DockerApi安全 3、更新Docker、日志、事件 4、Docker安全测试 5、Docker安全最佳实践 使用Nmap扫描Docker容器中的开放端口 使用docker ps命令获取正在运行的容器ID或名称。 在主机上安装Nmap工具。 使用以下命令扫描Docker容

    2024年02月04日
    浏览(34)
  • 【实战】十一、看板页面及任务组页面开发(一) —— React17+React Hook+TS4 最佳实践,仿 Jira 企业级项目(二十三)

    学习内容来源:React + React Hook + TS 最佳实践-慕课网 相对原教程,我在学习开始时(2023.03)采用的是当前最新版本: 项 版本 react react-dom ^18.2.0 react-router react-router-dom ^6.11.2 antd ^4.24.8 @commitlint/cli @commitlint/config-conventional ^17.4.4 eslint-config-prettier ^8.6.0 husky ^8.0.3 lint-staged ^13.1.2 p

    2024年02月12日
    浏览(25)
  • 【实战】十一、看板页面及任务组页面开发(五) —— React17+React Hook+TS4 最佳实践,仿 Jira 企业级项目(二十七)

    学习内容来源:React + React Hook + TS 最佳实践-慕课网 相对原教程,我在学习开始时(2023.03)采用的是当前最新版本: 项 版本 react react-dom ^18.2.0 react-router react-router-dom ^6.11.2 antd ^4.24.8 @commitlint/cli @commitlint/config-conventional ^17.4.4 eslint-config-prettier ^8.6.0 husky ^8.0.3 lint-staged ^13.1.2 p

    2024年02月10日
    浏览(26)
  • 【实战】 七、Hook,路由,与 URL 状态管理(上) —— React17+React Hook+TS4 最佳实践,仿 Jira 企业级项目(十一)

    学习内容来源:React + React Hook + TS 最佳实践-慕课网 相对原教程,我在学习开始时(2023.03)采用的是当前最新版本: 项 版本 react react-dom ^18.2.0 react-router react-router-dom ^6.11.2 antd ^4.24.8 @commitlint/cli @commitlint/config-conventional ^17.4.4 eslint-config-prettier ^8.6.0 husky ^8.0.3 lint-staged ^13.1.2 p

    2024年02月15日
    浏览(29)
  • 【实战】十一、看板页面及任务组页面开发(四) —— React17+React Hook+TS4 最佳实践,仿 Jira 企业级项目(二十六)

    学习内容来源:React + React Hook + TS 最佳实践-慕课网 相对原教程,我在学习开始时(2023.03)采用的是当前最新版本: 项 版本 react react-dom ^18.2.0 react-router react-router-dom ^6.11.2 antd ^4.24.8 @commitlint/cli @commitlint/config-conventional ^17.4.4 eslint-config-prettier ^8.6.0 husky ^8.0.3 lint-staged ^13.1.2 p

    2024年02月11日
    浏览(35)
  • Docker与DockerCompose最佳实践

    在本文中,我们将探讨Docker和Docker Compose的最佳实践,涵盖了从基础概念到实际应用场景的全面讨论。我们将深入了解Docker和Docker Compose的核心概念、算法原理、具体操作步骤和数学模型公式,并提供详细的代码实例和解释。此外,我们还将讨论实际应用场景、工具和资源推荐

    2024年02月19日
    浏览(24)
  • Docker与Kubernetes:最佳实践和最佳组合(DockerandKubernetes:BestPra

    作者:禅与计算机程序设计艺术 Docker 和 Kubernetes 是当今最流行的容器编排工具,随着越来越多的企业采用容器技术,越来越多的人都在思考如何实现容器云平台的自动化、高可用、可扩展等架构设计。而本文将从这两个开源项目的角度出发,深入探讨两者的最佳实践和最佳

    2024年02月07日
    浏览(36)
  • 使用Redis实现双平面部署的最佳实践

    双平面部署是一种常见的系统架构模式,用于提高系统的可靠性和性能。在这种架构中,拥有相同功能的两个平面同时运行,其中一个平面作为主平面处理请求,而另一个平面则作为备份平面。在传统的双平面部署中,通常会使用数据库复制和负载均衡技术来实现高可用性,

    2024年02月16日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包