docker快速搭建并使用Zabbix_docker zabbix,2024年最新携程Linux运维面试题

通过Docker部署:

# ZBX\_SERVER\_HOST更换为自己zabbix-server的所在地址
# 并且在zabbix的web页面中也需要填写agent的容器地址
docker run -d \
   --name zabbix-agent \
   -v /etc/zabbix \
   -v /var/log/zabbix:/var/log/zabbix \
   -e ZBX\_HOSTNAME="client-01" \
   -e ZBX\_SERVER\_HOST="10.253.50.145" \
   -e ZBX\_SERVER\_PORT=10051 \
   -p 10050:10050 \
   --restart=unless-stopped \
   --privileged \
   zabbix/zabbix-agent:alpine-6.2-latest

3.3 设置web为中文及bug处理
  1. 修改zabbix的web页面,设置页面显示为中文

User settings - Profile - Language - Chinese,最后点击下方的update

在这里插入图片描述
2. 修改zabbix的监控地址为agent地址

检测 - 主机 - 选择我们的zabbix-server - 鼠标单击然后选择配置

在这里插入图片描述
更换agent的地址为zabbix-server的地址

因为我们此刻是在zabbix-server的机器上安装了一台zabbix-agent,目的是为了检测我们zabbix-server所在机器的状态。

  • 如果大家将zabbix-agent安装在了其他机器上,更换为对应机器ip地址即可

在这里插入图片描述
3. 等待几分钟刷新页面即可

bug1:

如果发现可用性仍然没有变成绿色,并且页面报错
Asuming that agent dropped connect because of access permision,表明是我们没有开启对应的权限

  • 首先查看是否关闭了防火墙
    • 关闭防火墙命令:systemctl stop firewalld
  • 如果使用的是云服务器,查看云服务器的对应安全组策略是否开启
  • 权限不够:修改zabbix-agent的配置文件
    • vim /etc/zabbix/zabbix_agentd.conf
    • 找到Server位置,将其修改为自己server所在ip地址加网段,如:172.159.92.3/24;如果为了方便也可以将其修改为0.0.0.0/0(代表运行所有的服务器访问)
      在这里插入图片描述
      完成之后,:wq保存退出,systemctl restart zabbix-agent.service重启zabbix-agent,等待几分钟之后在刷新zabbix的web页面即可
  • 如果上述方法都不行,就对应查看日志报错信息,来对应处理:
    查看日志信息:tail -f /var/log/zabbix/zabbix_agentd.log
    • 报错信息:Unable to connect to [127.0.0.1]:10051 [cannot connect to [[127.0.0.1]:10051]: [111] Connection refused]
    • 表明是服务器地址配置错了,vim /etc/zabbix/zabbix_agentd.conf,将配置文件中的ServerActive更改为zabbix-server的地址,如:10.253.50.145,记住只需要修改ip,不用携带port端口
      在这里插入图片描述

bug2:

如果查询agent的日志文件发现报错信息:
23946:20230722:121107.962 no active checks on server [10.253.50.145:10051]: host [Zabbix server] not found

  • 查询日志文件命令:tail -f /var/log/zabbix/zabbix_agentd.log
  • 解决办法:修改agent配置文件中的Hostname,
    • 查看配置文件中的HostName:
      cat /etc/zabbix/zabbix_agentd.conf | grep Hostname
    • 在zabbix web页面Monitoring->Configuration->Hosts 页面更改Host name和zabbix_agentd.conf里面的Hostname一样。
      在这里插入图片描述
      在这里插入图片描述
  • 重启zabbix-agent
需求实战(HTTP代理+zabbix5)

客户需要监控我方服务的状态,因此我方只需要提供一个自定义模板即可(xml文件)+自定义告警模板即可

  • 方案实现:我方暴露一个API接口给Zabbix,通过HTTP代理的方式用于获取数据。【因此无需安装zabbix-agent】
①环境搭建:zabbix-server、web、mysql
  1. 安装并启动docker
yum install -y yum-utils
yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo
yum install docker
systemctl start docker

拉取mysql和zabbix的docker,因为zabbix 6以上,需要centos 8,受限于环境,这里演示zabbix 5版本的

  1. 拉取镜像并创建数据卷
# 拉取镜像
docker pull mysql:5.7
docker pull docker.io/zabbix/zabbix-web-nginx-mysql:centos-5.4-latest
docker pull docker.io/zabbix/zabbix-server-mysql:centos-5.4-latest
# 拉取完成后,开始安装
docker volume create -d local  mysql_data #存放mysql数据
docker volume create -d local  mysql_logs #存放mysql日志
docker volume create -d local  mysql_conf #存放mysql配置文件 

  1. 创建对应容器(mysql、zabbix-server、zabbix-web)
docker run --name mysql-server -t \
-v mysql_data:/var/lib/mysql \
-v mysql_logs:/var/log/mysql \
-v mysql_conf:/etc/mysql \
-e MYSQL\_DATABASE="zabbix" \
-e MYSQL\_USER="zabbix" \
-e MYSQL\_PASSWORD="123456" \
-e MYSQL\_ROOT\_PASSWORD="123456" \
--restart=unless-stopped \
-d mysql:5.7 \
--character-set-server=utf8 \
--collation-server=utf8_bin \
--default-authentication-plugin=mysql_native_password

docker volume create -d local  zabbix_server
docker run --name zabbix-server-mysql -t \
-v zabbix_server:/etc/zabbix \
-e DB\_SERVER\_HOST="mysql-server" \
-e MYSQL\_DATABASE="zabbix" \
-e MYSQL\_USER="zabbix" \
-e MYSQL\_PASSWORD="123456" \
-e MYSQL\_ROOT\_PASSWORD="123456" \
--link mysql-server:mysql \
--restart=unless-stopped \
-p 10051:10051 \
--hostname zabbix-server \
-d zabbix/zabbix-server-mysql:centos-5.4-latest

docker run --name zabbix-web-nginx-mysql -t \
-e PHP\_TZ="Asia/Shanghai" \
-e ZBX\_SERVER\_HOST="zabbix-server-mysql" \
-e DB\_SERVER\_HOST="mysql-server" \
-e MYSQL\_DATABASE="zabbix" \
-e MYSQL\_USER="zabbix" \
-e MYSQL\_PASSWORD="123456" \
-e MYSQL\_ROOT\_PASSWORD="123456" \
--link mysql-server:mysql \
--link zabbix-server-mysql:zabbix-server \
-p 80:8080 \
--restart unless-stopped \
--hostname zabbix-web \
-d zabbix/zabbix-web-nginx-mysql:centos-5.4-latest

  1. 创建好后,访问http://ip/zabbix。用Admin,zabbix即可登录。注意Admin是大写开头
    在这里插入图片描述
②创建自动发现、自定义模板
  1. 自动发现
    因为客户部署我方的机器过多,所以采用zabbix的自动发现来自动发现主机
  • 创建自动发现(填写对应ip范围及协议端口)
  • 配置关联动作(将发现的主机添加到主机组、并添加到我方提供给客户的自定义模板)
  1. 自定义模板(Template)
    我方提供给客户所需要的模板,用于监控指定服务的数据(调用我方提供的接口获取所需要监控的信息)
  • 自定义模板下创建监控项,如:我方接口返回多个Agent信息,那么就创建一个监控项,叫Agent Item
  • 在自定义模板Template下创建自动发现(HTTP代理)、监控项原型(agent的信息等,如:name、cpu useage)、触发器【根据自定义模板下的HTTP代理请求回来的数据,自动创建多个Agent,每个Agent包含对应监控项原型:name、cpu useage等】,当采集到的数据不合理时,则触发对应的触发器
完整步骤
1. 配置-模板-创建模板

在这里插入图片描述

2. 将模板加入templates组,配置模板宏(方便后续自动发现时,http代理使用)

在这里插入图片描述

3. 在我们新创建好的模板Ziyi Template下创建自动发现规则

在这里插入图片描述
在这里插入图片描述
在自动发现规则这里我们引用开始创建好的宏:
在这里插入图片描述
根据自己接口返回数据的格式,判断是否需要预处理:
在这里插入图片描述

比如我接口返回的是

{
	"code":1,
	"msg":"success",
	"content":[
		{
			"id":1,
			"name":"jack"
		},
		{
			"id":2,
			"name":"tom"
		}
	]
}

//那么我通过$.content预处理之后就可以获取到:
[
    [
        {
            "id": 1,
            "name": "jack"
        },
        {
            "id": 2,
            "name": "tom"
        }
    ]
]
//不过zabbix自带一层for处理,因此我们可以通过$.content.name直接遍历出每个name

在这里插入图片描述

4. 创建监控项

在这里插入图片描述
根据http代理获取对应监控项的值:
在这里插入图片描述

5. 创建自动发现的监控项原型

自动发现-创建监控项原型

  • 配置-模板-自动发现
    在这里插入图片描述

点击创建监控项原型(配合自动发现规则的宏使用可自动动态创建出监控的数据项):
在这里插入图片描述
在这里插入图片描述
修正:上面的键值应满足对应规则,样例:

键值(合法):ziyi.content.[{#USER_NAME}]

主要项选择我们第4步创建好的监控项User

6. 配置监控项原型的预处理

通过配置预处理步骤,来判断什么时候去获取值

在这里插入图片描述
tip:jsonpath用法:
在这里插入图片描述
jsonPath样例:https://www.cnblogs.com/lxmtx/p/12916659.html

7. 添加主机并应用我们的模板

监测 - 主机 - 创建主机
在这里插入图片描述

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Linux运维工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Linux运维知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip1024b (备注Linux运维获取)
img

最后的话

最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!

资料预览

给大家整理的视频资料:

给大家整理的电子书资料:

如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

mg-s4M1vZ1O-1712656903751)]

最后的话

最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!

资料预览

给大家整理的视频资料:

[外链图片转存中…(img-22d9mDXa-1712656903751)]

给大家整理的电子书资料:

[外链图片转存中…(img-J1j46RgQ-1712656903752)]

如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-Auc54kQR-1712656903752)]

  • 22
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以按照以下步骤搭建一个基于docker-compose的zabbix监控系统: 1. 首先,安装dockerdocker-compose,确保已经安装了最新版本的dockerdocker-compose。 2. 创建一个目录,用于存放docker-compose.yml文件和zabbix数据文件。 3. 在该目录下创建docker-compose.yml文件,内容如下: ``` version: '2.2' services: zabbix-server: image: zabbix/zabbix-server-pgsql:latest container_name: zabbix-server restart: always ports: - "10051:10051" environment: DB_SERVER_HOST: zabbix-db POSTGRES_USER: zabbix POSTGRES_PASSWORD: zabbix POSTGRES_DB: zabbix depends_on: - zabbix-db networks: - zabbix zabbix-web: image: zabbix/zabbix-web-nginx-pgsql:latest container_name: zabbix-web restart: always ports: - "80:8080" environment: DB_SERVER_HOST: zabbix-db POSTGRES_USER: zabbix POSTGRES_PASSWORD: zabbix POSTGRES_DB: zabbix ZBX_SERVER_HOST: zabbix-server PHP_TZ: "Asia/Shanghai" depends_on: - zabbix-db - zabbix-server networks: - zabbix zabbix-db: image: postgres:12-alpine container_name: zabbix-db restart: always environment: POSTGRES_USER: zabbix POSTGRES_PASSWORD: zabbix POSTGRES_DB: zabbix volumes: - ./zabbix-data:/var/lib/postgresql/data networks: - zabbix networks: zabbix: ``` 4. 运行docker-compose命令启动zabbix容器: ``` docker-compose up -d ``` 5. 访问http://localhost,进入zabbix Web界面,进行初始化设置。 6. 在zabbix Web界面中,添加主机、监控项、触发器等配置,即可开始监控。 注意:在docker-compose.yml文件中,使用zabbix官方提供的zabbix-server-pgsql、zabbix-web-nginx-pgsql和postgres镜像,因此无需手动安装和配置zabbix和数据库,可以直接启动容器进行监控。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值