自我介绍:广州测试小哥哥一枚 28岁 社区潜水已半年
发帖原因:期待大家一起来玩docker,快速搭建环境,发掘docker的无限可能~
大神语录:Docker 只是一种非常实用的工具,不要以 Docker 为目的去学习 Docker,重要的不是 Docker 而是您用 Docker 做什么。
愿景:技术交流,无分对错~欢迎大家指正
特别鸣谢: @ycwdaaaa @hogwarts
先上成果图:
docker 搭建 Zabbix
docker 搭建 Grafana 采用Zabbix 数据源
一、我的准备工作
1.购买阿里云服务器,我的是666 一年 (购买之后第三天被告知有拼团活动333 3年)
我的配置如下:
2.学习docker的基本原理和操作命令
推荐观看https://testerhome.com/topics/3387 三十分钟 Docker 新手入门
以下是我三天两夜里面不断重复使用的命令,供大家参考:
容器管理命令
- 1. docker run --name={your_name} --d {image_name} (运行容器)
- 2. docker ps -s -a {查看当前所有容器}
- 3. docker stop {container_name} (停止容器)
- 4. docker kill (container_name) {杀死容器}
- 5. docker rm -f {container_name} (删除容器)
查新信息相关命令
- 1. docker logs -f {容器名称} (查看容器日志)
- 2. docker info (查看docker服务的信息)
- 3. docker inspect {容器名称} (查看容器的元数据)
容器运行命令的一些参数
- 1. --name 指定容器名称
- 2. -d 后台运行
- 3. -port 指定端口映射规则
- 4. --network 指定容器运行的网路模式
- 5. -v 指定需要挂载的数据卷
- 6. -env 指定需要传递给容器的环境变量
理解docker的四种网络模式:
- Container
- briage
- Host
- none
3.docker hub 选购镜像
过程像海淘,里面全部介绍都是英文
我选的是下面这2个
镜像名 = 商品名
星数 = 类似好评数
pull = 拉取数 类似于购买数目
点开detail 会有这个镜像的介绍
二、搭建分析
1.搭建前你需要清楚的地方:
[1]启动容器数量
[2]容器间的依赖关系
[3]搭建系统组件容器间的通讯方式
2.举个栗子: 以我的实践(Zabbix + Grafana)为例
[1] 启动容器的数量 3个
从上到下,第一个容器 是grafana 、第二个是zabbix-xxl、第三个是zabbix-db-mariadb 的数据库
[2]容器间的依赖关系
grafana 依赖 zabbix-xxl 提供数据源,两个容器之间需要互相通信
zabbix-xxl 依赖 zabbix-db-mariadb提供数据库支持
[3]搭建系统组件容器间的通讯方式
grafana 依赖 zabbix-xxl 提供数据源 -------->因此我在启动grafana容器的时候使用container 模式,容器指向zabbix
执行语句:
docker run -d --name grafana -itd --net=container:zabbix grafana/grafana
zabbix-xxl 依赖 zabbix-db-mariadb提供数据库支持------------->因此zabbix-db-mariadb容器需要在zabbix启动前启动,
然后通过--link zabbix-db:zabbix.db参数连接
参考https://hub.docker.com/r/monitoringartist/zabbix-xxl/ 启动命令
[4]暴露的端口
启动zabbix-xxl 镜像容器的时候需要注意暴露端口的问题,原因是组件grafana容器会以container 模式连接到zabbix-xxl所在容器。
所以在启动zabbix-xxl 镜像容器时需要预先暴露grafana的端口3000,否则将无法对zabbix-xxl容器内的grafana进行访问。
- -p 80:80 \ zabbix 的端口映射
- -p 10051:10051 \ zabbix agent的端口映射
- -p 3000:3000 预留给grafana的端口映射
三、我的启动命令
多数摘取自https://hub.docker.com/r/monitoringartist/zabbix-xxl/docker,我还是建议大家看 hub 文档启动容器服务。
下面是我启动用到的命令,仅供参考:
create /var/lib/mysql as persistent volume storage 创建本地持久化储存盘
docker run -d -v /var/lib/mysql --name zabbix-db-storage busybox:latest
start DB for Zabbix - default 1GB innodb_buffer_pool_size is used 启动Zabbix-db 数据库
docker run \
-d \
--name zabbix-db \
-v /backups:/backups \
-v /etc/localtime:/etc/localtime:ro \
--volumes-from zabbix-db-storage \
--env="MARIADB_USER=zabbix" \
--env="MARIADB_PASS=my_password" \
monitoringartist/zabbix-db-mariadb
start Zabbix linked to started DB 启动Zabbix 且连接数据库 且添加端口3000的映射
docker run \
-d \
--name zabbix \
-p 80:80 \
-p 10051:10051 \
-p 3000:3000\
-v /etc/localtime:/etc/localtime:ro \
--link zabbix-db:zabbix.db \
--env="ZS_DBHost=zabbix.db" \
--env="ZS_DBUser=zabbix" \
--env="ZS_DBPassword=my_password" \
monitoringartist/zabbix-xxl:latest
以container 模式启动grafana , 容器指向 zabbix
docker run -d --name grafana -itd --net=container:zabbix grafana/grafana
四、收获Zabbix+Grafana环境搭建的果实,在Web界面下尽情学习和玩耍。
在Grafana 使用时可能会遇到的问题:
1.如何安装zabbix 插件
2.如何配置zabbix 数据源
3.如何在zabbix容器内查找连接使用api接口(api_jsonrpc.php)
这几个问题就留给小伙伴们自己探讨啦,百度一下基本都能够找到答案的~