同一个docker镜像,如何拉起多个docker container?
2017-05-16 22:36
453 查看
环境: centos7,zabbix3.0
关键步骤:
1. 安装dockeryum install epel-release
yum install docker
2. 安装docker-compose
sudo yum install -y python-pip
sudo pip install docker-compose
3. 拉取docker镜像
docker pull million12/zabbix-agent
注:docker镜像来自 https://hub.docker.com/r/million12/zabbix-agent/
4. 关键配置文件
2个关键配置文件,一个是zabbix_agentd.conf文件(参考:https://hub.docker.com/r/million12/zabbix-agent/),一个是docker-compose.yml
业务配置文件:
LogFile=/tmp/zabbix_agentd.log Server=10.1.1.1 ListenPort=10050 ServerActive=10.1.1.1:10051 AllowRoot=1
docker-compose配置文件:
1个container时:
version: '1' services: zabbix-agent000: image: million12/zabbix-agent container_name: zabbix-agent restart: always network_mode: "bridge" ports: - "8000:10050" volumes: - ./zabbix-agentd.conf:/etc/zabbix-agent/zabbix_agentd.conf - /proc:/data/proc - /sys:/data/sys - /dev:/data/dev - /var/run/docker.sock:/var/run/docker.sock environment: - ZABBIX_SERVER=10.1.1.1 - CONFIG_FILE=/etc/zabbix-agent/zabbix_agentd.conf - HOST_METADATA=vir_sysquery - HOSTNAME=vir
2个container时:
version: '1' services: zabbix-agent000: image: million12/zabbix-agent container_name: zabbix-agent000 restart: always network_mode: "bridge" ports: - "8000:10050" volumes: - ./zabbix-agentd.conf:/etc/zabbix-agent/zabbix_agentd.conf:ro - /proc:/data/proc - /sys:/data/sys - /dev:/data/dev - /var/run/docker.sock:/var/run/docker.sock environment: - ZABBIX_SERVER=10.1.1.1 - CONFIG_FILE=/etc/zabbix-agent/zabbix_agentd.conf - HOST_METADATA=vir000_sysquery - HOSTNAME=vir000 zabbix-agent001: image: million12/zabbix-agent container_name: zabbix-agent001 restart: always network_mode: "bridge" ports: - "8001:10050" volumes: - ./zabbix-agentd.conf:/etc/zabbix-agent/zabbix_agentd.conf:ro - /proc:/data/proc - /sys:/data/sys - /dev:/data/dev - /var/run/docker.sock:/var/run/docker.sock environment: - ZABBIX_SERVER=10.1.1.1 - CONFIG_FILE=/etc/zabbix-agent/zabbix_agentd.conf - HOST_METADATA=vir001_sysquery - HOSTNAME=vir001
5. 执行命令
在docker-compose.yml 文件所在的目录执行
docker-compose up -d
如果要查看启动详情,使用 docker-compose up 命令
至此,在docker所在的服务器应该能够看到有2个docker镜像启动。zabbix_server上也能看到有2个zabix_agent连接成功
FAQ:
问题:
起大批量的docker时,可能会出现以下问题:
ERROR: for zabbix-agent00103 UnixHTTPConnectionPool(host=’localhost’, port=None): Read timed out. (read timeout=60)
解决方法:
在起docker镜像的服务器上执行:
export COMPOSE_HTTP_TIMEOUT=3600
参考:
https://blog.smoker.cc/docker/zabbix-in-docker.html
https://hub.docker.com/r/million12/zabbix-agent/
相关文章推荐
- 如何避免Docker容器启动脚本运行后自动退出——一个cron定时任务docker镜像方案
- 如何将一个 镜像 pull到docker服务器上,并且实现该image 处于 up状态?
- 如何push一个docker镜像到DockerHub上
- 如何push一个docker镜像到DockerHub上
- 如何创建一个 Docker 镜像
- 如何创建一个安全的Docker基础镜像
- 如何创建一个 Docker 镜像
- 详解如何使用Docker部署一个web项目并打包成镜像文件
- 如何创建一个安全的Docker基础镜像
- 转:如何制作一个定制的 PHP 基础 Docker 镜像(一)
- 如何将一个docker镜像push到docker hub
- 如何使用Docker部署一个web项目并打包成镜像文件
- 如何创建一个安全的Docker基础镜像
- 详解Docker如何启动一个Centos镜像
- Docker学习笔记(3)-- 如何使用Dockerfile构建镜像
- 如何在 Docker 容器中架设一个完整的 WordPress 站点
- 如何使用 Docker 部署一个基于 Play Framework 的 Scala Web 应用?
- 如何制作高质量的docker镜像
- docker 实战---安装一个基础镜像 (一)
- docker学习笔记2—创建一个nginx的镜像,并使用浏览器访问