day058-docker常见面试题与初识zabbix
文章目录
- 0. 老男孩核心思想-人性思维方式
 - 1. docker常见面试题
 - 1.1 docker单机网络类型
 - 1.1.1 桥接模式
 - 1.1.2 Host主机模式
 - 1.1.3 container容器模式
 
- 1.2 docker跨主机网络类型
 - 1.3 docker的底层原理
 
- 2. zabbix
 - 2.1 监控服务
 - 2.2 zabbix架构
 - 2.3 部署zabbix服务端
 - 2.3.1 导入镜像
 - 2.3.2 配置docker-compose文件
 - 2.3.3 浏览器访问web页面
 
- 2.4 部署zabbix客户端
 - 2.4.1 官方下载客户端
 - 2.4.2 阿里云下载客户端
 - 2.4.3 修改配置文件
 
- 2.5 前端页面配置服务端主机
 - 2.6 监控主机流程
 - 2.6.1 客户端配置
 - 2.6.2 前端添加客户端主机
 
- 3. 思维导图
 
0. 老男孩核心思想-人性思维方式

1. docker常见面试题
1.1 docker单机网络类型
| docker单机网络类型 | 说明 | 
|---|---|
| bridge桥接 | 默认网络类型; 类似于虚拟机的NAT模式  | 
| 自定网络 | 自定义网络网段,一般与桥接搭配 | 
| host模式 | 与宿主机共用网卡,优势:性能好; 缺点:ip都一样,端口不能冲突  | 
| container模式 | 多个容器同用一个ip | 
| none | 无网络 | 
1.1.1 桥接模式

1.1.2 Host主机模式

1.1.3 container容器模式
Container模式是Docker的一种特殊网络模式,它允许一个容器共享另一个容器的网络命名空间,而不是使用独立的网络栈。这种模式适用于需要紧密网络耦合的场景,例如日志收集、Sidecar代理等。
- 主容器(如 
nginx)拥有自己的网络命名空间(IP、端口、路由等)。 - 副容器(如 
log-collector)共享主容器的网络栈,没有独立的IP,直接使用主容器的网络接口。 

1.2 docker跨主机网络类型

| 跨主机的网络类型 | 特点 | 
|---|---|
| macvlan | (1)docker原⽣⽀持,⽆需安装额外插件,配置起来相对简单。 (2)适合⼩规模docker环境,例如只有1-3台,如果服务器过多, ⼿动分配IP地址可能会⽆形之间增加⼯作量; 缺点: 需要⼿动分配IP地址,容器⽆⽹络。  | 
| overlay | ⼀般给docker swarm集群使⽤. 早期20.10overlay可以直接使⽤. 23,24版本只能搭配swarm使⽤.  | 
| fannel | k8s编排容器的时候使⽤的⽹络结构 | 
| calico | k8s编排容器的时候使⽤的⽹络结构 | 
1.3 docker的底层原理
- 容器是隔离环境中运行的一个进程;如果进程结束,容器就会停止
 - 容器的隔离环境,拥有自己的IP地址,系统文件,主机名,进程管理,相当于一个mini系统
 - 容器技术是基于Linux内核技术实现的 
- namespace:命名空间,资源隔离
 - cgroup:资源控制/限制
 - overlayfs:文件系统
 - chroot:切换根目录
 
 - namespace分类:
 
| namespace分类 | 说明 | 
|---|---|
| net | 网络资源隔离 | 
| user | 用户id,信息隔离 | 
| mnt | 磁盘资源隔离 | 
| ipc | 进程通讯资源格式 | 
| pid | 进程id隔离 | 
| uts | 系统资源,比如主机名隔离 | 
2. zabbix
- 服务端端口:10051
 - 客户端端口:10050
 
2.1 监控服务
| 监控服务 | 说明 | 
|---|---|
| zabbix | 监控系统底层环境;有模板,上手简单(前端是php页面) | 
| Prometheus | 通过各种客户端(exporter监控),性能高(golang),适用于docker、k8s容器监控 | 
| grafana | 优雅显示,监控大屏(获取zabbix或Prometheus数据) | 
| open falcon | 小米 | 
| n9e(夜莺 Nighngale) | 滴滴 | 
| 云监控(CMS) | 云产品 | 
| skywalking监控 | 链路监控(apm) | 
2.2 zabbix架构

2.3 部署zabbix服务端
- 镜像与docker-compose文件:
docker-compose.yml等4个文件 链接: https://pan.baidu.com/s/1-ZvhlB1JwvLpXQkhWQqnWg?pwd=vf2k 提取码: vf2k - 基础环境:docker、docker-compose
 
2.3.1 导入镜像
[root@m03 ~]# ll
-rw-r--r-- 1 root root      1607  7月 18 08:11 docker-compose.yml # docker-compose文件:自动化启动zabbix服务端容器
-rw-r--r-- 1 root root 615832064  7月 18 12:16 mysql-8.0.tar # 数据库容器
-rw-r--r-- 1 root root 334369792  7月 18 12:16 zbx-server-mysql-7.0.9.tar # zabbix服务端容器
-rw-r--r-- 1 root root 464802304  7月 18 12:16 zbx-web-ngx-mysql-7.0.9.tar # zabbix前端容器
# 导入镜像
[root@m03 ~]# for i in `ls *.tar` ;do docker load -i $i ;done
……
[root@m03 ~]# docker images
REPOSITORY                      TAG            IMAGE ID       CREATED         SIZE
zabbix/zabbix-web-nginx-mysql   7.0.9-ubuntu   b5019f1efaa9   5 months ago    455MB
zabbix/zabbix-server-mysql      7.0.9-ubuntu   77801f625b74   5 months ago    327MB
mysql                           8.0-debian     44a5ac32be1d   12 months ago   611MB
 
2.3.2 配置docker-compose文件
- zabbix-server、zabbix前端页面以及Mysql都需要数据库变量,可以将数据库变量写入文件,统一调用
 
# docker-compose变量
[root@m03 /app/tools/zbx]# cat .env 
ROOT_PASS="Root123"
ZBX_DB="zabbix"
ZBX_USER="zabbix"
ZBX_PASS="pwd"
# docker-compose文件
[root@m03 /app/tools/zbx]# cat docker-compose.yml 
#version: "3.8"
services:  db:  image: mysql:8.0-debiancontainer_name: zbx_dbnetworks:   - oldboy_zbx_net  restart: always   volumes:  - ./zbx_db/:/var/lib/mysql/environment:  MYSQL_ROOT_PASSWORD: "${ROOT_PASS}"MYSQL_DATABASE: "${ZBX_DB}"MYSQL_USER:     "${ZBX_USER}"MYSQL_PASSWORD: "${ZBX_PASS}"command:  - --character-set-server=utf8  - --collation-server=utf8_bin  - --default-authentication-plugin=mysql_native_password  zbx_server:image: zabbix/zabbix-server-mysql:7.0.9-ubuntucontainer_name: zabbix-server-mysql-7.0networks:   - oldboy_zbx_net  restart: always   ports:  - 10051:10051depends_on:- dbenvironment:  DB_SERVER_HOST: "db"MYSQL_ROOT_PASSWORD: "${ROOT_PASS}"MYSQL_DATABASE: "${ZBX_DB}"MYSQL_USER:     "${ZBX_USER}"MYSQL_PASSWORD: "${ZBX_PASS}"zbx_web:image: zabbix/zabbix-web-nginx-mysql:7.0.9-ubuntucontainer_name: zabbix-web-nginx-mysqlnetworks:   - oldboy_zbx_net  restart: always   ports:  - 80:8080depends_on:- db- zbx_serverenvironment:  ZBX_SERVER_HOST: "zbx_server"DB_SERVER_HOST: "db"MYSQL_ROOT_PASSWORD: "${ROOT_PASS}"MYSQL_DATABASE: "${ZBX_DB}"MYSQL_USER:     "${ZBX_USER}"MYSQL_PASSWORD: "${ZBX_PASS}"networks:  oldboy_zbx_net:  driver: bridge  ipam:  config:  - subnet: 172.100.0.0/16  ip_range: 172.100.1.0/24  gateway: 172.100.1.1# 启动容器
[root@m03 /app/tools/zbx]# docker-compose up -d
[+] Running 3/3✔ Container zbx_db                   Started                                                  1.7s ✔ Container zabbix-server-mysql-7.0  Started                                                  1.6s ✔ Container zabbix-web-nginx-mysql   Started                                                  1.8s 
[root@m03 /app/tools/zbx]# docker ps
CONTAINER ID   IMAGE                                        COMMAND                   CREATED          STATUS                            PORTS                                             NAMES
a7db1b841689   zabbix/zabbix-web-nginx-mysql:7.0.9-ubuntu   "docker-entrypoint.sh"    10 seconds ago   Up 8 seconds (health: starting)   8443/tcp, 0.0.0.0:80->8080/tcp, :::80->8080/tcp   zabbix-web-nginx-mysql
925d50fe425e   zabbix/zabbix-server-mysql:7.0.9-ubuntu      "/usr/bin/docker-ent…"   11 seconds ago   Up 9 seconds                      0.0.0.0:10051->10051/tcp, :::10051->10051/tcp     zabbix-server-mysql-7.0
9efc68ea5d19   mysql:8.0-debian                             "docker-entrypoint.s…"   11 seconds ago   Up 10 seconds                     3306/tcp, 33060/tcp                               zbx_db
 
2.3.3 浏览器访问web页面
- 主机做好hosts
 


- 修改语言和时区
 

2.4 部署zabbix客户端
- zabbix服务端需要自我监控,所以需要安装zabbix-agent2
 
2.4.1 官方下载客户端
[下载Zabbix 7.0 LTS for Red Hat Enterprise Linux 7](https://www.zabbix.com/cn/download?zabbix=7.0&os_distribution=red_hat_enterprise_linux&os_version=7&components=agent_2&db=&ws=)


2.4.2 阿里云下载客户端
[zabbix-zabbix-7.0-rhel-7-x86_64安装包下载_开源镜像站-阿里云](https://mirrors.aliyun.com/zabbix/zabbix/7.0/rhel/7/x86_64/?spm=a2c6h.25603864.0.0.45f246a3iL3tFU)
[root@m03 ~]# yum install -y https://mirrors.aliyun.com/zabbix/zabbix/7.0/rhel/7/x86_64/zabbix-agent2-7.0.0-release1.el7.x86_64.rpm
……
 
2.4.3 修改配置文件
- zabbix-agent2配置文件路径:
/etc/zabbix/zabbix_agent2.conf 
[root@m03 ~]# grep -E '^Server=' /etc/zabbix/zabbix_agent2.conf
Server=172.16.1.63,172.100.1.0/16  # zabbix服务端地址,docker容器网段;其他客户端只写服务端IP即可
[root@m03 ~]# systemctl enable --now zabbix-agent2.service 
Created symlink /etc/systemd/system/multi-user.target.wants/zabbix-agent2.service → /usr/lib/systemd/system/zabbix-agent2.service.
 
2.5 前端页面配置服务端主机


2.6 监控主机流程
2.6.1 客户端配置
[root@web01.oldboy.cn ~]# yum install -y https://mirrors.aliyun.com/zabbix/zabbix/7.0/rhel/7/x86_64/zabbix-agent2-7.0.0-release1.el7.x86_64.rpm
[root@web01.oldboy.cn ~]# vim /etc/zabbix/zabbix_agent2.conf 
[root@web01.oldboy.cn ~]# grep '^Server=' /etc/zabbix/zabbix_agent2.conf
Server=172.16.1.63
[root@web01.oldboy.cn ~]# systemctl enable --now zabbix-agent2.service 
Created symlink /etc/systemd/system/multi-user.target.wants/zabbix-agent2.service → /usr/lib/systemd/system/zabbix-agent2.service.
 
2.6.2 前端添加客户端主机



3. 思维导图
https://kdocs.cn/join/gpuxq6r?f=101\r\n邀请你加入共享群「老男孩教育Linux运维99期-孙克旭」一起进行文档协作
